Variable reference from $VAR to @VAR to avoid object conflict
This commit is contained in:
@@ -36,6 +36,7 @@ const (
|
||||
TokenCaret
|
||||
TokenAmpersand
|
||||
TokenConcat
|
||||
TokenVariableReference
|
||||
)
|
||||
|
||||
type Token struct {
|
||||
@@ -184,6 +185,8 @@ func (l *Lexer) NextToken() Token {
|
||||
return l.lexString()
|
||||
case '#':
|
||||
return l.lexHashIdentifier()
|
||||
case '@':
|
||||
return l.lexVariableReference()
|
||||
case '$':
|
||||
return l.lexObjectIdentifier()
|
||||
}
|
||||
@@ -311,3 +314,14 @@ func (l *Lexer) lexHashIdentifier() Token {
|
||||
}
|
||||
return l.emit(TokenIdentifier)
|
||||
}
|
||||
|
||||
func (l *Lexer) lexVariableReference() Token {
|
||||
for {
|
||||
r := l.next()
|
||||
if unicode.IsLetter(r) || unicode.IsDigit(r) || r == '_' || r == '-' {
|
||||
continue
|
||||
}
|
||||
l.backup()
|
||||
return l.emit(TokenVariableReference)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user