2017-05-21 23:13:04 +00:00
|
|
|
package hclhil
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
|
2017-05-28 00:33:09 +00:00
|
|
|
"github.com/zclconf/go-zcl/zcl"
|
2017-05-21 23:13:04 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Parse attempts to parse the given buffer as HCL with HIL expressions and,
|
|
|
|
// if successful, returns a zcl.File for the zcl configuration represented by
|
|
|
|
// it.
|
|
|
|
//
|
|
|
|
// The returned file is valid only if the returned diagnostics returns false
|
|
|
|
// from its HasErrors method. If HasErrors returns true, the file represents
|
|
|
|
// the subset of data that was able to be parsed, which may be none.
|
|
|
|
func Parse(src []byte, filename string) (*zcl.File, zcl.Diagnostics) {
|
|
|
|
return parse(src, filename)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ParseFile is a convenience wrapper around Parse that first attempts to load
|
|
|
|
// data from the given filename, passing the result to Parse if successful.
|
|
|
|
//
|
|
|
|
// If the file cannot be read, an error diagnostic with nil context is returned.
|
|
|
|
func ParseFile(filename string) (*zcl.File, zcl.Diagnostics) {
|
|
|
|
f, err := os.Open(filename)
|
|
|
|
if err != nil {
|
|
|
|
return nil, zcl.Diagnostics{
|
|
|
|
{
|
|
|
|
Severity: zcl.DiagError,
|
|
|
|
Summary: "Failed to open file",
|
|
|
|
Detail: fmt.Sprintf("The file %q could not be opened.", filename),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
defer f.Close()
|
|
|
|
|
|
|
|
src, err := ioutil.ReadAll(f)
|
|
|
|
if err != nil {
|
|
|
|
return nil, zcl.Diagnostics{
|
|
|
|
{
|
|
|
|
Severity: zcl.DiagError,
|
|
|
|
Summary: "Failed to read file",
|
|
|
|
Detail: fmt.Sprintf("The file %q was opened, but an error occured while reading it.", filename),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Parse(src, filename)
|
|
|
|
}
|
2017-05-22 05:09:17 +00:00
|
|
|
|
|
|
|
// ParseTemplate attempts to parse the given buffer as a HIL template and,
|
|
|
|
// if successful, returns a zcl.Expression for the value represented by it.
|
|
|
|
//
|
|
|
|
// The returned file is valid only if the returned diagnostics returns false
|
|
|
|
// from its HasErrors method. If HasErrors returns true, the file represents
|
|
|
|
// the subset of data that was able to be parsed, which may be none.
|
|
|
|
func ParseTemplate(src []byte, filename string) (zcl.Expression, zcl.Diagnostics) {
|
|
|
|
return parseTemplate(src, filename, zcl.Pos{Line: 1, Column: 1})
|
|
|
|
}
|
|
|
|
|
|
|
|
// ParseTemplateEmbedded is like ParseTemplate but is for templates that are
|
|
|
|
// embedded in a file in another language. Practically-speaking this just
|
|
|
|
// offsets the source positions returned in diagnostics, etc to be relative
|
|
|
|
// to the given position.
|
|
|
|
func ParseTemplateEmbedded(src []byte, filename string, startPos zcl.Pos) (zcl.Expression, zcl.Diagnostics) {
|
|
|
|
return parseTemplate(src, filename, startPos)
|
|
|
|
}
|