From 74785bd70d082da9ec1c3efbc56bb76a9a297182 Mon Sep 17 00:00:00 2001 From: Tobie Morgan Hitchcock Date: Sun, 13 May 2018 22:14:19 +0100 Subject: [PATCH] Add support for array index ranges in SQL queries --- sql/scanner.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/sql/scanner.go b/sql/scanner.go index f6b5919a..f5d984cf 100644 --- a/sql/scanner.go +++ b/sql/scanner.go @@ -489,14 +489,17 @@ func (s *scanner) scanIdiom(chp ...rune) (tok Token, lit string, val interface{} break } else if isIdentChar(ch) { buf.WriteRune(ch) + } else if isArrayChar(ch) { + tok = EXPR + buf.WriteRune(ch) } else if isExprsChar(ch) { tok = EXPR buf.WriteRune(ch) } else if ch == ':' { if tok == EXPR { - s.undo() - break + buf.WriteRune(ch) + continue } tbv = buf.String() @@ -1048,9 +1051,14 @@ func isThingChar(ch rune) bool { return isLetter(ch) || isNumber(ch) || ch == '_' } +// isArrayChar returns true if the rune is allowed in an ARRAY. +func isArrayChar(ch rune) bool { + return ch == '[' || ch == ']' +} + // isExprsChar returns true if the rune is allowed in a IDENT. func isExprsChar(ch rune) bool { - return isLetter(ch) || isNumber(ch) || ch == '.' || ch == '_' || ch == '*' || ch == '[' || ch == '$' || ch == ']' + return isLetter(ch) || isNumber(ch) || ch == '.' || ch == '_' || ch == '*' || ch == '$' } // eof represents a marker rune for the end of the reader.