package parser
import "github.com/docker/docker/builder/parser"
This package implements a parser and parse tree dumper for Dockerfiles.
Index ¶
Variables ¶
var ( TOKEN_WHITESPACE = regexp.MustCompile(`[\t\v\f\r ]+`) TOKEN_LINE_CONTINUATION = regexp.MustCompile(`\\[ \t]*$`) TOKEN_COMMENT = regexp.MustCompile(`^#.*$`) )
Types ¶
type Node ¶
type Node struct { Value string // actual content Next *Node // the next item in the current sexp Children []*Node // the children of this sexp Attributes map[string]bool // special attributes for this node Original string // original line used before parsing Flags []string // only top Node should have this set }
Node is a structure used to represent a parse tree.
In the node there are three fields, Value, Next, and Children. Value is the current token's string value. Next is always the next non-child token, and children contains all the children. Here's an example:
(value next (child child-next child-next-next) next-next)
This data structure is frankly pretty lousy for handling complex languages, but lucky for us the Dockerfile isn't very complicated. This structure works a little more effectively than a "proper" parse tree for our needs.
func Parse ¶
The main parse routine. Handles an io.ReadWriteCloser and returns the root of the AST.
func (*Node) Dump ¶
dumps the AST defined by `node` as a list of sexps. Returns a string suitable for printing.
Source Files ¶
line_parsers.go parser.go utils.go
Directories ¶
Path | Synopsis |
---|---|
builder/parser/dumper |
- Version
- v1.7.0-rc2
- Published
- Jun 4, 2015
- Platform
- js/wasm
- Imports
- 10 packages
- Last checked
- 7 minutes ago –
Tools for package owners.