jsoniter.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911
  1. package jsoniter
  2. import (
  3. "io"
  4. "fmt"
  5. "unicode/utf16"
  6. "strconv"
  7. "unsafe"
  8. )
  9. var digits []byte
  10. func init() {
  11. digits = make([]byte, 256)
  12. for i := 0; i < len(digits); i++ {
  13. digits[i] = 255
  14. }
  15. for i := '0'; i <= '9'; i++ {
  16. digits[i] = byte(i - '0');
  17. }
  18. for i := 'a'; i <= 'f'; i++ {
  19. digits[i] = byte((i - 'a') + 10);
  20. }
  21. for i := 'A'; i <= 'F'; i++ {
  22. digits[i] = byte((i - 'A') + 10);
  23. }
  24. }
  25. type Iterator struct {
  26. reader io.Reader
  27. buf []byte
  28. head int
  29. tail int
  30. Error error
  31. }
  32. func Parse(reader io.Reader, bufSize int) *Iterator {
  33. iter := &Iterator{
  34. reader: reader,
  35. buf: make([]byte, bufSize),
  36. head: 0,
  37. tail: 0,
  38. }
  39. iter.skipWhitespaces()
  40. return iter
  41. }
  42. func ParseBytes(input []byte) *Iterator {
  43. iter := &Iterator{
  44. reader: nil,
  45. buf: input,
  46. head: 0,
  47. tail: len(input),
  48. }
  49. iter.skipWhitespaces()
  50. return iter
  51. }
  52. func (iter *Iterator) Reuse(input []byte) *Iterator {
  53. // only for benchmarking
  54. iter.reader = nil
  55. iter.Error = nil
  56. iter.buf = input
  57. iter.head = 0
  58. iter.tail = len(input)
  59. iter.skipWhitespaces()
  60. return iter
  61. }
  62. func ParseString(input string) *Iterator {
  63. return ParseBytes([]byte(input))
  64. }
  65. func (iter *Iterator) skipWhitespaces() {
  66. for {
  67. for i := iter.head; i < iter.tail; i++ {
  68. c := iter.buf[i]
  69. switch c {
  70. case ' ', '\n', '\t', 'r':
  71. continue
  72. }
  73. iter.head = i
  74. return
  75. }
  76. if !iter.loadMore() {
  77. return
  78. }
  79. }
  80. }
  81. func (iter *Iterator) nextToken() byte {
  82. for {
  83. for i := iter.head; i < iter.tail; i++ {
  84. c := iter.buf[i]
  85. switch c {
  86. case ' ', '\n', '\t', 'r':
  87. continue
  88. }
  89. iter.head = i+1
  90. return c
  91. }
  92. if !iter.loadMore() {
  93. return 0
  94. }
  95. }
  96. }
  97. func (iter *Iterator) ReportError(operation string, msg string) {
  98. if iter.Error != nil {
  99. return
  100. }
  101. peekStart := iter.head - 10
  102. if peekStart < 0 {
  103. peekStart = 0
  104. }
  105. iter.Error = fmt.Errorf("%s: %s, parsing %v ...%s... at %s", operation, msg, iter.head,
  106. string(iter.buf[peekStart: iter.head]), string(iter.buf[0:iter.tail]))
  107. }
  108. func (iter *Iterator) CurrentBuffer() string {
  109. peekStart := iter.head - 10
  110. if peekStart < 0 {
  111. peekStart = 0
  112. }
  113. return fmt.Sprintf("parsing %v ...%s... at %s", iter.head,
  114. string(iter.buf[peekStart: iter.head]), string(iter.buf[0:iter.tail]))
  115. }
  116. func (iter *Iterator) readByte() (ret byte) {
  117. if iter.head == iter.tail {
  118. if iter.loadMore() {
  119. ret = iter.buf[iter.head]
  120. iter.head++
  121. return ret
  122. }
  123. }
  124. ret = iter.buf[iter.head]
  125. iter.head++
  126. return ret
  127. }
  128. func (iter *Iterator) loadMore() bool {
  129. if iter.reader == nil {
  130. iter.Error = io.EOF
  131. return false
  132. }
  133. for {
  134. n, err := iter.reader.Read(iter.buf)
  135. if n == 0 {
  136. if err != nil {
  137. iter.Error = err
  138. return false
  139. } else {
  140. // n == 0, err == nil is not EOF
  141. continue
  142. }
  143. } else {
  144. iter.head = 0
  145. iter.tail = n
  146. return true
  147. }
  148. }
  149. }
  150. func (iter *Iterator) unreadByte() {
  151. if iter.head == 0 {
  152. iter.ReportError("unreadByte", "unread too many bytes")
  153. return
  154. }
  155. iter.head -= 1
  156. return
  157. }
  158. const maxUint64 = (1 << 64 - 1)
  159. const cutoffUint64 = maxUint64 / 10 + 1
  160. const maxUint32 = (1 << 32 - 1)
  161. const cutoffUint32 = maxUint32 / 10 + 1
  162. func (iter *Iterator) ReadUint() (ret uint) {
  163. val := iter.ReadUint64()
  164. converted := uint(val)
  165. if uint64(converted) != val {
  166. iter.ReportError("ReadUint", "int overflow")
  167. return
  168. }
  169. return converted
  170. }
  171. func (iter *Iterator) ReadUint8() (ret uint8) {
  172. val := iter.ReadUint64()
  173. converted := uint8(val)
  174. if uint64(converted) != val {
  175. iter.ReportError("ReadUint8", "int overflow")
  176. return
  177. }
  178. return converted
  179. }
  180. func (iter *Iterator) ReadUint16() (ret uint16) {
  181. val := iter.ReadUint64()
  182. converted := uint16(val)
  183. if uint64(converted) != val {
  184. iter.ReportError("ReadUint16", "int overflow")
  185. return
  186. }
  187. return converted
  188. }
  189. func (iter *Iterator) ReadUint32() (ret uint32) {
  190. val := iter.ReadUint64()
  191. converted := uint32(val)
  192. if uint64(converted) != val {
  193. iter.ReportError("ReadUint32", "int overflow")
  194. return
  195. }
  196. return converted
  197. }
  198. func (iter *Iterator) ReadUint64() (ret uint64) {
  199. c := iter.readByte()
  200. v := digits[c]
  201. if v == 0 {
  202. return 0 // single zero
  203. }
  204. if v == 255 {
  205. iter.ReportError("ReadUint64", "unexpected character")
  206. return
  207. }
  208. for {
  209. if ret >= cutoffUint64 {
  210. iter.ReportError("ReadUint64", "overflow")
  211. return
  212. }
  213. ret = ret * 10 + uint64(v)
  214. c = iter.readByte()
  215. v = digits[c]
  216. if v == 255 {
  217. iter.unreadByte()
  218. break
  219. }
  220. }
  221. return ret
  222. }
  223. func (iter *Iterator) ReadInt() (ret int) {
  224. val := iter.ReadInt64()
  225. converted := int(val)
  226. if int64(converted) != val {
  227. iter.ReportError("ReadInt", "int overflow")
  228. return
  229. }
  230. return converted
  231. }
  232. func (iter *Iterator) ReadInt8() (ret int8) {
  233. val := iter.ReadInt64()
  234. converted := int8(val)
  235. if int64(converted) != val {
  236. iter.ReportError("ReadInt8", "int overflow")
  237. return
  238. }
  239. return converted
  240. }
  241. func (iter *Iterator) ReadInt16() (ret int16) {
  242. val := iter.ReadInt64()
  243. converted := int16(val)
  244. if int64(converted) != val {
  245. iter.ReportError("ReadInt16", "int overflow")
  246. return
  247. }
  248. return converted
  249. }
  250. func (iter *Iterator) ReadInt32() (ret int32) {
  251. val := iter.ReadInt64()
  252. converted := int32(val)
  253. if int64(converted) != val {
  254. iter.ReportError("ReadInt32", "int overflow")
  255. return
  256. }
  257. return converted
  258. }
  259. func (iter *Iterator) ReadInt64() (ret int64) {
  260. c := iter.readByte()
  261. if iter.Error != nil {
  262. return
  263. }
  264. /* optional leading minus */
  265. if c == '-' {
  266. n := iter.ReadUint64()
  267. return -int64(n)
  268. } else {
  269. iter.unreadByte()
  270. n := iter.ReadUint64()
  271. return int64(n)
  272. }
  273. }
  274. func (iter *Iterator) ReadString() (ret string) {
  275. return string(iter.ReadStringAsBytes())
  276. }
  277. // Tries to find the end of string
  278. // Support if string contains escaped quote symbols.
  279. func stringEnd(data []byte) (int, bool) {
  280. escaped := false
  281. for i, c := range data {
  282. if c == '"' {
  283. if !escaped {
  284. return i + 1, false
  285. } else {
  286. j := i - 1
  287. for {
  288. if j < 0 || data[j] != '\\' {
  289. return i + 1, true // even number of backslashes
  290. }
  291. j--
  292. if j < 0 || data[j] != '\\' {
  293. break // odd number of backslashes
  294. }
  295. j--
  296. }
  297. }
  298. } else if c == '\\' {
  299. escaped = true
  300. }
  301. }
  302. return -1, escaped
  303. }
  304. func (iter *Iterator) ReadStringAsBytes() (ret []byte) {
  305. c := iter.readByte()
  306. if c == 'n' {
  307. iter.skipNull()
  308. return
  309. }
  310. if c != '"' {
  311. iter.ReportError("ReadString", `expects " or n`)
  312. return
  313. }
  314. end, escaped := stringEnd(iter.buf[iter.head:iter.tail])
  315. if end != -1 && !escaped {
  316. ret = iter.buf[iter.head:iter.head+end-1]
  317. iter.head += end
  318. return ret
  319. }
  320. str := make([]byte, 0, 8)
  321. for iter.Error == nil {
  322. c = iter.readByte()
  323. if c == '"' {
  324. return str
  325. }
  326. if c == '\\' {
  327. c = iter.readByte()
  328. if iter.Error != nil {
  329. return
  330. }
  331. switch c {
  332. case 'u':
  333. r := iter.readU4()
  334. if iter.Error != nil {
  335. return
  336. }
  337. if utf16.IsSurrogate(r) {
  338. c = iter.readByte()
  339. if iter.Error != nil {
  340. return
  341. }
  342. if c != '\\' {
  343. iter.ReportError("ReadString",
  344. `expects \u after utf16 surrogate, but \ not found`)
  345. return
  346. }
  347. c = iter.readByte()
  348. if iter.Error != nil {
  349. return
  350. }
  351. if c != 'u' {
  352. iter.ReportError("ReadString",
  353. `expects \u after utf16 surrogate, but \u not found`)
  354. return
  355. }
  356. r2 := iter.readU4()
  357. if iter.Error != nil {
  358. return
  359. }
  360. combined := utf16.DecodeRune(r, r2)
  361. str = appendRune(str, combined)
  362. } else {
  363. str = appendRune(str, r)
  364. }
  365. case '"':
  366. str = append(str, '"')
  367. case '\\':
  368. str = append(str, '\\')
  369. case '/':
  370. str = append(str, '/')
  371. case 'b':
  372. str = append(str, '\b')
  373. case 'f':
  374. str = append(str, '\f')
  375. case 'n':
  376. str = append(str, '\n')
  377. case 'r':
  378. str = append(str, '\r')
  379. case 't':
  380. str = append(str, '\t')
  381. default:
  382. iter.ReportError("ReadString",
  383. `invalid escape char after \`)
  384. return
  385. }
  386. } else {
  387. str = append(str, c)
  388. }
  389. }
  390. return
  391. }
  392. func (iter *Iterator) readU4() (ret rune) {
  393. for i := 0; i < 4; i++ {
  394. c := iter.readByte()
  395. if iter.Error != nil {
  396. return
  397. }
  398. if (c >= '0' && c <= '9') {
  399. if ret >= cutoffUint32 {
  400. iter.ReportError("readU4", "overflow")
  401. return
  402. }
  403. ret = ret * 16 + rune(c - '0')
  404. } else if ((c >= 'a' && c <= 'f') ) {
  405. if ret >= cutoffUint32 {
  406. iter.ReportError("readU4", "overflow")
  407. return
  408. }
  409. ret = ret * 16 + rune(c - 'a' + 10)
  410. } else {
  411. iter.ReportError("readU4", "expects 0~9 or a~f")
  412. return
  413. }
  414. }
  415. return ret
  416. }
  417. const (
  418. t1 = 0x00 // 0000 0000
  419. tx = 0x80 // 1000 0000
  420. t2 = 0xC0 // 1100 0000
  421. t3 = 0xE0 // 1110 0000
  422. t4 = 0xF0 // 1111 0000
  423. t5 = 0xF8 // 1111 1000
  424. maskx = 0x3F // 0011 1111
  425. mask2 = 0x1F // 0001 1111
  426. mask3 = 0x0F // 0000 1111
  427. mask4 = 0x07 // 0000 0111
  428. rune1Max = 1 << 7 - 1
  429. rune2Max = 1 << 11 - 1
  430. rune3Max = 1 << 16 - 1
  431. surrogateMin = 0xD800
  432. surrogateMax = 0xDFFF
  433. MaxRune = '\U0010FFFF' // Maximum valid Unicode code point.
  434. RuneError = '\uFFFD' // the "error" Rune or "Unicode replacement character"
  435. )
  436. func appendRune(p []byte, r rune) []byte {
  437. // Negative values are erroneous. Making it unsigned addresses the problem.
  438. switch i := uint32(r); {
  439. case i <= rune1Max:
  440. p = append(p, byte(r))
  441. return p
  442. case i <= rune2Max:
  443. p = append(p, t2 | byte(r >> 6))
  444. p = append(p, tx | byte(r) & maskx)
  445. return p
  446. case i > MaxRune, surrogateMin <= i && i <= surrogateMax:
  447. r = RuneError
  448. fallthrough
  449. case i <= rune3Max:
  450. p = append(p, t3 | byte(r >> 12))
  451. p = append(p, tx | byte(r >> 6) & maskx)
  452. p = append(p, tx | byte(r) & maskx)
  453. return p
  454. default:
  455. p = append(p, t4 | byte(r >> 18))
  456. p = append(p, tx | byte(r >> 12) & maskx)
  457. p = append(p, tx | byte(r >> 6) & maskx)
  458. p = append(p, tx | byte(r) & maskx)
  459. return p
  460. }
  461. }
  462. func (iter *Iterator) ReadArray() (ret bool) {
  463. c := iter.nextToken()
  464. if iter.Error != nil {
  465. return
  466. }
  467. switch c {
  468. case 'n': {
  469. iter.skipNull()
  470. return false // null
  471. }
  472. case '[': {
  473. c = iter.nextToken()
  474. if iter.Error != nil {
  475. return
  476. }
  477. if c == ']' {
  478. return false
  479. } else {
  480. iter.unreadByte()
  481. return true
  482. }
  483. }
  484. case ']': return false
  485. case ',':
  486. iter.skipWhitespaces()
  487. return true
  488. default:
  489. iter.ReportError("ReadArray", "expect [ or , or ] or n")
  490. return
  491. }
  492. }
  493. func (iter *Iterator) ReadArrayCB(cb func()) {
  494. c := iter.nextToken()
  495. if c == 'n' {
  496. iter.skipNull()
  497. return // null
  498. }
  499. if c != '[' {
  500. iter.ReportError("ReadArrayCB", "expect [ or n")
  501. return
  502. }
  503. c = iter.nextToken()
  504. if c == ']' {
  505. return // []
  506. } else {
  507. iter.unreadByte()
  508. }
  509. for {
  510. if iter.Error != nil {
  511. return
  512. }
  513. cb()
  514. c = iter.nextToken()
  515. if c == ']' {
  516. return
  517. }
  518. if c != ',' {
  519. iter.ReportError("ReadArrayCB", "expect , or ]")
  520. return
  521. }
  522. iter.skipWhitespaces()
  523. }
  524. }
  525. func (iter *Iterator) ReadObjectCB(cb func(string)) {
  526. c := iter.nextToken()
  527. if c == 'n' {
  528. iter.skipNull()
  529. return // null
  530. }
  531. if c != '{' {
  532. iter.ReportError("ReadObjectCB", "expect { or n")
  533. return
  534. }
  535. c = iter.nextToken()
  536. if c == '}' {
  537. return // []
  538. } else {
  539. iter.unreadByte()
  540. }
  541. for {
  542. iter.skipWhitespaces()
  543. field := iter.readObjectField()
  544. if iter.Error != nil {
  545. return
  546. }
  547. cb(field)
  548. c = iter.nextToken()
  549. if c == '}' {
  550. return // end of object
  551. }
  552. if c != ',' {
  553. iter.ReportError("ReadObjectCB", `expect ,`)
  554. return
  555. }
  556. }
  557. }
  558. func (iter *Iterator) ReadObject() (ret string) {
  559. c := iter.nextToken()
  560. if iter.Error != nil {
  561. return
  562. }
  563. switch c {
  564. case 'n': {
  565. iter.skipNull()
  566. if iter.Error != nil {
  567. return
  568. }
  569. return "" // null
  570. }
  571. case '{': {
  572. c = iter.nextToken()
  573. if iter.Error != nil {
  574. return
  575. }
  576. switch c {
  577. case '}':
  578. return "" // end of object
  579. case '"':
  580. iter.unreadByte()
  581. return iter.readObjectField()
  582. default:
  583. iter.ReportError("ReadObject", `expect " after {`)
  584. return
  585. }
  586. }
  587. case ',':
  588. iter.skipWhitespaces()
  589. return iter.readObjectField()
  590. case '}':
  591. return "" // end of object
  592. default:
  593. iter.ReportError("ReadObject", `expect { or , or } or n`)
  594. return
  595. }
  596. }
  597. func (iter *Iterator) readObjectField() (ret string) {
  598. str := iter.ReadStringAsBytes()
  599. field := *(*string)(unsafe.Pointer(&str))
  600. c := iter.nextToken()
  601. if c != ':' {
  602. iter.ReportError("ReadObject", "expect : after object field")
  603. return
  604. }
  605. iter.skipWhitespaces()
  606. return field
  607. }
  608. func (iter *Iterator) ReadFloat32() (ret float32) {
  609. str := make([]byte, 0, 4)
  610. for c := iter.readByte(); iter.Error == nil; c = iter.readByte() {
  611. switch c {
  612. case '-', '+', '.', 'e', 'E', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9':
  613. str = append(str, c)
  614. continue
  615. default:
  616. iter.unreadByte()
  617. }
  618. break
  619. }
  620. if iter.Error != nil && iter.Error != io.EOF {
  621. return
  622. }
  623. val, err := strconv.ParseFloat(*(*string)(unsafe.Pointer(&str)), 32)
  624. if err != nil {
  625. iter.Error = err
  626. return
  627. }
  628. return float32(val)
  629. }
  630. func (iter *Iterator) ReadFloat64() (ret float64) {
  631. str := make([]byte, 0, 4)
  632. for c := iter.readByte(); iter.Error == nil; c = iter.readByte() {
  633. switch c {
  634. case '-', '+', '.', 'e', 'E', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9':
  635. str = append(str, c)
  636. continue
  637. default:
  638. iter.unreadByte()
  639. }
  640. break
  641. }
  642. if iter.Error != nil && iter.Error != io.EOF {
  643. return
  644. }
  645. val, err := strconv.ParseFloat(*(*string)(unsafe.Pointer(&str)), 64)
  646. if err != nil {
  647. iter.Error = err
  648. return
  649. }
  650. return val
  651. }
  652. func (iter *Iterator) ReadBool() (ret bool) {
  653. c := iter.readByte()
  654. if iter.Error != nil {
  655. return
  656. }
  657. switch c {
  658. case 't':
  659. iter.skipTrue()
  660. if iter.Error != nil {
  661. return
  662. }
  663. return true
  664. case 'f':
  665. iter.skipFalse()
  666. if iter.Error != nil {
  667. return
  668. }
  669. return false
  670. default:
  671. iter.ReportError("ReadBool", "expect t or f")
  672. return
  673. }
  674. }
  675. func (iter *Iterator) skipTrue() {
  676. for {
  677. for i := iter.head; i < iter.tail; i++ {
  678. c := iter.buf[i]
  679. switch c {
  680. case 'r', 'u', 'e':
  681. continue
  682. }
  683. iter.head = i
  684. return
  685. }
  686. if !iter.loadMore() {
  687. return
  688. }
  689. }
  690. }
  691. func (iter *Iterator) skipFalse() {
  692. for {
  693. for i := iter.head; i < iter.tail; i++ {
  694. c := iter.buf[i]
  695. switch c {
  696. case 'a', 'l', 's', 'e':
  697. continue
  698. }
  699. iter.head = i
  700. return
  701. }
  702. if !iter.loadMore() {
  703. return
  704. }
  705. }
  706. }
  707. func (iter *Iterator) ReadNull() (ret bool) {
  708. c := iter.readByte()
  709. if c == 'n' {
  710. iter.skipNull()
  711. return true
  712. }
  713. iter.unreadByte()
  714. return false
  715. }
  716. func (iter *Iterator) skipNull() {
  717. for {
  718. for i := iter.head; i < iter.tail; i++ {
  719. c := iter.buf[i]
  720. switch c {
  721. case 'u', 'l':
  722. continue
  723. }
  724. iter.head = i
  725. return
  726. }
  727. if !iter.loadMore() {
  728. return
  729. }
  730. }
  731. }
  732. func (iter *Iterator) Skip() {
  733. c := iter.readByte()
  734. switch c {
  735. case '"':
  736. iter.skipString()
  737. case '-', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9':
  738. iter.skipNumber()
  739. case '[':
  740. iter.skipArray()
  741. case '{':
  742. iter.skipObject()
  743. case 't':
  744. iter.skipTrue()
  745. case 'f':
  746. iter.skipFalse()
  747. case 'n':
  748. iter.skipNull()
  749. default:
  750. iter.ReportError("Skip", fmt.Sprintf("do not know how to skip: %v", c))
  751. return
  752. }
  753. }
  754. func (iter *Iterator) skipString() {
  755. escaped := false
  756. for {
  757. for i := iter.head; i < iter.tail; i++ {
  758. c := iter.buf[i]
  759. switch c {
  760. case '"':
  761. if escaped {
  762. escaped = false
  763. } else {
  764. iter.head = i+1
  765. return
  766. }
  767. case '\\':
  768. escaped = !escaped
  769. default:
  770. escaped= false
  771. }
  772. }
  773. if !iter.loadMore() {
  774. return
  775. }
  776. }
  777. }
  778. func (iter *Iterator) skipNumber() {
  779. for {
  780. for i := iter.head; i < iter.tail; i++ {
  781. c := iter.buf[i]
  782. switch c {
  783. case '-', '+', '.', 'e', 'E', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9':
  784. continue
  785. }
  786. iter.head = i
  787. return
  788. }
  789. if !iter.loadMore() {
  790. return
  791. }
  792. }
  793. }
  794. func (iter *Iterator) skipArray() {
  795. c := iter.nextToken()
  796. if c == ']' {
  797. return
  798. } else {
  799. iter.unreadByte()
  800. }
  801. for {
  802. if iter.Error != nil {
  803. return
  804. }
  805. iter.Skip()
  806. c = iter.nextToken()
  807. switch c {
  808. case ',':
  809. iter.skipWhitespaces()
  810. continue
  811. case ']':
  812. return
  813. default:
  814. iter.ReportError("skipArray", "expects , or ]")
  815. return
  816. }
  817. }
  818. }
  819. func (iter *Iterator) skipObject() {
  820. c := iter.nextToken()
  821. if c == '}' {
  822. return // end of object
  823. } else {
  824. iter.unreadByte()
  825. }
  826. for {
  827. c = iter.nextToken()
  828. if c != '"' {
  829. iter.ReportError("skipObject", `expects "`)
  830. return
  831. }
  832. iter.skipString()
  833. c = iter.nextToken()
  834. if c != ':' {
  835. iter.ReportError("skipObject", `expects :`)
  836. return
  837. }
  838. iter.skipWhitespaces()
  839. if iter.Error != nil {
  840. return
  841. }
  842. iter.Skip()
  843. c = iter.nextToken()
  844. switch c {
  845. case ',':
  846. iter.skipWhitespaces()
  847. continue
  848. case '}':
  849. return // end of object
  850. default:
  851. iter.ReportError("skipObject", "expects , or }")
  852. return
  853. }
  854. }
  855. }