File: function_no_proto_type.go

package info (click to toggle)
c2go 0.26.11-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,052 kB
  • sloc: ansic: 6,037; sh: 82; makefile: 5
file content (49 lines) | stat: -rw-r--r-- 1,303 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package ast

// FunctionNoProtoType is a function type without parameters.
//
// Example:
//    int (*)()
type FunctionNoProtoType struct {
	Addr        Address
	Type        string
	CallingConv string
	ChildNodes  []Node
}

func parseFunctionNoProtoType(line string) *FunctionNoProtoType {
	groups := groupsFromRegex(
		"'(?P<type>.*?)' (?P<calling_conv>.*)",
		line,
	)

	return &FunctionNoProtoType{
		Addr:        ParseAddress(groups["address"]),
		Type:        groups["type"],
		CallingConv: groups["calling_conv"],
		ChildNodes:  []Node{},
	}
}

// AddChild adds a new child node. Child nodes can then be accessed with the
// Children attribute.
func (n *FunctionNoProtoType) AddChild(node Node) {
	n.ChildNodes = append(n.ChildNodes, node)
}

// Address returns the numeric address of the node. See the documentation for
// the Address type for more information.
func (n *FunctionNoProtoType) Address() Address {
	return n.Addr
}

// Children returns the child nodes. If this node does not have any children or
// this node does not support children it will always return an empty slice.
func (n *FunctionNoProtoType) Children() []Node {
	return n.ChildNodes
}

// Position returns the position in the original source code.
func (n *FunctionNoProtoType) Position() Position {
	return Position{}
}