2022-09-04 12:02:48 -06:00
|
|
|
package parser
|
|
|
|
|
2022-09-04 21:47:56 -06:00
|
|
|
import "git.tebibyte.media/arf/arf/types"
|
|
|
|
|
2022-09-04 15:13:49 -06:00
|
|
|
// LookupSection looks returns the section under the give name. If the section
|
|
|
|
// does not exist, nil is returned.
|
2022-09-04 21:47:56 -06:00
|
|
|
func (tree SyntaxTree) LookupSection (name string) (section Section) {
|
2022-09-04 15:13:49 -06:00
|
|
|
section = tree.sections[name]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-04 21:47:56 -06:00
|
|
|
// Sections returns an iterator for the tree's sections
|
|
|
|
func (tree SyntaxTree) Sections () (iterator types.Iterator[Section]) {
|
|
|
|
iterator = types.NewIterator(tree.sections)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-07 15:12:46 -06:00
|
|
|
// ResolveRequire returns the full path, from the filesystem root, of an import.
|
|
|
|
// This method will return false for exists if the module has not been
|
|
|
|
// imported.
|
|
|
|
func (tree SyntaxTree) ResolveRequire (name string) (path string, exists bool) {
|
|
|
|
path, exists = tree.requires[name]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-04 12:02:48 -06:00
|
|
|
// Kind returns the section's kind (SectionKindType).
|
|
|
|
func (section TypeSection) Kind () (kind SectionKind) {
|
|
|
|
kind = SectionKindType
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Kind returns the section's kind (SectionKindEnum).
|
|
|
|
func (section EnumSection) Kind () (kind SectionKind) {
|
|
|
|
kind = SectionKindEnum
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Kind returns the section's kind (SectionKindFace).
|
|
|
|
func (section FaceSection) Kind () (kind SectionKind) {
|
|
|
|
kind = SectionKindFace
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Kind returns the section's kind (SectionKindData).
|
|
|
|
func (section DataSection) Kind () (kind SectionKind) {
|
|
|
|
kind = SectionKindData
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Kind returns the section's kind (SectionKindFunc).
|
|
|
|
func (section FuncSection) Kind () (kind SectionKind) {
|
|
|
|
kind = SectionKindFunc
|
|
|
|
return
|
|
|
|
}
|
2022-09-04 20:19:19 -06:00
|
|
|
|
|
|
|
// Length returns the amount of names in the identifier.
|
|
|
|
func (identifier Identifier) Length () (length int) {
|
|
|
|
length = len(identifier.trail)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Item returns the name at the specified index.
|
|
|
|
func (identifier Identifier) Item (index int) (item string) {
|
|
|
|
item = identifier.trail[index]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-19 10:17:12 -06:00
|
|
|
// Bite removes the first item from the identifier and returns it.
|
|
|
|
func (identifier *Identifier) Bite () (item string) {
|
|
|
|
item = identifier.trail[0]
|
|
|
|
identifier.trail = identifier.trail[1:]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-04 20:19:19 -06:00
|
|
|
// Kind returns the type's kind.
|
|
|
|
func (what Type) Kind () (kind TypeKind) {
|
|
|
|
kind = what.kind
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Mutable returns whether or not the type's data is mutable.
|
|
|
|
func (what Type) Mutable () (mutable bool) {
|
|
|
|
mutable = what.mutable
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-05 09:20:23 -06:00
|
|
|
// Length returns the length of the type. If it is greater than 1, that means
|
|
|
|
// the type is a fixed length array.
|
2022-09-04 20:19:19 -06:00
|
|
|
func (what Type) Length () (length uint64) {
|
2022-09-05 09:20:23 -06:00
|
|
|
length = 1
|
|
|
|
if what.length > 1 {
|
2022-09-04 20:19:19 -06:00
|
|
|
length = what.length
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Name returns the name of the type, if it is a basic type. Otherwise, it
|
|
|
|
// returns a zero value identifier.
|
|
|
|
func (what Type) Name () (name Identifier) {
|
|
|
|
if what.kind == TypeKindBasic {
|
|
|
|
name = what.name
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Points returns the type that this type points to, or is an array of. If the
|
|
|
|
// type is a basic type, this returns a zero value type.
|
|
|
|
func (what Type) Points () (points Type) {
|
|
|
|
if what.kind != TypeKindBasic {
|
|
|
|
points = *what.points
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
2022-09-04 21:47:56 -06:00
|
|
|
|
2022-09-11 14:15:02 -06:00
|
|
|
// MembersLength returns the amount of new members the type specifier defines.
|
|
|
|
// If it defines no new members, it returns zero.
|
|
|
|
func (what Type) MembersLength () (length int) {
|
|
|
|
length = len(what.members)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Member returns the member at index.
|
|
|
|
func (what Type) Member (index int) (member TypeMember) {
|
|
|
|
member = what.members[index]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// BitWidth returns the bit width of the type member. If it is zero, it should
|
|
|
|
// be treated as unspecified.
|
|
|
|
func (member TypeMember) BitWidth () (width uint64) {
|
|
|
|
width = member.bitWidth
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-04 23:05:03 -06:00
|
|
|
// Kind returns what kind of argument it is.
|
|
|
|
func (argument Argument) Kind () (kind ArgumentKind) {
|
|
|
|
kind = argument.kind
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Value returns the underlying value of the argument. You can use Kind() to
|
|
|
|
// find out what to cast this to.
|
|
|
|
func (argument Argument) Value () (value any) {
|
|
|
|
value = argument.value
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-04 23:09:29 -06:00
|
|
|
// Length returns the amount of members in the section.
|
|
|
|
func (section EnumSection) Length () (length int) {
|
|
|
|
length = len(section.members)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Item returns the member at index.
|
|
|
|
func (section EnumSection) Item (index int) (member EnumMember) {
|
|
|
|
member = section.members[index]
|
|
|
|
return
|
|
|
|
}
|
2022-09-04 23:21:51 -06:00
|
|
|
|
|
|
|
// InputsLength returns the amount of inputs in the behavior.
|
|
|
|
func (behavior FaceBehavior) IntputsLength () (length int) {
|
|
|
|
length = len(behavior.inputs)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Input returns the input at index.
|
|
|
|
func (behavior FaceBehavior) Input (index int) (input Declaration) {
|
|
|
|
input = behavior.inputs[index]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// OutputsLength returns the amount of outputs in the behavior.
|
|
|
|
func (behavior FaceBehavior) OutputsLength () (length int) {
|
|
|
|
length = len(behavior.outputs)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Output returns the output at index.
|
|
|
|
func (behavior FaceBehavior) Output (index int) (output Declaration) {
|
|
|
|
output = behavior.outputs[index]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Behaviors returns an iterator for the interface's behaviors.
|
|
|
|
func (section FaceSection) Behaviors () (iterator types.Iterator[FaceBehavior]) {
|
|
|
|
iterator = types.NewIterator(section.behaviors)
|
|
|
|
return
|
2022-09-05 12:09:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
// External returns whether or not the data section is external.
|
|
|
|
func (section DataSection) External () (external bool) {
|
|
|
|
external = section.external
|
|
|
|
return
|
2022-09-04 23:21:51 -06:00
|
|
|
}
|
2022-09-05 00:04:37 -06:00
|
|
|
|
|
|
|
// Kind returns what kind of phrase it is.
|
|
|
|
func (phrase Phrase) Kind () (kind PhraseKind) {
|
|
|
|
kind = phrase.kind
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// ArgumentsLength returns the amount of arguments in the phrase.
|
|
|
|
func (phrase Phrase) ArgumentsLength () (length int) {
|
|
|
|
length = len(phrase.arguments)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Argument returns the argument at index.
|
|
|
|
func (phrase Phrase) Argument (index int) (argument Argument) {
|
|
|
|
argument = phrase.arguments[index]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-05 09:49:19 -06:00
|
|
|
// ReturneesLength returns the amount of things the phrase returns to.
|
|
|
|
func (phrase Phrase) ReturneesLength () (length int) {
|
|
|
|
length = len(phrase.returnees)
|
2022-09-05 00:04:37 -06:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-05 09:49:19 -06:00
|
|
|
// Returnee returns the returnee at index.
|
|
|
|
func (phrase Phrase) Returnee (index int) (returnee Argument) {
|
|
|
|
returnee = phrase.returnees[index]
|
2022-09-05 00:04:37 -06:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Block returns the block under the phrase, if it is a control flow statement.
|
|
|
|
func (phrase Phrase) Block () (block Block) {
|
|
|
|
block = phrase.block
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-09-05 08:39:46 -06:00
|
|
|
// Receiver returns the method receiver, if there is one. Otherwise, it returns
|
|
|
|
// nil.
|
|
|
|
func (section FuncSection) Receiver () (receiver *Declaration) {
|
|
|
|
receiver = section.receiver
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// InputsLength returns the number of inputs in the function.
|
|
|
|
func (section FuncSection) InputsLength () (length int) {
|
|
|
|
length = len(section.inputs)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Input returns the input at index.
|
|
|
|
func (section FuncSection) Input (index int) (input Declaration) {
|
|
|
|
input = section.inputs[index]
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// OutputsLength returns the number of outputs in the function.
|
|
|
|
func (section FuncSection) OutputsLength () (length int) {
|
|
|
|
length = len(section.outputs)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Root returns the root block of the section.
|
|
|
|
func (section FuncSection) Root () (root Block) {
|
|
|
|
root = section.root
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// External returns whether or not the function is an external function or not.
|
|
|
|
func (section FuncSection) External () (external bool) {
|
|
|
|
external = section.external
|
|
|
|
return
|
|
|
|
}
|