summaryrefslogtreecommitdiff
path: root/vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go
diff options
context:
space:
mode:
authorLibravatar Terin Stock <terinjokes@gmail.com>2025-03-09 17:47:56 +0100
committerLibravatar Terin Stock <terinjokes@gmail.com>2025-03-10 01:59:49 +0100
commit3ac1ee16f377d31a0fb80c8dae28b6239ac4229e (patch)
treef61faa581feaaeaba2542b9f2b8234a590684413 /vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go
parent[chore] update URLs to forked source (diff)
downloadgotosocial-3ac1ee16f377d31a0fb80c8dae28b6239ac4229e.tar.xz
[chore] remove vendor
Diffstat (limited to 'vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go')
-rw-r--r--vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go93
1 files changed, 0 insertions, 93 deletions
diff --git a/vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go b/vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go
deleted file mode 100644
index 462f8d91d..000000000
--- a/vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go
+++ /dev/null
@@ -1,93 +0,0 @@
-package pgdialect
-
-import (
- "bytes"
- "fmt"
- "io"
-)
-
-type arrayParser struct {
- p pgparser
-
- elem []byte
- err error
-}
-
-func newArrayParser(b []byte) *arrayParser {
- p := new(arrayParser)
-
- if len(b) < 2 || b[0] != '{' || b[len(b)-1] != '}' {
- p.err = fmt.Errorf("pgdialect: can't parse array: %q", b)
- return p
- }
-
- p.p.Reset(b[1 : len(b)-1])
- return p
-}
-
-func (p *arrayParser) Next() bool {
- if p.err != nil {
- return false
- }
- p.err = p.readNext()
- return p.err == nil
-}
-
-func (p *arrayParser) Err() error {
- if p.err != io.EOF {
- return p.err
- }
- return nil
-}
-
-func (p *arrayParser) Elem() []byte {
- return p.elem
-}
-
-func (p *arrayParser) readNext() error {
- ch := p.p.Read()
- if ch == 0 {
- return io.EOF
- }
-
- switch ch {
- case '}':
- return io.EOF
- case '"':
- b, err := p.p.ReadSubstring(ch)
- if err != nil {
- return err
- }
-
- if p.p.Peek() == ',' {
- p.p.Advance()
- }
-
- p.elem = b
- return nil
- case '[', '(':
- rng, err := p.p.ReadRange(ch)
- if err != nil {
- return err
- }
-
- if p.p.Peek() == ',' {
- p.p.Advance()
- }
-
- p.elem = rng
- return nil
- default:
- lit := p.p.ReadLiteral(ch)
- if bytes.Equal(lit, []byte("NULL")) {
- lit = nil
- }
-
- if p.p.Peek() == ',' {
- p.p.Advance()
- }
-
- p.elem = lit
- return nil
- }
-}