mirror of
https://github.com/json-iterator/go.git
synced 2024-11-24 08:22:14 +02:00
Merge pull request #373 from ernado/append-skip
fix #372: add AppendSkip iterator method
This commit is contained in:
commit
27518f6661
25
iter_skip.go
25
iter_skip.go
@ -37,17 +37,24 @@ func (iter *Iterator) SkipAndReturnBytes() []byte {
|
|||||||
return iter.stopCapture()
|
return iter.stopCapture()
|
||||||
}
|
}
|
||||||
|
|
||||||
type captureBuffer struct {
|
// SkipAndAppendBytes skips next JSON element and appends its content to
|
||||||
startedAt int
|
// buffer, returning the result.
|
||||||
captured []byte
|
func (iter *Iterator) SkipAndAppendBytes(buf []byte) []byte {
|
||||||
|
iter.startCaptureTo(buf, iter.head)
|
||||||
|
iter.Skip()
|
||||||
|
return iter.stopCapture()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (iter *Iterator) startCapture(captureStartedAt int) {
|
func (iter *Iterator) startCaptureTo(buf []byte, captureStartedAt int) {
|
||||||
if iter.captured != nil {
|
if iter.captured != nil {
|
||||||
panic("already in capture mode")
|
panic("already in capture mode")
|
||||||
}
|
}
|
||||||
iter.captureStartedAt = captureStartedAt
|
iter.captureStartedAt = captureStartedAt
|
||||||
iter.captured = make([]byte, 0, 32)
|
iter.captured = buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (iter *Iterator) startCapture(captureStartedAt int) {
|
||||||
|
iter.startCaptureTo(make([]byte, 0, 32), captureStartedAt)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (iter *Iterator) stopCapture() []byte {
|
func (iter *Iterator) stopCapture() []byte {
|
||||||
@ -58,13 +65,7 @@ func (iter *Iterator) stopCapture() []byte {
|
|||||||
remaining := iter.buf[iter.captureStartedAt:iter.head]
|
remaining := iter.buf[iter.captureStartedAt:iter.head]
|
||||||
iter.captureStartedAt = -1
|
iter.captureStartedAt = -1
|
||||||
iter.captured = nil
|
iter.captured = nil
|
||||||
if len(captured) == 0 {
|
return append(captured, remaining...)
|
||||||
copied := make([]byte, len(remaining))
|
|
||||||
copy(copied, remaining)
|
|
||||||
return copied
|
|
||||||
}
|
|
||||||
captured = append(captured, remaining...)
|
|
||||||
return captured
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Skip skips a json object and positions to relatively the next json object
|
// Skip skips a json object and positions to relatively the next json object
|
||||||
|
@ -105,6 +105,15 @@ func Test_skip_and_return_bytes_with_reader(t *testing.T) {
|
|||||||
should.Equal(`{"a" : [{"stream": "c"}], "d": 102 }`, string(skipped))
|
should.Equal(`{"a" : [{"stream": "c"}], "d": 102 }`, string(skipped))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Test_append_skip_and_return_bytes_with_reader(t *testing.T) {
|
||||||
|
should := require.New(t)
|
||||||
|
iter := jsoniter.Parse(jsoniter.ConfigDefault, bytes.NewBufferString(`[ {"a" : [{"stream": "c"}], "d": 102 }, "stream"]`), 4)
|
||||||
|
iter.ReadArray()
|
||||||
|
buf := make([]byte, 0, 1024)
|
||||||
|
buf = iter.SkipAndAppendBytes(buf)
|
||||||
|
should.Equal(`{"a" : [{"stream": "c"}], "d": 102 }`, string(buf))
|
||||||
|
}
|
||||||
|
|
||||||
func Test_skip_empty(t *testing.T) {
|
func Test_skip_empty(t *testing.T) {
|
||||||
should := require.New(t)
|
should := require.New(t)
|
||||||
should.NotNil(jsoniter.Get([]byte("")).LastError())
|
should.NotNil(jsoniter.Get([]byte("")).LastError())
|
||||||
|
Loading…
Reference in New Issue
Block a user