Documentation ¶
Overview ¶
Package cue is a transition package for supporting the cue.Value API. It aims to be plugin compatible with the old API.
Index ¶
- Constants
- Variables
- func NewRuntime() *runtime.Runtime
- type Attribute
- type FieldInfo
- type Instance
- func (inst *Instance) Build(p *build.Instance) *Instance
- func (inst *Instance) Doc() []*ast.CommentGroup
- func (inst *Instance) Eval(expr ast.Expr) Value
- func (inst *Instance) Fill(x interface{}, path ...string) (*Instance, error)
- func (inst *Instance) Lookup(path ...string) Value
- func (inst *Instance) LookupDef(path string) Value
- func (inst *Instance) LookupField(path ...string) (f FieldInfo, err error)deprecated
- func (inst *Instance) Value() Value
- 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) Optiondeprecated
- func Optional(include bool) Option
- func Raw() Option
- func ResolveReferences(resolve bool) Option
- func Schema() Option
- type Runtime
- func (r *Runtime) Build(instance *build.Instance) (*Instance, error)
- func (r *Runtime) Compile(filename string, source interface{}) (*Instance, error)
- func (r *Runtime) CompileExpr(expr ast.Expr) (*Instance, error)
- func (r *Runtime) CompileFile(file *ast.File) (*Instance, error)
- func (r *Runtime) FromExpr(expr ast.Expr) (*Instance, error)deprecated
- func (r *Runtime) Marshal(instances ...*Instance) (b []byte, err error)
- func (r *Runtime) Parse(name string, source interface{}) (*Instance, error)deprecated
- func (r *Runtime) Unmarshal(b []byte) ([]*Instance, error)
- type Struct
- type Value
- 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) Bool() (bool, error)
- func (v Value) Bytes() ([]byte, error)
- func (v Value) Decode(x interface{}) error
- func (v Value) Default() (Value, bool)
- func (v Value) Doc() []*ast.CommentGroup
- func (v Value) Elem() (Value, bool)
- 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) FieldByName(name string, isIdent bool) (f FieldInfo, err error)
- func (v Value) Fields(opts ...Option) (*Iterator, error)
- func (v Value) Fill(x interface{}, path ...string) 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) IsClosed() bool
- func (v Value) IsConcrete() bool
- func (v Value) Kind() Kind
- func (v Value) Label() (string, bool)
- func (v Value) Len() Value
- func (v Value) List() (Iterator, error)
- func (v Value) Lookup(path ...string) Value
- func (v Value) LookupDef(name string) Value
- func (v Value) LookupField(name string) (FieldInfo, error)deprecated
- 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) Pos() token.Pos
- func (v Value) Reader() (io.Reader, error)
- func (v Value) Reference() (inst *Instance, path []string)
- func (v Value) Source() ast.Node
- func (v Value) Split() []Valuedeprecated
- func (v Value) String() (string, error)
- func (v Value) Struct() (*Struct, error)
- func (v Value) Subsume(w Value, opts ...Option) error
- func (v Value) Subsumes(w Value) booldeprecated
- func (v Value) Syntax(opts ...Option) ast.Node
- func (v Value) Template() func(label string) Value
- 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))
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 ( // 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 ¶
func NewRuntime ¶
NewRuntime creates a *runtime.Runtime with builtins preloaded.
Types ¶
type Attribute ¶
type Attribute struct {
// contains filtered or unexported fields
}
An Attribute contains meta data about a field.
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.
type FieldInfo ¶
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 ¶
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))
func Merge ¶
Merge unifies the given instances into a single one.
Errors regarding conflicts are included in the result, but not reported, so that these will only surface during manifestation. This allows non-conflicting parts to be used.
func (*Instance) Build ¶
Build creates a new instance from the build instances, allowing unbound identifier to bind to the top-level field in inst. The top-level fields in inst take precedence over predeclared identifier and builtin functions.
func (*Instance) Doc ¶
func (inst *Instance) Doc() []*ast.CommentGroup
Doc returns the package comments for this instance.
func (*Instance) Eval ¶
Eval evaluates an expression within an existing instance.
Expressions may refer to builtin packages if they can be uniquely identified.
func (*Instance) Fill ¶
Fill creates a new instance with the values of the old instance unified with the given value. It is not possible to update the emit value.
Values may be any Go value that can be converted to CUE, an ast.Expr or a Value. In the latter case, it will panic if the Value is not from the same Runtime.
func (*Instance) Lookup ¶
Lookup reports the value at a path starting from the top level struct. The Exists method of the returned value will report false if the path did not exist. The Err method reports if any error occurred during evaluation. The empty path returns the top-level configuration struct. Use LookupDef for definitions or LookupField for any kind of field.
func (*Instance) LookupDef ¶
LookupDef reports the definition with the given name within struct v. The Exists method of the returned value will report false if the definition did not exist. The Err method reports if any error occurred during evaluation.
func (*Instance) LookupField
deprecated
LookupField reports a Field at a path starting from v, or an error if the path is not. The empty path returns v itself.
It cannot look up hidden or unexported fields.
Deprecated: this API does not work with new-style definitions. Use FieldByName defined on inst.Value().
type Iterator ¶
type Iterator struct {
// contains filtered or unexported fields
}
An Iterator iterates over values.
func (*Iterator) IsDefinition ¶
IsDefinition reports if a field is a definition.
func (*Iterator) IsOptional ¶
IsOptional reports if a field is optional.
func (*Iterator) Label ¶
Label reports the label of the value if i iterates over struct fields and "" otherwise.
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 ¶
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 ¶
DisallowCycles forces validation in the precense of cycles, even if non-concrete values are allowed. This is implied by Concrete(true).
func Final ¶
func Final() Option
Final indicates a value is final. It implicitly closes all structs and lists in a value and selects defaults.
func Raw ¶
func Raw() Option
Raw tells Syntax to generate the value as is without any simplifications.
func ResolveReferences ¶
ResolveReferences forces the evaluation of references when outputting. This implies the input cannot have cycles.
type Runtime ¶
type Runtime struct {
// contains filtered or unexported fields
}
A Runtime is used for creating CUE interpretations.
Any operation that involves two Values or Instances should originate from the same Runtime.
The zero value of a Runtime is ready to use.
func (*Runtime) Build ¶
Build creates an Instance from the given build.Instance. A returned Instance may be incomplete, in which case its Err field is set.
func (*Runtime) Compile ¶
Compile compiles the given source into an Instance. The source code may be provided as a string, byte slice, io.Reader. The name is used as the file name in position information. The source may import builtin packages. Use Build to allow importing non-builtin packages.
func (*Runtime) CompileExpr ¶
CompileExpr compiles the given source expression into an Instance. The source may import builtin packages. Use Build to allow importing non-builtin packages.
func (*Runtime) CompileFile ¶
CompileFile compiles the given source file into an Instance. The source may import builtin packages. Use Build to allow importing non-builtin packages.
func (*Runtime) Marshal ¶
Marshal creates bytes from a group of instances. Imported instances will be included in the emission.
The stored instances are functionally the same, but preserving of file information is only done on a best-effort basis.
func (*Runtime) Parse
deprecated
Parse parses a CUE source value into a CUE Instance. The source code may be provided as a string, byte slice, or io.Reader. The name is used as the file name in position information. The source may import builtin packages.
Deprecated: use Compile
type Struct ¶
type Struct struct {
// contains filtered or unexported fields
}
Struct represents a CUE struct value.
func (*Struct) FieldByName ¶
FieldByName looks up a field for the given name. If isIdent is true, it will look up a definition or hidden field (starting with `_` or `_#`). Otherwise it interprets name as an arbitrary string for a regular field.
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 ¶
Dereference reports the value v refers to if v is a reference or v itself otherwise.
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) Bytes ¶
Bytes returns a byte slice if v represents a list of bytes or an error otherwise.
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 ¶
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) FieldByName ¶
FieldByName looks up a field for the given name. If isIdent is true, it will look up a definition or hidden field (starting with `_` or `_#`). Otherwise it interprets name as an arbitrary string for a regular field.
func (Value) Fields ¶
Fields creates an iterator over v's fields if v is a struct or an error otherwise.
func (Value) Fill ¶
Fill creates a new value by unifying v with the value of x at the given path.
Values may be any Go value that can be converted to CUE, an ast.Expr or a Value. In the latter case, it will panic if the Value is not from the same Runtime.
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) 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) IsClosed ¶
IsClosed reports whether a list of struct is closed. It reports false when when the value is not a list or struct.
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) Label ¶
Label reports he label used to obtain this value from the enclosing struct.
TODO: get rid of this somehow. Probably by including a FieldInfo struct or the like.
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) Lookup ¶
Lookup reports the value at a path starting from v. The empty path returns v itself. Use LookupDef for definitions or LookupField for any kind of field.
The Exists() method can be used to verify if the returned value existed. Lookup cannot be used to look up hidden or optional fields or definitions.
func (Value) LookupDef ¶
LookupDef reports the definition with the given name within struct v. The Exists method of the returned value will report false if the definition did not exist. The Err method reports if any error occurred during evaluation.
func (Value) LookupField
deprecated
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) Reader ¶
Reader returns a new Reader if v is a string or bytes type and an error otherwise.
func (Value) Reference ¶
Reference returns the instance and path referred to by this value such that inst.Lookup(path) resolves to the same value, or no path if this value is not a reference. If a reference contains index selection (foo[bar]), it will only return a reference if the index resolves to a concrete value.
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) Split
deprecated
Split returns a list of values from which v originated such that the unification of all these values equals v and for all returned values. It will also split unchecked unifications (embeddings), so unifying the split values may fail if actually unified. Source returns a non-nil value.
Deprecated: use Expr.
func (Value) Struct ¶
Struct returns the underlying struct of a value or an error if the value is not a struct.
func (Value) Subsume ¶
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() to indicate that the subsumed value is data, and that
Use the Final option to check subsumption if a w is known to be final, and should assumed to be closed.
Options are currently ignored and the function will panic if any are passed.
Value v and w must be obtained from the same build. TODO: remove this requirement.
func (Value) Subsumes
deprecated
Deprecated: use Subsume.
Subsumes reports whether w is an instance of v.
Without options, Subsumes checks whether v is a backwards compatbile schema of w.
By default, Subsumes tests whether two values are compatible 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) Template ¶
Template returns a function that represents the template definition for a struct in a configuration file. It returns nil if v is not a struct kind or if there is no template associated with the struct.
The returned function returns the value that would be unified with field given its name.
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 ¶
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.