object

package
v0.24.6 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 20, 2024 License: BSD-3-Clause Imports: 15 Imported by: 1

Documentation

Overview

Operations on objects, variables, and kinds.

Index

Constants

This section is empty.

Variables

View Source
var Z_Types = typeinfo.TypeSet{
	Name: "object",
	Comment: []string{
		"Operations on objects, variables, and kinds.",
	},

	Slot:       z_slot_list,
	Flow:       z_flow_list,
	Signatures: z_signatures,
}

package listing of type data

View Source
var Zt_AtField typeinfo.Flow

at_field, a type of flow.

View Source
var Zt_AtIndex typeinfo.Flow

at_index, a type of flow.

View Source
var Zt_DecrementAspect typeinfo.Flow

decrement_aspect, a type of flow.

View Source
var Zt_Dot = typeinfo.Slot{
	Name: "dot",
	Markup: map[string]any{
		"comment": "Access values stored inside other values.",
	},
}

dot, a type of slot.

View Source
var Zt_FieldsOfKind typeinfo.Flow

fields_of_kind, a type of flow.

View Source
var Zt_IncrementAspect typeinfo.Flow

increment_aspect, a type of flow.

View Source
var Zt_IsExactKindOf typeinfo.Flow

is_exact_kind_of, a type of flow.

View Source
var Zt_IsKindOf typeinfo.Flow

is_kind_of, a type of flow.

View Source
var Zt_KindOf typeinfo.Flow

kind_of, a type of flow.

View Source
var Zt_KindsOf typeinfo.Flow

kinds_of, a type of flow.

View Source
var Zt_ObjectDot typeinfo.Flow

object_dot, a type of flow.

View Source
var Zt_ObjectName typeinfo.Flow

object_name, a type of flow.

View Source
var Zt_ObjectStates typeinfo.Flow

object_states, a type of flow.

View Source
var Zt_SetState typeinfo.Flow

set_state, a type of flow.

View Source
var Zt_SetValue typeinfo.Flow

set_value, a type of flow.

View Source
var Zt_VariableDot typeinfo.Flow

variable_dot, a type of flow.

Functions

func GetNamedValue

func GetNamedValue(run rt.Runtime, name string, dots []Dot) (ret rt.Value, err error)

note: currently templates can't analyze the context they're being called in, so: if the command is being used to get an object value and no variable can be found in the current context of the requested name, see if the requested name is an object instead.

Types

type AtField

type AtField struct {
	FieldName rtti.TextEval
	Markup    map[string]any
}

Select a named field from a record, or a named property from an object.

func (*AtField) GetMarkup

func (op *AtField) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*AtField) Resolve

func (op *AtField) Resolve(run rt.Runtime) (ret rt.Dotted, err error)

return a dot.Field

func (*AtField) TypeInfo

func (*AtField) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type AtField_Slice

type AtField_Slice []AtField

Holds a slice of type AtField.

func (*AtField_Slice) Repeats

