hcl/token/token.go

85 lines
1.7 KiB
Go
Raw Normal View History

2015-10-04 17:16:43 +00:00
package token
2015-10-03 12:34:06 +00:00
import "strconv"
// Token is the set of lexical tokens of the HCL (HashiCorp Configuration Language)
type Token int
const (
// Special tokens
ILLEGAL Token = iota
EOF
COMMENT
literal_beg
IDENT // literals
NUMBER // 12345
FLOAT // 123.45
BOOL // true,false
STRING // "abc"
literal_end
operator_beg
LBRACK // [
LBRACE // {
COMMA // ,
PERIOD // .
RBRACK // ]
RBRACE // }
ASSIGN // =
ADD // +
SUB // -
operator_end
)
2015-10-03 12:34:06 +00:00
var tokens = [...]string{
ILLEGAL: "ILLEGAL",
EOF: "EOF",
COMMENT: "COMMENT",
IDENT: "IDENT",
NUMBER: "NUMBER",
FLOAT: "FLOAT",
BOOL: "BOOL",
STRING: "STRING",
2015-10-06 17:57:10 +00:00
LBRACK: "LBRACK",
LBRACE: "LBRACE",
COMMA: "COMMA",
PERIOD: "PERIOD",
2015-10-03 12:34:06 +00:00
2015-10-06 17:57:10 +00:00
RBRACK: "RBRACK",
RBRACE: "RBRACE",
2015-10-03 12:34:06 +00:00
2015-10-06 17:57:10 +00:00
ASSIGN: "ASSIGN",
ADD: "ADD",
SUB: "SUB",
2015-10-03 12:34:06 +00:00
}
// String returns the string corresponding to the token tok.
// For operators, delimiters, and keywords the string is the actual
// token character sequence (e.g., for the token ADD, the string is
// "+"). For all other tokens the string corresponds to the token
// constant name (e.g. for the token IDENT, the string is "IDENT").
func (t Token) String() string {
s := ""
if 0 <= t && t < Token(len(tokens)) {
s = tokens[t]
}
if s == "" {
s = "token(" + strconv.Itoa(int(t)) + ")"
}
return s
}
// IsLiteral returns true for tokens corresponding to identifiers and basic
// type literals; it returns false otherwise.
func (t Token) IsLiteral() bool { return literal_beg < t && t < literal_end }
// IsOperator returns true for tokens corresponding to operators and
// delimiters; it returns false otherwise.
func (t Token) IsOperator() bool { return operator_beg < t && t < operator_end }