diff options
author | 2025-03-09 17:47:56 +0100 | |
---|---|---|
committer | 2025-03-10 01:59:49 +0100 | |
commit | 3ac1ee16f377d31a0fb80c8dae28b6239ac4229e (patch) | |
tree | f61faa581feaaeaba2542b9f2b8234a590684413 /vendor/github.com/uptrace/bun/dialect/pgdialect/array_parser.go | |
parent | [chore] update URLs to forked source (diff) | |
download | gotosocial-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.go | 93 |
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 - } -} |