func (op *AtField_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of AtField.

func (*AtField_Slice) TypeInfo

func (*AtField_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of AtField.

type AtIndex

type AtIndex struct {
	Index  rtti.NumEval
	Markup map[string]any
}

Select a value from a list of values.

func (*AtIndex) GetMarkup

func (op *AtIndex) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*AtIndex) Resolve

func (op *AtIndex) Resolve(run rt.Runtime) (ret rt.Dotted, err error)

return a dot.Index

func (*AtIndex) TypeInfo

func (*AtIndex) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type AtIndex_Slice

type AtIndex_Slice []AtIndex

Holds a slice of type AtIndex.

func (*AtIndex_Slice) Repeats

func (op *AtIndex_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of AtIndex.

func (*AtIndex_Slice) TypeInfo

func (*AtIndex_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of AtIndex.

type DecrementAspect

type DecrementAspect struct {
	Target     rtti.Address
	AspectName rtti.TextEval
	Step       rtti.NumEval
	Clamp      rtti.BoolEval
	Markup     map[string]any
}

Change to the previous state in some particular set of states for a given object ( or record. ) Optionally, returns the new value of the state. Uses the order of the states where as they were originally defined. See [DefineState].

func (*DecrementAspect) Execute

func (op *DecrementAspect) Execute(run rt.Runtime) (err error)

func (*DecrementAspect) GetMarkup

func (op *DecrementAspect) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*DecrementAspect) GetText

func (op *DecrementAspect) GetText(run rt.Runtime) (ret rt.Value, err error)

func (*DecrementAspect) TypeInfo

func (*DecrementAspect) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type DecrementAspect_Slice

type DecrementAspect_Slice []DecrementAspect

Holds a slice of type DecrementAspect.

func (*DecrementAspect_Slice) Repeats

func (op *DecrementAspect_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of DecrementAspect.

func (*DecrementAspect_Slice) TypeInfo

func (*DecrementAspect_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of DecrementAspect.

type Dot

type Dot interface {
	Resolve(rt.Runtime) (rt.Dotted, error)
}

Dot - access to a value inside another value. ex. in objects, lists, or records.

func MakeDot

func MakeDot(path ...any) (ret []Dot)

type Dot_Slot

type Dot_Slot struct{ Value Dot }

Holds a single slot.

func (*Dot_Slot) TypeInfo

func (*Dot_Slot) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a single slot.

type Dot_Slots

type Dot_Slots []Dot

Holds a slice of slots.

func (*Dot_Slots) Repeats

func (op *Dot_Slots) Repeats() bool

Implements typeinfo.Repeats for a slice of slots.

func (*Dot_Slots) TypeInfo

func (*Dot_Slots) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of slots.

type FieldsOfKind

type FieldsOfKind struct {
	KindName rtti.TextEval
	Markup   map[string]any
}

A list of the fields of a given kind.

func (*FieldsOfKind) GetMarkup

func (op *FieldsOfKind) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*FieldsOfKind) GetTextList

func (op *FieldsOfKind) GetTextList(run rt.Runtime) (ret rt.Value, err error)

tbd: fields of kind could be expanded to full introspection if the Field structure was a record. ( maybe some core classes could be exposed using the test reflection? might make porting harder )

func (*FieldsOfKind) TypeInfo

func (*FieldsOfKind) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type FieldsOfKind_Slice

type FieldsOfKind_Slice []FieldsOfKind

Holds a slice of type FieldsOfKind.

func (*FieldsOfKind_Slice) Repeats

func (op *FieldsOfKind_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of FieldsOfKind.

func (*FieldsOfKind_Slice) TypeInfo

func (*FieldsOfKind_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of FieldsOfKind.

type IncrementAspect

type IncrementAspect struct {
	Target     rtti.Address
	AspectName rtti.TextEval
	Step       rtti.NumEval
	Clamp      rtti.BoolEval
	Markup     map[string]any
}

Change to the next state in some particular set of states for a given object ( or record. ) Optionally, returns the new value of the state. Uses the order of the states where as they were originally defined. See [DefineState].

func (*IncrementAspect) Execute

func (op *IncrementAspect) Execute(run rt.Runtime) (err error)

func (*IncrementAspect) GetMarkup

func (op *IncrementAspect) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*IncrementAspect) GetText

func (op *IncrementAspect) GetText(run rt.Runtime) (ret rt.Value, err error)

func (*IncrementAspect) TypeInfo

func (*IncrementAspect) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type IncrementAspect_Slice

type IncrementAspect_Slice []IncrementAspect

Holds a slice of type IncrementAspect.

func (*IncrementAspect_Slice) Repeats

func (op *IncrementAspect_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of IncrementAspect.

func (*IncrementAspect_Slice) TypeInfo

func (*IncrementAspect_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of IncrementAspect.

type IsExactKindOf

type IsExactKindOf struct {
	Target   rtti.Address
	KindName rtti.TextEval
	Markup   map[string]any
}

Determine whether an object (or record) is of exactly the named kind. For example, all containers are a kind of prop. Asking if a container is exactly a prop would return false. See also IsKindOf.

func (*IsExactKindOf) GetBool

func (op *IsExactKindOf) GetBool(run rt.Runtime) (ret rt.Value, err error)

returns true if the indicated object is of the specified kind but not a kind that derives from the specified kind. returns an error if there is no such object; returns the false for an empty request.

func (*IsExactKindOf) GetMarkup

func (op *IsExactKindOf) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*IsExactKindOf) TypeInfo

func (*IsExactKindOf) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type IsExactKindOf_Slice

type IsExactKindOf_Slice []IsExactKindOf

Holds a slice of type IsExactKindOf.

func (*IsExactKindOf_Slice) Repeats

func (op *IsExactKindOf_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of IsExactKindOf.

func (*IsExactKindOf_Slice) TypeInfo

func (*IsExactKindOf_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of IsExactKindOf.

type IsKindOf

type IsKindOf struct {
	Target   rtti.Address
	KindName rtti.TextEval
	Nothing  bool
	Markup   map[string]any
}

Determine whether an object (or record) is compatible with the named kind. For example, all containers are a kind of prop. Asking if a container is a kind of a prop would return true. See also IsExactKindOf.

func (*IsKindOf) GetBool

func (op *IsKindOf) GetBool(run rt.Runtime) (ret rt.Value, err error)

returns true if the indicated object is of the specified kind. returns an error if there is no such object; returns the false for an empty request UNLESS nothing objects were specified as being allowed to match.

func (*IsKindOf) GetMarkup

func (op *IsKindOf) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*IsKindOf) TypeInfo

func (*IsKindOf) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type IsKindOf_Slice

type IsKindOf_Slice []IsKindOf

Holds a slice of type IsKindOf.

func (*IsKindOf_Slice) Repeats

func (op *IsKindOf_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of IsKindOf.

func (*IsKindOf_Slice) TypeInfo

func (*IsKindOf_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of IsKindOf.

type KindOf

type KindOf struct {
	Target  rtti.Address
	Nothing bool
	Markup  map[string]any
}

The kind of an object or record.

func (*KindOf) GetMarkup

func (op *KindOf) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*KindOf) GetText

func (op *KindOf) GetText(run rt.Runtime) (ret rt.Value, err error)

returns the kind of the indicated object. returns an error if there is no such object; returns the empty string for an empty request.

func (*KindOf) TypeInfo

func (*KindOf) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type KindOf_Slice

type KindOf_Slice []KindOf

Holds a slice of type KindOf.

func (*KindOf_Slice) Repeats

func (op *KindOf_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of KindOf.

func (*KindOf_Slice) TypeInfo

func (*KindOf_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of KindOf.

type KindsOf

type KindsOf struct {
	KindName rtti.TextEval
	Markup   map[string]any
}

A list of all objects accessible by the current scene that compatible with the specified kind.

func (*KindsOf) GetMarkup

func (op *KindsOf) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*KindsOf) GetTextList

func (op *KindsOf) GetTextList(run rt.Runtime) (ret rt.Value, err error)

returns a list of all objects of the specified kind.

func (*KindsOf) TypeInfo

func (*KindsOf) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type KindsOf_Slice

type KindsOf_Slice []KindsOf

Holds a slice of type KindsOf.

func (*KindsOf_Slice) Repeats

func (op *KindsOf_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of KindsOf.

func (*KindsOf_Slice) TypeInfo

func (*KindsOf_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of KindsOf.

type ObjectDot

type ObjectDot struct {
	NounName rtti.TextEval
	Dot      []Dot
	Markup   map[string]any
}

Read a value from an object. As a special case, if there are no dot parts, this will return the id of the object. In .tell files, this command is often specified with a shortcut. For example:

"#my_object.some_field"

is a shorter way to say:

Object:dot:
- "my object"
- "some field"

WARNING: This doesn't convert values from one type to another. For instance, if a field was declared as text, this will error if read as a boolean.

func Object

func Object(name string, path ...any) *ObjectDot

func (*ObjectDot) GetBool

func (op *ObjectDot) GetBool(run rt.Runtime) (ret rt.Value, err error)

func (*ObjectDot) GetMarkup

func (op *ObjectDot) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*ObjectDot) GetNum

func (op *ObjectDot) GetNum(run rt.Runtime) (rt.Value, error)

func (*ObjectDot) GetNumList

func (op *ObjectDot) GetNumList(run rt.Runtime) (rt.Value, error)

func (*ObjectDot) GetRecord

func (op *ObjectDot) GetRecord(run rt.Runtime) (rt.Value, error)

func (*ObjectDot) GetRecordList

func (op *ObjectDot) GetRecordList(run rt.Runtime) (rt.Value, error)

func (*ObjectDot) GetReference

func (op *ObjectDot) GetReference(run rt.Runtime) (ret rt.Reference, err error)

func (*ObjectDot) GetText

func (op *ObjectDot) GetText(run rt.Runtime) (ret rt.Value, err error)

as a special case, if there are no dot parts, return the id of the object

func (*ObjectDot) GetTextList

func (op *ObjectDot) GetTextList(run rt.Runtime) (rt.Value, error)

func (*ObjectDot) TypeInfo

func (*ObjectDot) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type ObjectDot_Slice

type ObjectDot_Slice []ObjectDot

Holds a slice of type ObjectDot.

func (*ObjectDot_Slice) Repeats

func (op *ObjectDot_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of ObjectDot.

func (*ObjectDot_Slice) TypeInfo

func (*ObjectDot_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of ObjectDot.

type ObjectName

type ObjectName struct {
	Target rtti.Address
	Markup map[string]any
}

The full name of an object as originally specified by the author. Generates an error for unknown objects except it returns empty text when given empty text. See also ObjectDot which can return the object's unique id.

func (*ObjectName) GetMarkup

func (op *ObjectName) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*ObjectName) GetText

func (op *ObjectName) GetText(run rt.Runtime) (ret rt.Value, err error)

returns the author specified name for the indicated object. returns an error if there is no such object; returns the empty string for an empty request.

func (*ObjectName) TypeInfo

func (*ObjectName) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type ObjectName_Slice

type ObjectName_Slice []ObjectName

Holds a slice of type ObjectName.

func (*ObjectName_Slice) Repeats

func (op *ObjectName_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of ObjectName.

func (*ObjectName_Slice) TypeInfo

func (*ObjectName_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of ObjectName.

type ObjectStates

type ObjectStates struct {
	Target rtti.Address
	Markup map[string]any
}

All of an object's current states as a list of text. ( Despite the name, can also be used on records. )

func (*ObjectStates) GetMarkup

func (op *ObjectStates) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*ObjectStates) GetTextList

func (op *ObjectStates) GetTextList(run rt.Runtime) (ret rt.Value, err error)

func (*ObjectStates) TypeInfo

func (*ObjectStates) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type ObjectStates_Slice

type ObjectStates_Slice []ObjectStates

Holds a slice of type ObjectStates.

func (*ObjectStates_Slice) Repeats

func (op *ObjectStates_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of ObjectStates.

func (*ObjectStates_Slice) TypeInfo

func (*ObjectStates_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of ObjectStates.

type SetState

type SetState struct {
	Target    rtti.Address
	StateName rtti.TextEval
	Markup    map[string]any
}

Set the state of an object or record. See also: story `Define state:names:`.

func (*SetState) Execute

func (op *SetState) Execute(run rt.Runtime) (err error)

func (*SetState) GetMarkup

func (op *SetState) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*SetState) TypeInfo

func (*SetState) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type SetState_Slice

type SetState_Slice []SetState

Holds a slice of type SetState.

func (*SetState_Slice) Repeats

func (op *SetState_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of SetState.

func (*SetState_Slice) TypeInfo

func (*SetState_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of SetState.

type SetValue

type SetValue struct {
	Target rtti.Address
	Value  rtti.Assignment
	Markup map[string]any
}

Store a value into a variable or object. Values are specified as a generic [Assignment]. The various "From" commands exist to cast specific value types into an assignment.

WARNING: This doesn't convert values from one type to another. For example:

Set:value:
- "@some_local_variable"
- FromText: "a piece of text to store."

will only work if the local variable can store text. If the variable was declared as a number, the command will generate an error.

func (*SetValue) Execute

func (op *SetValue) Execute(run rt.Runtime) (err error)

func (*SetValue) GetMarkup

func (op *SetValue) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*SetValue) TypeInfo

func (*SetValue) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type SetValue_Slice

type SetValue_Slice []SetValue

Holds a slice of type SetValue.

func (*SetValue_Slice) Repeats

func (op *SetValue_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of SetValue.

func (*SetValue_Slice) TypeInfo

func (*SetValue_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of SetValue.

type VariableDot

type VariableDot struct {
	VariableName rtti.TextEval
	Dot          []Dot
	Markup       map[string]any
}

Read a value from a variable. In .tell files, this command is often specified with a shortcut. For example:

"@some_local_variable"

is a shorter way to say:

Variable:dot: "some local variable"

WARNING: This doesn't convert values from one type to another. For instance, if a field was declared as text, this will error if read as a boolean.

func Variable

func Variable(name string, path ...any) *VariableDot

generate a statement which extracts a variable's value. path can include strings ( for reading from records ) or integers ( for reading from lists )

func (*VariableDot) GetBool

func (op *VariableDot) GetBool(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) GetMarkup

func (op *VariableDot) GetMarkup(ensure bool) map[string]any

Implements typeinfo.Markup

func (*VariableDot) GetNum

func (op *VariableDot) GetNum(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) GetNumList

func (op *VariableDot) GetNumList(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) GetRecord

func (op *VariableDot) GetRecord(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) GetRecordList

func (op *VariableDot) GetRecordList(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) GetReference

func (op *VariableDot) GetReference(run rt.Runtime) (ret rt.Reference, err error)

func (*VariableDot) GetText

func (op *VariableDot) GetText(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) GetTextList

func (op *VariableDot) GetTextList(run rt.Runtime) (ret rt.Value, err error)

func (*VariableDot) TypeInfo

func (*VariableDot) TypeInfo() typeinfo.T

Implements typeinfo.Instance

type VariableDot_Slice

type VariableDot_Slice []VariableDot

Holds a slice of type VariableDot.

func (*VariableDot_Slice) Repeats

func (op *VariableDot_Slice) Repeats() bool

Implements typeinfo.Repeats for a slice of VariableDot.

func (*VariableDot_Slice) TypeInfo

func (*VariableDot_Slice) TypeInfo() typeinfo.T

Implements typeinfo.Instance for a slice of VariableDot.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL