From 8d4346edef9b6d8a5e016e48b9f6c59bd2b3ba35 Mon Sep 17 00:00:00 2001 From: Kristoffer Carlsson Date: Sat, 10 Nov 2018 11:27:26 -0500 Subject: [PATCH] restore special case parsing of numbers for in memory JSON (#265) --- src/Parser.jl | 5 ++--- src/specialized.jl | 4 ++-- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/Parser.jl b/src/Parser.jl index 493aa93..d066672 100644 --- a/src/Parser.jl +++ b/src/Parser.jl @@ -20,13 +20,12 @@ abstract type ParserState end mutable struct MemoryParserState <: ParserState utf8::String s::Int - utf8array::Vector{UInt8} end # it is convenient to access MemoryParserState like a Vector{UInt8} to avoid copies Base.@propagate_inbounds Base.getindex(state::MemoryParserState, i::Int) = codeunit(state.utf8, i) Base.length(state::MemoryParserState) = sizeof(state.utf8) -Base.unsafe_convert(::Type{Ptr{UInt8}}, state::MemoryParserState) = unsafe_convert(Ptr{UInt8}, state.utf8) +Base.unsafe_convert(::Type{Ptr{UInt8}}, state::MemoryParserState) = Base.unsafe_convert(Ptr{UInt8}, state.utf8) mutable struct StreamingParserState{T <: IO} <: ParserState io::T @@ -409,7 +408,7 @@ function parse(str::AbstractString; dicttype=Dict{String,Any}, inttype::Type{<:Real}=Int64) pc = _get_parsercontext(dicttype, inttype) - ps = MemoryParserState(str, 1, UInt8[]) + ps = MemoryParserState(str, 1) v = parse_value(pc, ps) chomp_space!(ps) if hasmore(ps) diff --git a/src/specialized.jl b/src/specialized.jl index dee81ba..e204299 100644 --- a/src/specialized.jl +++ b/src/specialized.jl @@ -120,7 +120,7 @@ function parse_string(ps::MemoryParserState, b::IOBuffer) b end -function parse_number(ps::MemoryParserState) +function parse_number(pc::ParserContext, ps::MemoryParserState) s = p = ps.s e = length(ps) isint = true @@ -140,5 +140,5 @@ function parse_number(ps::MemoryParserState) end ps.s = p - number_from_bytes(ps, isint, ps, s, p - 1) + number_from_bytes(pc, ps, isint, ps, s, p - 1) end