Documentation ¶
Overview ¶
Package cue is the main API for CUE evaluation.
Value is the main type that represents CUE evaluations. Values are created with a cue.Context. Only values created from the same Context can be involved in the same operation.
A Context defines the set of active packages, the translations of field names to unique codes, as well as the set of builtins. Use
import "cuelang.org/go/cue/cuecontext" ctx := cuecontext.New()
to obtain a context.
Note that the following types are DEPRECATED and their usage should be avoided if possible:
FieldInfo Instance Runtime Struct
Many types also have deprecated methods. Code that already uses deprecated methods can keep using them for at least some time. We aim to provide a go or cue fix solution to automatically rewrite code using the new API.
Index ¶
- Constants
- Variables
- type AttrKind
- type Attribute
- func (a *Attribute) Arg(i int) (key, value string)
- func (a *Attribute) Contents() string
- func (a *Attribute) Err() error
- func (a *Attribute) Flag(pos int, key string) (bool, error)
- func (a Attribute) Format(w fmt.State, verb rune)
- func (a *Attribute) Int(pos int) (int64, error)
- func (a *Attribute) Kind() AttrKind
- func (a *Attribute) Lookup(pos int, key string) (val string, found bool, err error)
- func (a *Attribute) Name() string
- func (a *Attribute) NumArgs() int
- func (a *Attribute) RawArg(i int) string
- func (a *Attribute) String(pos int) (string, error)
- type BuildOption
- type Context
- func (c *Context) BuildExpr(x ast.Expr, options ...BuildOption) Value
- func (c *Context) BuildFile(f *ast.File, options ...BuildOption) Value
- func (c *Context) BuildInstance(i *build.Instance, options ...BuildOption) Value
- func (c *Context) BuildInstances(instances []*build.Instance) ([]Value, error)
- func (c *Context) CompileBytes(b []byte, options ...BuildOption) Value
- func (c *Context) CompileString(src string, options ...BuildOption) Value
- func (c *Context) Encode(x interface{}, option ...EncodeOption) Value
- func (c *Context) EncodeType(x interface{}, option ...EncodeOption) Value
- func (c *Context) NewList(v ...Value) Value
- type EncodeOption
- type FieldInfo
- type Instance
- type InstanceOrValue
- type Iterator
- type Kind
- type Op
- type Option
- func All() Option
- func Attributes(include bool) Option
- func Concrete(concrete bool) Option
- func Definitions(include bool) Option
- func DisallowCycles(disallow bool) Option
- func Docs(include bool) Option
- func Final() Option
- func Hidden(include bool) Option
- func Optional(include bool) Option
- func Raw() Option
- func ResolveReferences(resolve bool) Option
- func Schema() Option
- type Path
- type Runtimedeprecated
- type Selector
- type Struct
- type Value
- func (v Value) Allows(sel Selector) bool
- func (v Value) AppendFloat(buf []byte, fmt byte, prec int) ([]byte, error)
- func (v Value) AppendInt(buf []byte, base int) ([]byte, error)
- func (v Value) Attribute(key string) Attribute
- func (v Value) Attributes(mask AttrKind) []Attribute
- func (v Value) Bool() (bool, error)
- func (v Value) Bytes() ([]byte, error)
- func (v Value) Context() *Context
- func (v Value) Decode(x interface{}) error
- func (v Value) Default() (Value, bool)
- func (v Value) Doc() []*ast.CommentGroup
- func (v Value) Equals(other Value) bool
- func (v Value) Err() error
- func (v Value) Eval() Value
- func (v Value) Exists() bool
- func (v Value) Expr() (Op, []Value)
- func (v Value) Fields(opts ...Option) (*Iterator, error)
- func (v Value) FillPath(p Path, x interface{}) Value
- func (v Value) Float64() (float64, error)
- func (v Value) Format(state fmt.State, verb rune)
- func (v Value) IncompleteKind() Kind
- func (v Value) Int(z *big.Int) (*big.Int, error)
- func (v Value) Int64() (int64, error)
- func (v Value) IsConcrete() bool
- func (v Value) Kind() Kind
- func (v Value) Len() Value
- func (v Value) List() (Iterator, error)
- func (v Value) LookupPath(p Path) Value
- func (v Value) MantExp(mant *big.Int) (exp int, err error)
- func (v Value) MarshalJSON() (b []byte, err error)
- func (v Value) Null() error
- func (v Value) Path() Path
- func (v Value) Pos() token.Pos
- func (v Value) ReferencePath() (root Value, p Path)
- func (v Value) Source() ast.Node
- func (v Value) String() (string, error)
- func (v Value) Subsume(w Value, opts ...Option) error
- func (v Value) Syntax(opts ...Option) ast.Node
- func (v Value) Uint64() (uint64, error)
- func (v Value) Unify(w Value) Value
- func (v Value) UnifyAccept(w Value, accept Value) Value
- func (v Value) Validate(opts ...Option) error
- func (v Value) Walk(before func(Value) bool, after func(Value))
Examples ¶
Constants ¶
const ( NoOp = adt.NoOp AndOp = adt.AndOp OrOp = adt.OrOp SelectorOp = adt.SelectorOp IndexOp = adt.IndexOp SliceOp = adt.SliceOp CallOp = adt.CallOp BooleanAndOp = adt.BoolAndOp BooleanOrOp = adt.BoolOrOp EqualOp = adt.EqualOp NotOp = adt.NotOp NotEqualOp = adt.NotEqualOp LessThanOp = adt.LessThanOp LessThanEqualOp = adt.LessEqualOp GreaterThanOp = adt.GreaterThanOp GreaterThanEqualOp = adt.GreaterEqualOp RegexMatchOp = adt.MatchOp NotRegexMatchOp = adt.NotMatchOp AddOp = adt.AddOp SubtractOp = adt.SubtractOp MultiplyOp = adt.MultiplyOp FloatQuotientOp = adt.FloatQuotientOp IntQuotientOp = adt.IntQuotientOp IntRemainderOp = adt.IntRemainderOp IntDivideOp = adt.IntDivideOp IntModuloOp = adt.IntModuloOp InterpolationOp = adt.InterpolationOp )
Values of Op.
const ( // NullKind indicates a null value. NullKind Kind = adt.NullKind // BoolKind indicates a boolean value. BoolKind = adt.BoolKind // IntKind represents an integral number. IntKind = adt.IntKind // FloatKind represents a decimal float point number that cannot be // converted to an integer. The underlying number may still be integral, // but resulting from an operation that enforces the float type. FloatKind = adt.FloatKind // StringKind indicates any kind of string. StringKind = adt.StringKind // BytesKind is a blob of data. BytesKind = adt.BytesKind // StructKind is a kev-value map. StructKind = adt.StructKind // ListKind indicates a list of values. ListKind = adt.ListKind // NumberKind represents any kind of number. NumberKind = IntKind | FloatKind TopKind = adt.TopKind )
Variables ¶
var ( // AnyIndex can be used to ask for any index. // // In paths it is used to select constraints that apply to all elements. AnyIndex = anyIndex // AnyString can be used to ask for any regular string field. // // In paths it is used to select constraints that apply to all elements. AnyString = anyLabel )
var ( // ErrBelow indicates that a value was rounded down in a conversion. ErrBelow = errors.New("value was rounded down") // ErrAbove indicates that a value was rounded up in a conversion. ErrAbove = errors.New("value was rounded up") // ErrInfinite indicates that a value is infinite. ErrInfinite = errors.New("infinite") )
Functions ¶
This section is empty.
Types ¶
type AttrKind ¶ added in v0.3.0
type AttrKind int
AttrKind indicates the location of an attribute within CUE source.
const ( // FieldAttr indicates a field attribute. // foo: bar @attr() FieldAttr AttrKind = AttrKind(internal.FieldAttr) // DeclAttr indicates a declaration attribute. // foo: { // @attr() // } DeclAttr AttrKind = AttrKind(internal.DeclAttr) // A ValueAttr is a bit mask to request any attribute that is locally // associated with a field, instead of, for instance, an entire file. ValueAttr AttrKind = FieldAttr | DeclAttr )
type Attribute ¶
type Attribute struct {
// contains filtered or unexported fields
}
An Attribute contains meta data about a field.
func (*Attribute) Arg ¶ added in v0.3.0
Arg reports the contents of the ith comma-separated argument of a.
If the argument contains an unescaped equals sign, it returns a key-value pair. Otherwise it returns the contents in value.
func (*Attribute) Contents ¶ added in v0.3.0
Contents reports the full contents of an attribute within parentheses, so contents in @attr(contents).
func (*Attribute) Err ¶
Err returns the error associated with this Attribute or nil if this attribute is valid.
func (*Attribute) Flag ¶
Flag reports whether an entry with the given name exists at position pos or onwards or an error if the attribute is invalid or if the first pos-1 entries are not defined.
func (*Attribute) Int ¶
Int reports the integer at the given position or an error if the attribute is invalid, the position does not exist, or the value at the given position is not an integer.
func (*Attribute) Kind ¶ added in v0.3.0
Kind reports the type of location within CUE source where the attribute was specified.
func (*Attribute) Lookup ¶
Lookup searches for an entry of the form key=value from position pos onwards and reports the value if found. It reports an error if the attribute is invalid or if the first pos-1 entries are not defined.
func (*Attribute) Name ¶ added in v0.3.0
Name returns the name of the attribute, for instance, "json" for @json(...).
func (*Attribute) NumArgs ¶ added in v0.3.0
NumArgs reports the number of arguments parsed for this attribute.
type BuildOption ¶ added in v0.4.0
A BuildOption defines options for the various build-related methods of Context.
func Filename ¶ added in v0.4.0
func Filename(filename string) BuildOption
Filename assigns a filename to parsed content.
func ImportPath ¶ added in v0.4.0
func ImportPath(path string) BuildOption
ImportPath defines the import path to use for building CUE. The import path influences the scope in which identifiers occurring in the input CUE are defined. Passing the empty string is equal to not specifying this option.
This option is typically not necessary when building using a build.Instance, but takes precedence otherwise.
func InferBuiltins ¶ added in v0.4.0
func InferBuiltins(elide bool) BuildOption
InferBuiltins allows unresolved references to bind to builtin packages with a unique package name.
This option is intended for evaluating expressions in a context where import statements cannot be used. It is not recommended to use this for evaluating CUE files.
func Scope ¶ added in v0.4.0
func Scope(scope Value) BuildOption
Scope defines a context in which to resolve unresolved identifiers.
Only one scope may be given. It panics if more than one scope is given or if the Context in which scope was created differs from the one where this option is used.
type Context ¶ added in v0.4.0
A Context is used for creating CUE Values.
A Context keeps track of loaded instances, indices of internal representations of values, and defines the set of supported builtins. Any operation that involves two Values should originate from the same Context.
Use
ctx := cuecontext.New()
to create a new Context.
Example ¶
package main import ( "fmt" "cuelang.org/go/cue" "cuelang.org/go/cue/cuecontext" ) func main() { ctx := cuecontext.New() v := ctx.CompileString(` a: 2 b: 3 "a+b": a + b `) p("lookups") p("a: %v", v.LookupPath(cue.ParsePath("a"))) p("b: %v", v.LookupPath(cue.ParsePath("b"))) p(`"a+b": %v`, v.LookupPath(cue.ParsePath(`"a+b"`))) p("") p("expressions") p("a + b: %v", ctx.CompileString("a + b", cue.Scope(v))) p("a * b: %v", ctx.CompileString("a * b", cue.Scope(v)))
Output:
func (*Context) BuildExpr ¶ added in v0.4.0
func (c *Context) BuildExpr(x ast.Expr, options ...BuildOption) Value
BuildExpr creates a Value from x.
The returned Value will represent an error, accessible through Err, if any error occurred.
func (*Context) BuildFile ¶ added in v0.4.0
func (c *Context) BuildFile(f *ast.File, options ...BuildOption) Value
BuildFile creates a Value from f.
The returned Value will represent an error, accessible through Err, if any error occurred.
func (*Context) BuildInstance ¶ added in v0.4.0
func (c *Context) BuildInstance(i *build.Instance, options ...BuildOption) Value
BuildInstance creates a Value from the given build.Instance.
The returned Value will represent an error, accessible through Err, if any error occurred.
func (*Context) BuildInstances ¶ added in v0.4.0
BuildInstances creates a Value for each of the given instances and reports the combined errors or nil if there were no errors.
func (*Context) CompileBytes ¶ added in v0.4.0
func (c *Context) CompileBytes(b []byte, options ...BuildOption) Value
ParseString parses and build a Value from the given source bytes.
The returned Value will represent an error, accessible through Err, if any error occurred.
func (*Context) CompileString ¶ added in v0.4.0
func (c *Context) CompileString(src string, options ...BuildOption) Value
CompileString parses and build a Value from the given source string.
The returned Value will represent an error, accessible through Err, if any error occurred.
func (*Context) Encode ¶ added in v0.4.0
func (c *Context) Encode(x interface{}, option ...EncodeOption) Value
Encode converts a Go value to a CUE value.
The returned Value will represent an error, accessible through Err, if any error occurred.
Encode traverses the value v recursively. If an encountered value implements the json.Marshaler interface and is not a nil pointer, Encode calls its MarshalJSON method to produce JSON and convert that to CUE instead. If no MarshalJSON method is present but the value implements encoding.TextMarshaler instead, Encode calls its MarshalText method and encodes the result as a string.
Otherwise, Encode uses the following type-dependent default encodings:
Boolean values encode as CUE booleans.
Floating point, integer, and *big.Int and *big.Float values encode as CUE numbers.
String values encode as CUE strings coerced to valid UTF-8, replacing sequences of invalid bytes with the Unicode replacement rune as per Unicode's and W3C's recommendation.
Array and slice values encode as CUE lists, except that []byte encodes as a bytes value, and a nil slice encodes as the null.
Struct values encode as CUE structs. Each exported struct field becomes a member of the object, using the field name as the object key, unless the field is omitted for one of the reasons given below.
The encoding of each struct field can be customized by the format string stored under the "json" key in the struct field's tag. The format string gives the name of the field, possibly followed by a comma-separated list of options. The name may be empty in order to specify options without overriding the default field name.
The "omitempty" option specifies that the field should be omitted from the encoding if the field has an empty value, defined as false, 0, a nil pointer, a nil interface value, and any empty array, slice, map, or string.
See the documentation for Go's json.Marshal for more details on the field tags and their meaning.
Anonymous struct fields are usually encoded as if their inner exported fields were fields in the outer struct, subject to the usual Go visibility rules amended as described in the next paragraph. An anonymous struct field with a name given in its JSON tag is treated as having that name, rather than being anonymous. An anonymous struct field of interface type is treated the same as having that type as its name, rather than being anonymous.
The Go visibility rules for struct fields are amended for when deciding which field to encode or decode. If there are multiple fields at the same level, and that level is the least nested (and would therefore be the nesting level selected by the usual Go rules), the following extra rules apply:
1) Of those fields, if any are JSON-tagged, only tagged fields are considered, even if there are multiple untagged fields that would otherwise conflict.
2) If there is exactly one field (tagged or not according to the first rule), that is selected.
3) Otherwise there are multiple fields, and all are ignored; no error occurs.
Map values encode as CUE structs. The map's key type must either be a string, an integer type, or implement encoding.TextMarshaler. The map keys are sorted and used as CUE struct field names by applying the following rules, subject to the UTF-8 coercion described for string values above:
- keys of any string type are used directly
- encoding.TextMarshalers are marshaled
- integer keys are converted to strings
Pointer values encode as the value pointed to. A nil pointer encodes as the null CUE value.
Interface values encode as the value contained in the interface. A nil interface value encodes as the null CUE value. The NilIsAny EncodingOption can be used to interpret nil as any (_) instead.
Channel, complex, and function values cannot be encoded in CUE. Attempting to encode such a value results in the returned value being an error, accessible through the Err method.
func (*Context) EncodeType ¶ added in v0.4.0
func (c *Context) EncodeType(x interface{}, option ...EncodeOption) Value
Encode converts a Go type to a CUE value.
The returned Value will represent an error, accessible through Err, if any error occurred.
type EncodeOption ¶ added in v0.4.0
type EncodeOption func(*encodeOptions)
An EncodeOption defines options for the various encoding-related methods of Context.
func NilIsAny ¶ added in v0.4.0
func NilIsAny(isAny bool) EncodeOption
NilIsAny indicates whether a nil value is interpreted as null or _.
The default is to interpret nil as _.
type FieldInfo ¶ added in v0.0.5
type FieldInfo struct { Selector string Name string // Deprecated: use Selector Pos int Value Value IsDefinition bool IsOptional bool IsHidden bool }
FieldInfo contains information about a struct field.
type Instance ¶
type Instance struct { ImportPath string Dir string PkgName string DisplayName string Incomplete bool // true if Pkg and all its dependencies are free of errors Err errors.Error // non-nil if the package had errors // contains filtered or unexported fields }
An Instance defines a single configuration based on a collection of underlying CUE files.
func Build
deprecated
Build creates one Instance for each build.Instance. A returned Instance may be incomplete, in which case its Err field is set.
Example:
inst := cue.Build(load.Instances(args))
Deprecated: use Context.BuildInstances. The use of Instance is being phased out.
type InstanceOrValue ¶ added in v0.4.0
type InstanceOrValue interface { Value() Value // contains filtered or unexported methods }
An InstanceOrValue is implemented by Value and *Instance.
This is a placeholder type that is used to allow Instance-based APIs to transition to Value-based APIs. The goals is to get rid of the Instance type before v1.0.0.
type Iterator ¶
type Iterator struct {
// contains filtered or unexported fields
}
An Iterator iterates over values.
func (*Iterator) IsOptional ¶
IsOptional reports if a field is optional.
func (*Iterator) Next ¶
Next advances the iterator to the next value and reports whether there was any. It must be called before the first call to Value or Key.
type Op ¶
Op indicates the operation at the top of an expression tree of the expression use to evaluate a value.
type Option ¶
type Option option
An Option defines modes of evaluation.
func All ¶
func All() Option
All indicates that all fields and values should be included in processing even if they can be elided or omitted.
func Attributes ¶
Attributes indicates that attributes should be included.
func Concrete ¶
Concrete ensures that all values are concrete.
For Validate this means it returns an error if this is not the case. In other cases a non-concrete value will be replaced with an error.
func Definitions ¶ added in v0.0.12
Definitions indicates whether definitions should be included.
Definitions may still be included for certain functions if they are referred to by other other values.
func DisallowCycles ¶ added in v0.0.5
DisallowCycles forces validation in the precense of cycles, even if non-concrete values are allowed. This is implied by Concrete(true).
func Final ¶ added in v0.1.0
func Final() Option
Final indicates a value is final. It implicitly closes all structs and lists in a value and selects defaults.
func Raw ¶ added in v0.0.5
func Raw() Option
Raw tells Syntax to generate the value as is without any simplifications.
func ResolveReferences ¶ added in v0.1.0
ResolveReferences forces the evaluation of references when outputting. This implies the input cannot have cycles.
type Path ¶ added in v0.3.0
type Path struct {
// contains filtered or unexported fields
}
A Path is series of selectors to query a CUE value.
func ParsePath ¶ added in v0.3.0
ParsePath parses a CUE expression into a Path. Any error resulting from this conversion can be obtained by calling Err on the result.
Unlike with normal CUE expressions, the first element of the path may be a string literal.
A path may not contain hidden fields. To create a path with hidden fields, use MakePath and Ident.
func (Path) Optional ¶ added in v0.3.1
Optional returns the optional form of a Path. For instance,
foo.bar --> foo?.bar?
type Runtime
deprecated
A Runtime is used for creating CUE Values.
Any operation that involves two Values or Instances should originate from the same Runtime.
The zero value of Runtime works for legacy reasons, but should not be used. It may panic at some point.
Deprecated: use Context.
type Selector ¶ added in v0.3.0
type Selector struct {
// contains filtered or unexported fields
}
A Selector is a component of a path.
func Def ¶ added in v0.3.0
A Def marks a string as a definition label. An # will be added if a string is not prefixed with a #. It will panic if s cannot be written as a valid identifier.
func Hid ¶ added in v0.3.0
Hid returns a selector for a hidden field. It panics is pkg is empty. Hidden fields are scoped by package, and pkg indicates for which package the hidden field must apply.For anonymous packages, it must be set to "_".
Example ¶
package main import ( "fmt" "io/ioutil" "os" "cuelang.org/go/cue" "cuelang.org/go/internal/cuetxtar" "github.com/rogpeppe/go-internal/txtar" ) func load(file string) *cue.Instance { dir, _ := ioutil.TempDir("", "*") defer os.RemoveAll(dir) inst := cue.Build(cuetxtar.Load(txtar.Parse([]byte(file)), dir))[0] if err := inst.Err; err != nil { panic(err) } return inst } func main() { const file = ` -- cue.mod/module.cue -- module: "acme.com" -- main.cue -- import "acme.com/foo:bar" bar _foo: int // scoped in main (anonymous) package baz: _foo -- foo/bar.cue -- package bar _foo: int // scoped within imported package bar: _foo ` v := load(file).Value() v = v.FillPath(cue.MakePath(cue.Hid("_foo", "acme.com/foo:bar")), 1) v = v.FillPath(cue.MakePath(cue.Hid("_foo", "_")), 2) fmt.Println(v.LookupPath(cue.ParsePath("bar")).Int64()) fmt.Println(v.LookupPath(cue.ParsePath("baz")).Int64()) }
Output: 1 <nil> 2 <nil>
func (Selector) IsDefinition ¶ added in v0.4.0
IsDefinition reports whether sel is a non-hidden definition label type.
func (Selector) Optional ¶ added in v0.3.1
Optional converts sel into an optional equivalent.
foo -> foo?
type Struct ¶ added in v0.0.5
type Struct struct {
// contains filtered or unexported fields
}
Struct represents a CUE struct value.
type Value ¶
type Value struct {
// contains filtered or unexported fields
}
Value holds any value, which may be a Boolean, Error, List, Null, Number, Struct, or String.
func Dereference ¶ added in v0.1.0
Dereference reports the value v refers to if v is a reference or v itself otherwise.
func (Value) Allows ¶ added in v0.3.1
Allows reports whether a field with the given selector could be added to v.
Allows does not take into account validators like list.MaxItems(4). This may change in the future.
Example ¶
package main import ( "fmt" "cuelang.org/go/cue" "cuelang.org/go/cue/cuecontext" ) func main() { ctx := cuecontext.New() const file = ` a: [1, 2, ...int] b: #Point #Point: { x: int y: int z?: int } c: [string]: int d: #C #C: [>"m"]: int ` v := ctx.CompileString(file) a := v.LookupPath(cue.ParsePath("a")) fmt.Println("a allows:") fmt.Println(" index 4: ", a.Allows(cue.Index(4))) fmt.Println(" any index: ", a.Allows(cue.AnyIndex)) fmt.Println(" any string: ", a.Allows(cue.AnyString)) b := v.LookupPath(cue.ParsePath("b")) fmt.Println("b allows:") fmt.Println(" field x: ", b.Allows(cue.Str("x"))) fmt.Println(" field z: ", b.Allows(cue.Str("z"))) fmt.Println(" field foo: ", b.Allows(cue.Str("foo"))) fmt.Println(" index 4: ", b.Allows(cue.Index(4))) fmt.Println(" any string: ", b.Allows(cue.AnyString)) c := v.LookupPath(cue.ParsePath("c")) fmt.Println("c allows:") fmt.Println(" field z: ", c.Allows(cue.Str("z"))) fmt.Println(" field foo: ", c.Allows(cue.Str("foo"))) fmt.Println(" index 4: ", c.Allows(cue.Index(4))) fmt.Println(" any string: ", c.Allows(cue.AnyString)) d := v.LookupPath(cue.ParsePath("d")) fmt.Println("d allows:") fmt.Println(" field z: ", d.Allows(cue.Str("z"))) fmt.Println(" field foo: ", d.Allows(cue.Str("foo"))) fmt.Println(" index 4: ", d.Allows(cue.Index(4))) fmt.Println(" any string: ", d.Allows(cue.AnyString)) }
Output: a allows: index 4: true any index: true any string: false b allows: field x: true field z: true field foo: false index 4: false any string: false c allows: field z: true field foo: true index 4: false any string: true d allows: field z: true field foo: false index 4: false any string: false
func (Value) AppendFloat ¶
AppendFloat appends to buf the string form of the floating-point number x. It returns an error if v is not a number.
func (Value) AppendInt ¶
AppendInt appends the string representation of x in the given base to buf and returns the extended buffer, or an error if the underlying number was not an integer.
func (Value) Attribute ¶
Attribute returns the attribute data for the given key. The returned attribute will return an error for any of its methods if there is no attribute for the requested key.
func (Value) Attributes ¶ added in v0.3.0
Attributes reports all field attributes for the Value.
To retrieve attributes of multiple kinds, you can bitwise-or kinds together. Use ValueKind to query attributes associated with a value.
func (Value) Bytes ¶
Bytes returns a byte slice if v represents a list of bytes or an error otherwise.
func (Value) Context ¶ added in v0.4.0
Context reports the Context with which this value was created.
func (Value) Decode ¶
Decode initializes x with Value v. If x is a struct, it will validate the constraints specified in the field tags.
func (Value) Default ¶
Default reports the default value and whether it existed. It returns the normal value if there is no default.
func (Value) Doc ¶
func (v Value) Doc() []*ast.CommentGroup
Doc returns all documentation comments associated with the field from which the current value originates.
func (Value) Equals ¶ added in v0.0.5
Equals reports whether two values are equal, ignoring optional fields. The result is undefined for incomplete values.
func (Value) Eval ¶
Eval resolves the references of a value and returns the result. This method is not necessary to obtain concrete values.
func (Value) Expr ¶
Expr reports the operation of the underlying expression and the values it operates on.
For unary expressions, it returns the single value of the expression.
For binary expressions it returns first the left and right value, in that order. For associative operations however, (for instance '&' and '|'), it may return more than two values, where the operation is to be applied in sequence.
For selector and index expressions it returns the subject and then the index. For selectors, the index is the string value of the identifier.
For interpolations it returns a sequence of values to be concatenated, some of which will be literal strings and some unevaluated expressions.
A builtin call expression returns the value of the builtin followed by the args of the call.
func (Value) Fields ¶
Fields creates an iterator over v's fields if v is a struct or an error otherwise.
func (Value) FillPath ¶ added in v0.3.0
FillPath creates a new value by unifying v with the value of x at the given path.
If x is an cue/ast.Expr, it will be evaluated within the context of the given path: identifiers that are not resolved within the expression are resolved as if they were defined at the path position.
If x is a Value, it will be used as is. It panics if x is not created from the same Runtime as v.
Otherwise, the given Go value will be converted to CUE using the same rules as Context.Encode.
Any reference in v referring to the value at the given path will resolve to x in the newly created value. The resulting value is not validated.
func (Value) Float64 ¶
Float64 returns the float64 value nearest to x. It reports an error if v is not a number. If x is too small to be represented by a float64 (|x| < math.SmallestNonzeroFloat64), the result is (0, ErrBelow) or (-0, ErrAbove), respectively, depending on the sign of x. If x is too large to be represented by a float64 (|x| > math.MaxFloat64), the result is (+Inf, ErrAbove) or (-Inf, ErrBelow), depending on the sign of x.
func (Value) Format ¶
Format prints a CUE value.
WARNING:
although we are narrowing down the semantics, the verbs and options are still subject to change. this API is experimental although it is likely getting close to the final design.
It recognizes the following verbs:
v print CUE value
The verbs support the following flags:
# print as schema and include definitions. The result is printed as a self-contained file, instead of an the expression format. + evaluate: resolve defaults and error on incomplete errors
Indentation can be controlled as follows:
width indent the cue block by <width> tab stops (e.g. %2v) precision convert tabs to <precision> spaces (e.g. %.2v), where a value of 0 means no indentation or newlines (TODO).
If the value kind corresponds to one of the following Go types, the usual Go formatting verbs for that type can be used:
Int: b,d,o,O,q,x,X Float: f,e,E,g,G String/Bytes: s,q,x,X
The %v directive will be used if the type is not supported for that verb.
Example ¶
package main import ( "fmt" "cuelang.org/go/cue" "cuelang.org/go/cue/cuecontext" ) func main() { ctx := cuecontext.New() v := ctx.CompileString(` a: 2 + b b: *3 | int s: "foo\nbar" `) fmt.Println("### ALL") fmt.Println(v) fmt.Println("---") fmt.Printf("%#v\n", v) fmt.Println("---") fmt.Printf("%+v\n", v) a := v.LookupPath(cue.ParsePath("a")) fmt.Println("\n### INT") fmt.Printf("%%v: %v\n", a) fmt.Printf("%%05d: %05d\n", a) s := v.LookupPath(cue.ParsePath("s")) fmt.Println("\n### STRING") fmt.Printf("%%v: %v\n", s) fmt.Printf("%%s: %s\n", s) fmt.Printf("%%q: %q\n", s) v = ctx.CompileString(` #Def: a: [string]: int b: #Def b: a: { a: 3 b: 3 } `) b := v.LookupPath(cue.ParsePath("b.a")) fmt.Println("\n### DEF") fmt.Println(b) fmt.Println("---") // This will indicate that the result is closed by including a hidden // definition. fmt.Printf("%#v\n", b) }
Output: ### ALL { a: 5 b: *3 | int s: """ foo bar """ } --- a: 2 + b b: *3 | int s: "foo\nbar" --- { a: 5 b: 3 s: """ foo bar """ } ### INT %v: 5 %05d: 00005 ### STRING %v: """ foo bar """ %s: foo bar %q: "foo\nbar" ### DEF { a: 3 b: 3 } --- _#def _#def: { { [string]: int } a: 3 b: 3 }
func (Value) IncompleteKind ¶
IncompleteKind returns a mask of all kinds that this value may be.
func (Value) Int ¶
Int converts the underlying integral number to an big.Int. It reports an error if the underlying value is not an integer type. If a non-nil *Int argument z is provided, Int stores the result in z instead of allocating a new Int.
func (Value) Int64 ¶
Int64 converts the underlying integral number to int64. It reports an error if the underlying value is not an integer type or cannot be represented as an int64. The result is (math.MinInt64, ErrAbove) for x < math.MinInt64, and (math.MaxInt64, ErrBelow) for x > math.MaxInt64.
func (Value) IsConcrete ¶
IsConcrete reports whether the current value is a concrete scalar value (not relying on default values), a terminal error, a list, or a struct. It does not verify that values of lists or structs are concrete themselves. To check whether there is a concrete default, use v.Default().IsConcrete().
func (Value) Kind ¶
Kind returns the kind of value. It returns BottomKind for atomic values that are not concrete. For instance, it will return BottomKind for the bounds >=0.
func (Value) Len ¶
Len returns the number of items of the underlying value. For lists it reports the capacity of the list. For structs it indicates the number of fields, for bytes the number of bytes.
func (Value) List ¶
List creates an iterator over the values of a list or reports an error if v is not a list.
func (Value) LookupPath ¶ added in v0.3.0
LookupPath reports the value for path p relative to v.
func (Value) MantExp ¶
MantExp breaks x into its mantissa and exponent components and returns the exponent. If a non-nil mant argument is provided its value is set to the mantissa of x. The components satisfy x == mant × 10**exp. It returns an error if v is not a number.
The components are not normalized. For instance, 2.00 is represented mant == 200 and exp == -2. Calling MantExp with a nil argument is an efficient way to get the exponent of the receiver.
func (Value) MarshalJSON ¶
MarshalJSON marshalls this value into valid JSON.
func (Value) Path ¶ added in v0.3.0
Path returns the path to this value from the root of an Instance.
This is currently only defined for values that have a fixed path within a configuration, and thus not those that are derived from Elem, Template, or programmatically generated values such as those returned by Unify.
func (Value) ReferencePath ¶ added in v0.4.0
ReferencePath returns the value and path referred to by this value such that value.LookupPath(path) resolves to the same value, or no path if this value is not a reference.
func (Value) Source ¶
Source returns the original node for this value. The return value may not be a syntax.Expr. For instance, a struct kind may be represented by a struct literal, a field comprehension, or a file. It returns nil for computed nodes. Use Split to get all source values that apply to a field.
func (Value) Subsume ¶ added in v0.1.0
Subsume reports nil when w is an instance of v or an error otherwise.
Without options, the entire value is considered for assumption, which means Subsume tests whether v is a backwards compatible (newer) API version of w.
Use the Final option to check subsumption if a w is known to be final, and should assumed to be closed.
Use the Raw option to do a low-level subsumption, taking defaults into account.
Value v and w must be obtained from the same build. TODO: remove this requirement.
func (Value) Syntax ¶
Syntax converts the possibly partially evaluated value into syntax. This can use used to print the value with package format.
func (Value) Uint64 ¶
Uint64 converts the underlying integral number to uint64. It reports an error if the underlying value is not an integer type or cannot be represented as a uint64. The result is (0, ErrAbove) for x < 0, and (math.MaxUint64, ErrBelow) for x > math.MaxUint64.
func (Value) Unify ¶
Unify reports the greatest lower bound of v and w.
Value v and w must be obtained from the same build. TODO: remove this requirement.
func (Value) UnifyAccept ¶ added in v0.3.0
UnifyAccept is as v.Unify(w), but will disregard any field that is allowed in the Value accept.
func (Value) Validate ¶
Validate reports any errors, recursively. The returned error may represent more than one error, retrievable with errors.Errors, if more than one exists.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package ast declares the types used to represent syntax trees for CUE packages.
|
Package ast declares the types used to represent syntax trees for CUE packages. |
Package build defines data types and utilities for defining CUE configuration instances.
|
Package build defines data types and utilities for defining CUE configuration instances. |
Package errors defines shared types for handling CUE errors.
|
Package errors defines shared types for handling CUE errors. |
Package format implements standard formatting of CUE configurations.
|
Package format implements standard formatting of CUE configurations. |
Package literal implements conversions to and from string representations of basic data types.
|
Package literal implements conversions to and from string representations of basic data types. |
Package load loads CUE instances.
|
Package load loads CUE instances. |
Package parser implements a parser for CUE source files.
|
Package parser implements a parser for CUE source files. |
Package scanner implements a scanner for CUE source text.
|
Package scanner implements a scanner for CUE source text. |
Package token defines constants representing the lexical tokens of the Go programming language and basic operations on tokens (printing, predicates).
|
Package token defines constants representing the lexical tokens of the Go programming language and basic operations on tokens (printing, predicates). |