前言
parser package 包含了 golang 语法分析相关的数据结构和方法,源代码位于 <go-src>/src/go/parser
之前大概看了点 PHP 和 Ruby 的源代码,感叹 go 确实如宣传的一样,简洁如 C,parser.go 代码总共 几千行(Ruby 语法规则定义文件有 1w 多行),使用递归下降语法分析方法(感觉 go 语言的语法规则很适合递归下降)
example_test.go
parser package 里面也有一个示例 example_test.go,如何使用 parser
func ExampleParseFile() {
fset := token.NewFileSet() // positions are relative to fset
// Parse the file containing this very example
// but stop after processing the imports.
f, err := parser.ParseFile(fset, "example_test.go", nil, parser.ImportsOnly)
if err != nil {
fmt.Println(err)
return
}
// Print the imports from the file's AST.
for _, s := range f.Imports {
fmt.Println(s.Path.Value)
}
// output:
//
// "fmt"
// "go/parser"
// "go/token"
}
parser struct
The parser structure holds the parser’s internal state.
type parser struct {
// 词法扫描相关字段
file *token.File
errors scanner.ErrorList
scanner scanner.Scanner
...
pos token.Pos // token position
tok token.Token // one token look-ahead
lit string // token literal
...
// 作用域相关字段
pkgScope *ast.Scope // pkgScope.Outer == nil
topScope *ast.Scope // top-most scope; may be pkgScope
unresolved []*ast.Ident // unresolved identifiers
imports []*ast.ImportSpec // list of imports
...
}
parser 结构体以小写字母开头,意味着它是一个仅供内部使用的数据结构,里面字段比较多,一时不明白用途关系不大,有个大概印象