From b24a2b89926615dee176c39361db76bdfb994a99 Mon Sep 17 00:00:00 2001 From: Paresh Mathur Date: Sat, 24 Oct 2020 14:53:21 +0200 Subject: [PATCH] Fix failing case of Bytes parser when there is only 1 byte in the stream --- src/CombinedParsers.jl | 4 ++-- test/test-parser.jl | 9 +++++++-- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/src/CombinedParsers.jl b/src/CombinedParsers.jl index 10461fc..27a513b 100644 --- a/src/CombinedParsers.jl +++ b/src/CombinedParsers.jl @@ -494,8 +494,8 @@ end If available before end of sequence, parse `N` bytes successfully with `result_type` `T`, fail otherwise. """ Bytes(N::Integer, T::Type=Vector{UInt8}) = Bytes{T}(N) -_iterate(parser::Bytes, sequence, till, posi, next_i, state::Nothing) = - posi+parser.N <= till ? (nextind(sequence,posi,parser.N), MatchState()) : nothing +_iterate(parser::Bytes, sequence, till, posi, next_i, state::Nothing) = + posi+parser.N <= till+1 ? (nextind(sequence,posi,parser.N), MatchState()) : nothing _iterate(parser::Bytes, sequence, till, posi, next_i, state::MatchState) = nothing regex_string_(x::Bytes{N}) where N = ".{$(N)}" diff --git a/test/test-parser.jl b/test/test-parser.jl index c0dcddc..a7318ad 100644 --- a/test/test-parser.jl +++ b/test/test-parser.jl @@ -54,9 +54,14 @@ end dat = 'a'^(new_Repeat_max)*'b'; @test String(parse(Repeat_stop('a','b';max=new_Repeat_max), dat))==dat[1:end-1] end -end - +@testset "Bytes" begin + # simple test for binary parsing + @test parse(Bytes(1,UInt8),[0x33]) == 0x33 + @test parse(Bytes(2,UInt16),[0x33,0x66]) == 0x6633 + @test parse(Bytes(4,Float32),[0x55,0x77,0x33,0x66]) == reinterpret(Float32,0x66337755) +end +end @testset "FlatMap" begin @test parse(