本文整理匯總了Golang中mojom/mojom_parser/lexer.Token.LongLocationString方法的典型用法代碼示例。如果您正苦於以下問題:Golang Token.LongLocationString方法的具體用法?Golang Token.LongLocationString怎麽用?Golang Token.LongLocationString使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類mojom/mojom_parser/lexer.Token
的用法示例。
在下文中一共展示了Token.LongLocationString方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: matchSemicolonToken
func (p *Parser) matchSemicolonToken(previousToken lexer.Token) bool {
if !p.OK() {
return false
}
if p.match(lexer.Semi) {
return true
}
message := fmt.Sprintf("Missing semicolon after %s at %s.",
previousToken, previousToken.LongLocationString())
p.err = &ParseError{ParserErrorCodeUnexpectedToken, message}
return false
}
示例2: matchSemicolonToken
func (p *Parser) matchSemicolonToken(previousToken lexer.Token) bool {
if !p.OK() {
return false
}
if p.match(lexer.SEMI) {
return true
}
message := fmt.Sprintf("Missing semicolon after %s at %s.",
previousToken, previousToken.LongLocationString())
p.err = &ParseError{E_UNEXPECTED_TOKEN, message}
return false
}
示例3: expectedTokenError
// |unexpected| should be a string of the grammatical form "Unexpected token at %s: %s."
// |expected| should be a string of the grammatic form "a semicolon"
func (p *Parser) expectedTokenError(token lexer.Token, unexpected string, expected string) string {
message := fmt.Sprintf(" Expecting %s.", expected)
switch token.Kind {
case lexer.ErrorUnknown, lexer.ErrorIllegalChar,
lexer.ErrorUnterminatedStringLiteral,
lexer.ErrorUnterminatedComment:
message = fmt.Sprintf("%s at %s.", token, token.LongLocationString()) + message
default:
message = fmt.Sprintf(unexpected, token.LongLocationString(), token) + message
}
p.err = &ParseError{ParserErrorCodeUnexpectedToken, message}
return message
}
示例4: expectedTokenError
// |unexpected| should be a string of the grammatical form "Unexpected token at %s: %s."
// |expected| should be a string of the grammatic form "a semicolon"
func (p *Parser) expectedTokenError(token lexer.Token, unexpected string, expected string) string {
message := fmt.Sprintf(" Expecting %s.", expected)
switch token.Kind {
case lexer.ERROR_UNKNOWN, lexer.ERROR_ILLEGAL_CHAR,
lexer.ERROR_UNTERMINATED_STRING_LITERAL,
lexer.ERROR_UNTERMINATED_COMMENT:
message = fmt.Sprintf("%s at %s.", token, token.LongLocationString()) + message
default:
message = fmt.Sprintf(unexpected, token.LongLocationString(), token) + message
}
p.err = &ParseError{E_UNEXPECTED_TOKEN, message}
return message
}
示例5: parseStructField
// STRUCT_FIELD -> TYPE name [ordinal] [equals DEFAULT_VALUE] semi
// DEFAULT_VALUE -> APPROPRIATE_VAL_SPEC | default
// APPROPRIATE_VAL_SPEC -> VALUE_REF {{that resolves to a type that is assignment compatible to the type of the assignee}}
func (p *Parser) parseStructField(attributes *mojom.Attributes) *mojom.StructField {
if !p.OK() {
return nil
}
p.pushChildNode("structField")
defer p.popNode()
fieldType := p.parseType()
fieldName := p.readName()
nameToken := p.lastConsumed
p.attachToken()
ordinalValue, err := p.readOrdinal()
if err != nil {
p.err = p.newInvalidOrdinalError("field", fieldName, nameToken, err)
return nil
}
var defaultValue mojom.ValueRef
var defaultValueToken lexer.Token
if p.tryMatch(lexer.Equals) {
defaultValueToken = p.peekNextToken("Expecting a default value.")
if defaultValueToken.Kind == lexer.Default {
p.consumeNextToken()
defaultValue = mojom.MakeDefaultLiteral()
} else {
defaultValue = p.parseValue(fieldType)
}
}
if !p.matchSemicolon() {
return nil
}
declData := p.DeclDataWithOrdinal(fieldName, nameToken, attributes, ordinalValue)
field := mojom.NewStructField(declData, fieldType, defaultValue)
if !field.ValidateDefaultValue() {
valueString := fmt.Sprintf("%v", defaultValue)
valueTypeString := ""
concreteValue := defaultValue.ResolvedConcreteValue()
if concreteValue != nil {
valueString = fmt.Sprintf("%v", concreteValue.Value())
valueTypeString = fmt.Sprintf(" of type %s", concreteValue.ValueType())
}
message := fmt.Sprintf("Illegal assignment at %s: Field %s of type %s may not be assigned the value %v%s.",
defaultValueToken.LongLocationString(), fieldName, fieldType, valueString, valueTypeString)
p.err = &ParseError{ParserErrorCodeNotAssignmentCompatible, message}
return nil
}
return field
}
示例6: parseStructField
// STRUCT_FIELD -> TYPE name [ordinal] [equals DEFAULT_VALUE] semi
// DEFAULT_VALUE -> APPROPRIATE_VAL_SPEC | default
// APPROPRIATE_VAL_SPEC -> VALUE_REF {{that resolves to a type that is assignment compatible to the type of the assignee}}
func (p *Parser) parseStructField(attributes *mojom.Attributes) *mojom.StructField {
if !p.OK() {
return nil
}
p.pushChildNode("structField")
defer p.popNode()
fieldType := p.parseType()
fieldName := p.readName()
p.attachToken()
ordinalValue := p.readOrdinal()
var defaultValue mojom.ValueRef
var defaultValueToken lexer.Token
if p.tryMatch(lexer.EQUALS) {
defaultValueToken = p.peekNextToken("Expecting a default value.")
if defaultValueToken.Kind == lexer.DEFAULT {
p.consumeNextToken()
defaultValue = mojom.MakeDefaultLiteral()
} else {
defaultValue = p.parseValue(fieldType)
}
}
if !p.matchSemicolon() {
return nil
}
field := mojom.NewStructField(fieldType, fieldName, ordinalValue, attributes, defaultValue)
if !field.ValidateDefaultValue() {
valueString := fmt.Sprintf("%v", defaultValue)
valueTypeString := ""
concreteValue := defaultValue.ResolvedConcreteValue()
if concreteValue != nil {
valueString = fmt.Sprintf("%v", concreteValue.Value())
valueTypeString = fmt.Sprintf(" of type %s", concreteValue.ValueType())
}
message := fmt.Sprintf("Illegal assignment at %s: Field %s of type %s may not be assigned the value %v%s.",
defaultValueToken.LongLocationString(), fieldName, fieldType, valueString, valueTypeString)
p.err = &ParseError{E_TYPE_NOT_ASSIGNMENT_COMPATIBLE, message}
return nil
}
return field
}