Run gofmt -w on everything. Add 'gogc' option to use Go garbage

collector for memory management.
This commit is contained in:
Greg 2019-06-11 12:38:22 -04:00
parent d0654613ea
commit 9a4fabda24
297 changed files with 6690 additions and 6641 deletions

4
.gitignore vendored
View File

@ -9,3 +9,7 @@ examples/foundation/foundation
examples/foundation/ns
examples/simple/simple
examples/simple/ClassOne
examples/memory/memory
examples/memory/ns
examples/gc/gc
examples/gc/ns

View File

@ -6,23 +6,22 @@ import (
func TestAlignedAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7f8a1d8ccfd0 <col:47, col:57> aligned`:
testNode{&AlignedAttr{
`0x7f8a1d8ccfd0 <col:47, col:57> aligned`: testNode{&AlignedAttr{
Addr: 0x7f8a1d8ccfd0,
Pos: NewPositionFromString("col:47, col:57"),
IsAligned: true,
ChildNodes: []Node{},
},
},
0x7f8a1d8ccfd0,
NewPositionFromString("col:47, col:57"),
[]Node{},
},
`0x2c8ba10 <col:42>`: testNode{ &AlignedAttr{
`0x2c8ba10 <col:42>`: testNode{&AlignedAttr{
Addr: 0x2c8ba10,
Pos: NewPositionFromString("col:42"),
IsAligned: false,
ChildNodes: []Node{},
},
},
0x2c8ba10,
NewPositionFromString("col:42"),
[]Node{},
@ -31,4 +30,3 @@ func TestAlignedAttr(t *testing.T) {
runNodeTests(t, nodes)
}

View File

@ -2,7 +2,6 @@ package ast
import (
"strings"
//"git.wow.st/gmp/nswrap/util"
)

View File

@ -6,20 +6,18 @@ import (
func TestAllocSizeAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7f8e390a5d38 <col:100, col:114> 1 2`:
testNode{&AllocSizeAttr{
`0x7f8e390a5d38 <col:100, col:114> 1 2`: testNode{&AllocSizeAttr{
Addr: 0x7f8e390a5d38,
Pos: NewPositionFromString("col:100, col:114"),
A: "1",
B: "2",
ChildNodes: []Node{},
},
0x7f8e390a5d38,
NewPositionFromString("col:100, col:114"),
[]Node{},
0x7f8e390a5d38,
NewPositionFromString("col:100, col:114"),
[]Node{},
},
`0x7fbd1a167f48 </usr/include/stdlib.h:342:37> Inherited 1 0`:
testNode{&AllocSizeAttr{
`0x7fbd1a167f48 </usr/include/stdlib.h:342:37> Inherited 1 0`: testNode{&AllocSizeAttr{
Addr: 0x7fbd1a167f48,
Pos: NewPositionFromString("/usr/include/stdlib.h:342:37"),
Inherited: true,
@ -27,12 +25,11 @@ func TestAllocSizeAttr(t *testing.T) {
B: "0",
ChildNodes: []Node{},
},
0x7fbd1a167f48,
NewPositionFromString("/usr/include/stdlib.h:342:37"),
[]Node{},
0x7fbd1a167f48,
NewPositionFromString("/usr/include/stdlib.h:342:37"),
[]Node{},
},
`0x7fbd1a167f48 </usr/include/stdlib.h:342:37> Inherited 1`:
testNode{&AllocSizeAttr{
`0x7fbd1a167f48 </usr/include/stdlib.h:342:37> Inherited 1`: testNode{&AllocSizeAttr{
Addr: 0x7fbd1a167f48,
Pos: NewPositionFromString("/usr/include/stdlib.h:342:37"),
Inherited: true,
@ -40,9 +37,9 @@ func TestAllocSizeAttr(t *testing.T) {
B: "",
ChildNodes: []Node{},
},
0x7fbd1a167f48,
NewPositionFromString("/usr/include/stdlib.h:342:37"),
[]Node{},
0x7fbd1a167f48,
NewPositionFromString("/usr/include/stdlib.h:342:37"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestAlwaysInlineAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fce780f5018 </usr/include/sys/cdefs.h:313:68> always_inline`:
testNode{&AlwaysInlineAttr{
`0x7fce780f5018 </usr/include/sys/cdefs.h:313:68> always_inline`: testNode{&AlwaysInlineAttr{
Addr: 0x7fce780f5018,
Pos: NewPositionFromString("/usr/include/sys/cdefs.h:313:68"),
ChildNodes: []Node{},
},
0x7fce780f5018,
NewPositionFromString("/usr/include/sys/cdefs.h:313:68"),
[]Node{},
0x7fce780f5018,
NewPositionFromString("/usr/include/sys/cdefs.h:313:68"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseArcWeakrefUnavailableAttr(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &ArcWeakrefUnavailableAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestArcWeakrefUnavailableAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7>`:
testNode{&ArcWeakrefUnavailableAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7>`: testNode{&ArcWeakrefUnavailableAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -7,7 +7,7 @@ import (
func TestArrayFiller(t *testing.T) {
i := 0
runNodeTest(t, Parse(`array filler`),
testNode{ &ArrayFiller{ ChildNodes: []Node{} },
0,NewPositionFromString(""),[]Node{}},
testNode{&ArrayFiller{ChildNodes: []Node{}},
0, NewPositionFromString(""), []Node{}},
&i)
}

View File

@ -2,13 +2,13 @@ package ast
// ArraySubscriptExpr is expression.
type ArraySubscriptExpr struct {
Addr Address
Pos Position
Type string
Type2 string
IsLvalue bool
Addr Address
Pos Position
Type string
Type2 string
IsLvalue bool
IsVectorComponent bool
ChildNodes []Node
ChildNodes []Node
}
func parseArraySubscriptExpr(line string) Node {
@ -23,13 +23,13 @@ func parseArraySubscriptExpr(line string) Node {
}
return &ArraySubscriptExpr{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: groups["type"],
Type2: groups["type2"],
IsLvalue: len(groups["lvalue"]) > 0,
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: groups["type"],
Type2: groups["type2"],
IsLvalue: len(groups["lvalue"]) > 0,
IsVectorComponent: len(groups["vcomp"]) > 0,
ChildNodes: []Node{},
ChildNodes: []Node{},
}
}

View File

@ -6,8 +6,7 @@ import (
func TestArraySubscriptExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7fe35b85d180 <col:63, col:69> 'char *' lvalue`:
testNode{&ArraySubscriptExpr{
`0x7fe35b85d180 <col:63, col:69> 'char *' lvalue`: testNode{&ArraySubscriptExpr{
Addr: 0x7fe35b85d180,
Pos: NewPositionFromString("col:63, col:69"),
Type: "char *",
@ -15,12 +14,11 @@ func TestArraySubscriptExpr(t *testing.T) {
IsLvalue: true,
ChildNodes: []Node{},
},
0x7fe35b85d180,
NewPositionFromString("col:63, col:69"),
[]Node{},
0x7fe35b85d180,
NewPositionFromString("col:63, col:69"),
[]Node{},
},
`0x2416660 <col:2, col:5> 'u32':'unsigned int' lvalue`:
testNode{&ArraySubscriptExpr{
`0x2416660 <col:2, col:5> 'u32':'unsigned int' lvalue`: testNode{&ArraySubscriptExpr{
Addr: 0x2416660,
Pos: NewPositionFromString("col:2, col:5"),
Type: "u32",
@ -28,12 +26,11 @@ func TestArraySubscriptExpr(t *testing.T) {
IsLvalue: true,
ChildNodes: []Node{},
},
0x2416660,
NewPositionFromString("col:2, col:5"),
[]Node{},
0x2416660,
NewPositionFromString("col:2, col:5"),
[]Node{},
},
`0x3f147c0 <col:39, col:55> 'extCoord':'extCoord' lvalue`:
testNode{&ArraySubscriptExpr{
`0x3f147c0 <col:39, col:55> 'extCoord':'extCoord' lvalue`: testNode{&ArraySubscriptExpr{
Addr: 0x3f147c0,
Pos: NewPositionFromString("col:39, col:55"),
Type: "extCoord",
@ -41,9 +38,9 @@ func TestArraySubscriptExpr(t *testing.T) {
IsLvalue: true,
ChildNodes: []Node{},
},
0x3f147c0,
NewPositionFromString("col:39, col:55"),
[]Node{},
0x3f147c0,
NewPositionFromString("col:39, col:55"),
[]Node{},
},
}

View File

@ -6,29 +6,27 @@ import (
func TestAsmLabelAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7ff26d8224e8 </usr/include/sys/cdefs.h:569:36> "_fopen"`:
testNode{&AsmLabelAttr{
`0x7ff26d8224e8 </usr/include/sys/cdefs.h:569:36> "_fopen"`: testNode{&AsmLabelAttr{
Addr: 0x7ff26d8224e8,
Pos: NewPositionFromString("/usr/include/sys/cdefs.h:569:36"),
Inherited: false,
FunctionName: "_fopen",
ChildNodes: []Node{},
},
0x7ff26d8224e8,
NewPositionFromString("/usr/include/sys/cdefs.h:569:36"),
[]Node{},
0x7ff26d8224e8,
NewPositionFromString("/usr/include/sys/cdefs.h:569:36"),
[]Node{},
},
`0x7fd55a169318 </usr/include/stdio.h:325:47> Inherited "_popen"`:
testNode{&AsmLabelAttr{
`0x7fd55a169318 </usr/include/stdio.h:325:47> Inherited "_popen"`: testNode{&AsmLabelAttr{
Addr: 0x7fd55a169318,
Pos: NewPositionFromString("/usr/include/stdio.h:325:47"),
Inherited: true,
FunctionName: "_popen",
ChildNodes: []Node{},
},
0x7fd55a169318,
NewPositionFromString("/usr/include/stdio.h:325:47"),
[]Node{},
0x7fd55a169318,
NewPositionFromString("/usr/include/stdio.h:325:47"),
[]Node{},
},
}

View File

@ -11,7 +11,7 @@ import (
var (
TrackPositions bool = false
Debug = false
Debug = false
)
// Node represents any node in the AST.
@ -252,9 +252,9 @@ func Parse(fullline string) Node {
case "ObjCIndependentClassAttr":
return parseObjCIndependentClassAttr(line)
case "ObjCInterface":
return parseObjCInterface(line,false)
return parseObjCInterface(line, false)
case "super ObjCInterface":
return parseObjCInterface(line,true)
return parseObjCInterface(line, true)
case "ObjCInterfaceDecl":
return parseObjCInterfaceDecl(line)
case "ObjCInterfaceType":
@ -394,7 +394,7 @@ func Parse(fullline string) Node {
case "NullStmt":
return nil
default:
return parseUnknown(nodeName,line)
return parseUnknown(nodeName, line)
}
}

View File

@ -10,9 +10,9 @@ import (
)
type testNode struct {
n Node
addr Address
pos Position
n Node
addr Address
pos Position
children []Node
}
@ -30,24 +30,24 @@ func formatMultiLine(o interface{}) string {
func runNodeTest(t *testing.T, actual Node, expected testNode, i *int) {
testName := fmt.Sprintf("Example%d", *i)
t.Run(testName + "a", func(t *testing.T) {
t.Run(testName+"a", func(t *testing.T) {
if !reflect.DeepEqual(expected.n, actual) {
t.Errorf("%s", util.ShowDiff(formatMultiLine(expected.n),
formatMultiLine(actual)))
}
})
t.Run(testName+"b", func(t *testing.T) {
if !reflect.DeepEqual(actual.Address(),expected.addr) {
if !reflect.DeepEqual(actual.Address(), expected.addr) {
t.Errorf("Address mismatch")
}
})
t.Run(testName+"c", func(t *testing.T) {
if !reflect.DeepEqual(actual.Position(),expected.pos) {
if !reflect.DeepEqual(actual.Position(), expected.pos) {
t.Errorf("Position mismatch")
}
})
t.Run(testName+"d", func(t *testing.T) {
if !reflect.DeepEqual(actual.Children(),expected.children) {
if !reflect.DeepEqual(actual.Children(), expected.children) {
t.Errorf("Children mismatch")
}
})
@ -55,8 +55,8 @@ func runNodeTest(t *testing.T, actual Node, expected testNode, i *int) {
cs := expected.children
node := &Unknown{}
actual.AddChild(node)
cs = append(cs,node)
if !reflect.DeepEqual(actual.Children(),cs) {
cs = append(cs, node)
if !reflect.DeepEqual(actual.Children(), cs) {
t.Errorf("Children mismatch")
}
})
@ -71,7 +71,7 @@ func runNodeTests(t *testing.T, tests map[string]testNode) {
name := reflect.TypeOf(expected.n).Elem().Name()
actual := Parse(name + " " + line)
runNodeTest(t,actual,expected,&i)
runNodeTest(t, actual, expected, &i)
}
}
@ -96,7 +96,7 @@ func TestPrint(t *testing.T) {
}
var lines = []string{
// c2go ast sqlite3.c | head -5000 | sed 's/^[ |`-]*//' | sed 's/<<<NULL>>>/NullStmt/g' | gawk 'length > 0 {print "`" $0 "`,"}'
// c2go ast sqlite3.c | head -5000 | sed 's/^[ |`-]*//' | sed 's/<<<NULL>>>/NullStmt/g' | gawk 'length > 0 {print "`" $0 "`,"}'
}
func BenchmarkParse(b *testing.B) {
@ -106,4 +106,3 @@ func BenchmarkParse(b *testing.B) {
}
}
}

View File

@ -21,7 +21,7 @@ func parseAttributedType(line string) Node {
return &AttributedType{
Addr: ParseAddress(groups["address"]),
Type: groups["type"],
Sugar: len(groups["sugar"])>0,
Sugar: len(groups["sugar"]) > 0,
ChildNodes: []Node{},
}
}

View File

@ -6,82 +6,75 @@ import (
func TestAttributedType(t *testing.T) {
nodes := map[string]testNode{
`0x10c0d6770 'CVDisplayLinkRef _Nonnull' sugar`:
testNode{&AttributedType{
`0x10c0d6770 'CVDisplayLinkRef _Nonnull' sugar`: testNode{&AttributedType{
Addr: 0x10c0d6770,
Type: `CVDisplayLinkRef _Nonnull`,
Sugar: true,
ChildNodes: []Node{},
},
0x10c0d6770,
NewPositionFromString(""),
[]Node{},
0x10c0d6770,
NewPositionFromString(""),
[]Node{},
},
`0x10c0d68b0 'const CVTimeStamp * _Nonnull' sugar`:
testNode{&AttributedType{
`0x10c0d68b0 'const CVTimeStamp * _Nonnull' sugar`: testNode{&AttributedType{
Addr: 0x10c0d68b0,
Type: `const CVTimeStamp * _Nonnull`,
Sugar: true,
ChildNodes: []Node{},
},
0x10c0d68b0,
NewPositionFromString(""),
[]Node{},
0x10c0d68b0,
NewPositionFromString(""),
[]Node{},
},
`0x10c0d6ab0 'CVOptionFlags * _Nonnull' sugar`:
testNode{&AttributedType{
`0x10c0d6ab0 'CVOptionFlags * _Nonnull' sugar`: testNode{&AttributedType{
Addr: 0x10c0d6ab0,
Type: `CVOptionFlags * _Nonnull`,
Sugar: true,
ChildNodes: []Node{},
},
0x10c0d6ab0,
NewPositionFromString(""),
[]Node{},
0x10c0d6ab0,
NewPositionFromString(""),
[]Node{},
},
`0x10c0fc7d0 'CVPixelBufferRef _Nonnull' sugar`:
testNode{&AttributedType{
`0x10c0fc7d0 'CVPixelBufferRef _Nonnull' sugar`: testNode{&AttributedType{
Addr: 0x10c0fc7d0,
Type: `CVPixelBufferRef _Nonnull`,
Sugar: true,
ChildNodes: []Node{},
},
0x10c0fc7d0,
NewPositionFromString(""),
[]Node{},
0x10c0fc7d0,
NewPositionFromString(""),
[]Node{},
},
`0x7faa1906d680 'NSError * _Nullable' sugar`:
testNode{&AttributedType{
`0x7faa1906d680 'NSError * _Nullable' sugar`: testNode{&AttributedType{
Addr: 0x7faa1906d680,
Type: `NSError * _Nullable`,
Sugar: true,
ChildNodes: []Node{},
},
0x7faa1906d680,
NewPositionFromString(""),
[]Node{},
0x7faa1906d680,
NewPositionFromString(""),
[]Node{},
},
`0x7faa19085760 'id<NSSecureCoding> _Nullable' sugar`:
testNode{&AttributedType{
`0x7faa19085760 'id<NSSecureCoding> _Nullable' sugar`: testNode{&AttributedType{
Addr: 0x7faa19085760,
Type: `id<NSSecureCoding> _Nullable`,
Sugar: true,
ChildNodes: []Node{},
},
0x7faa19085760,
NewPositionFromString(""),
[]Node{},
0x7faa19085760,
NewPositionFromString(""),
[]Node{},
},
`0x7faa19085840 'NSError * _Null_unspecified' sugar`:
testNode{&AttributedType{
`0x7faa19085840 'NSError * _Null_unspecified' sugar`: testNode{&AttributedType{
Addr: 0x7faa19085840,
Type: `NSError * _Null_unspecified`,
Sugar: true,
ChildNodes: []Node{},
},
0x7faa19085840,
NewPositionFromString(""),
[]Node{},
0x7faa19085840,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestAvailabilityAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc5ff8e5d18 </usr/include/AvailabilityInternal.h:21697:88, col:124> macos 10.10 0 0 "" ""`:
testNode{&AvailabilityAttr{
`0x7fc5ff8e5d18 </usr/include/AvailabilityInternal.h:21697:88, col:124> macos 10.10 0 0 "" ""`: testNode{&AvailabilityAttr{
Addr: 0x7fc5ff8e5d18,
Pos: NewPositionFromString("/usr/include/AvailabilityInternal.h:21697:88, col:124"),
OS: "macos",
@ -20,12 +19,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fc5ff8e5d18,
NewPositionFromString("/usr/include/AvailabilityInternal.h:21697:88, col:124"),
[]Node{},
0x7fc5ff8e5d18,
NewPositionFromString("/usr/include/AvailabilityInternal.h:21697:88, col:124"),
[]Node{},
},
`0x7fc5ff8e60d0 </usr/include/Availability.h:215:81, col:115> watchos 3.0 0 0 "" ""`:
testNode{&AvailabilityAttr{
`0x7fc5ff8e60d0 </usr/include/Availability.h:215:81, col:115> watchos 3.0 0 0 "" ""`: testNode{&AvailabilityAttr{
Addr: 0x7fc5ff8e60d0,
Pos: NewPositionFromString("/usr/include/Availability.h:215:81, col:115"),
OS: "watchos",
@ -38,12 +36,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fc5ff8e60d0,
NewPositionFromString("/usr/include/Availability.h:215:81, col:115"),
[]Node{},
0x7fc5ff8e60d0,
NewPositionFromString("/usr/include/Availability.h:215:81, col:115"),
[]Node{},
},
`0x7fc5ff8e6170 <col:81, col:115> tvos 10.0 0 0 "" ""`:
testNode{&AvailabilityAttr{
`0x7fc5ff8e6170 <col:81, col:115> tvos 10.0 0 0 "" ""`: testNode{&AvailabilityAttr{
Addr: 0x7fc5ff8e6170,
Pos: NewPositionFromString("col:81, col:115"),
OS: "tvos",
@ -56,12 +53,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fc5ff8e6170,
NewPositionFromString("col:81, col:115"),
[]Node{},
0x7fc5ff8e6170,
NewPositionFromString("col:81, col:115"),
[]Node{},
},
`0x7fc5ff8e61d8 <col:81, col:115> ios 10.0 0 0 "" ""`:
testNode{&AvailabilityAttr{
`0x7fc5ff8e61d8 <col:81, col:115> ios 10.0 0 0 "" ""`: testNode{&AvailabilityAttr{
Addr: 0x7fc5ff8e61d8,
Pos: NewPositionFromString("col:81, col:115"),
OS: "ios",
@ -74,12 +70,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fc5ff8e61d8,
NewPositionFromString("col:81, col:115"),
[]Node{},
0x7fc5ff8e61d8,
NewPositionFromString("col:81, col:115"),
[]Node{},
},
`0x7fc5ff8f0e18 </usr/include/sys/cdefs.h:275:50, col:99> swift 0 0 0 Unavailable "Use snprintf instead." ""`:
testNode{&AvailabilityAttr{
`0x7fc5ff8f0e18 </usr/include/sys/cdefs.h:275:50, col:99> swift 0 0 0 Unavailable "Use snprintf instead." ""`: testNode{&AvailabilityAttr{
Addr: 0x7fc5ff8f0e18,
Pos: NewPositionFromString("/usr/include/sys/cdefs.h:275:50, col:99"),
OS: "swift",
@ -92,12 +87,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fc5ff8f0e18,
NewPositionFromString("/usr/include/sys/cdefs.h:275:50, col:99"),
[]Node{},
0x7fc5ff8f0e18,
NewPositionFromString("/usr/include/sys/cdefs.h:275:50, col:99"),
[]Node{},
},
`0x7fc5ff8f1988 <line:275:50, col:99> swift 0 0 0 Unavailable "Use mkstemp(3) instead." ""`:
testNode{&AvailabilityAttr{
`0x7fc5ff8f1988 <line:275:50, col:99> swift 0 0 0 Unavailable "Use mkstemp(3) instead." ""`: testNode{&AvailabilityAttr{
Addr: 0x7fc5ff8f1988,
Pos: NewPositionFromString("line:275:50, col:99"),
OS: "swift",
@ -110,12 +104,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fc5ff8f1988,
NewPositionFromString("line:275:50, col:99"),
[]Node{},
0x7fc5ff8f1988,
NewPositionFromString("line:275:50, col:99"),
[]Node{},
},
`0x104035438 </usr/include/AvailabilityInternal.h:14571:88, col:124> macosx 10.10 0 0 ""`:
testNode{&AvailabilityAttr{
`0x104035438 </usr/include/AvailabilityInternal.h:14571:88, col:124> macosx 10.10 0 0 ""`: testNode{&AvailabilityAttr{
Addr: 0x104035438,
Pos: NewPositionFromString("/usr/include/AvailabilityInternal.h:14571:88, col:124"),
OS: "macosx",
@ -128,12 +121,11 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x104035438,
NewPositionFromString("/usr/include/AvailabilityInternal.h:14571:88, col:124"),
[]Node{},
0x104035438,
NewPositionFromString("/usr/include/AvailabilityInternal.h:14571:88, col:124"),
[]Node{},
},
`0x7f9bd588b1a8 </usr/include/gethostuuid.h:39:65, col:100> Inherited macos 10.5 0 0 "" ""`:
testNode{&AvailabilityAttr{
`0x7f9bd588b1a8 </usr/include/gethostuuid.h:39:65, col:100> Inherited macos 10.5 0 0 "" ""`: testNode{&AvailabilityAttr{
Addr: 0x7f9bd588b1a8,
Pos: NewPositionFromString("/usr/include/gethostuuid.h:39:65, col:100"),
OS: "macos",
@ -146,9 +138,9 @@ func TestAvailabilityAttr(t *testing.T) {
IsInherited: true,
ChildNodes: []Node{},
},
0x7f9bd588b1a8,
NewPositionFromString("/usr/include/gethostuuid.h:39:65, col:100"),
[]Node{},
0x7f9bd588b1a8,
NewPositionFromString("/usr/include/gethostuuid.h:39:65, col:100"),
[]Node{},
},
}

View File

@ -20,9 +20,9 @@ func parseBinaryOperator(line string) Node {
}
return &BinaryOperator{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: groups["type1"],
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: groups["type1"],
//Type2: groups["type2"],
Operator: groups["operator"],
ChildNodes: []Node{},

View File

@ -6,20 +6,18 @@ import (
func TestBinaryOperator(t *testing.T) {
nodes := map[string]testNode{
`0x7fca2d8070e0 <col:11, col:23> 'unsigned char' '='`:
testNode{&BinaryOperator{
`0x7fca2d8070e0 <col:11, col:23> 'unsigned char' '='`: testNode{&BinaryOperator{
Addr: 0x7fca2d8070e0,
Pos: NewPositionFromString("col:11, col:23"),
Type: "unsigned char",
Operator: "=",
ChildNodes: []Node{},
},
0x7fca2d8070e0,
NewPositionFromString("col:11, col:23"),
[]Node{},
0x7fca2d8070e0,
NewPositionFromString("col:11, col:23"),
[]Node{},
},
`0x1ff95b8 <line:78:2, col:7> 'T_ENUM':'T_ENUM' '='`:
testNode{&BinaryOperator{
`0x1ff95b8 <line:78:2, col:7> 'T_ENUM':'T_ENUM' '='`: testNode{&BinaryOperator{
Addr: 0x1ff95b8,
Pos: NewPositionFromString("line:78:2, col:7"),
Type: "T_ENUM",
@ -27,9 +25,9 @@ func TestBinaryOperator(t *testing.T) {
Operator: "=",
ChildNodes: []Node{},
},
0x1ff95b8,
NewPositionFromString("line:78:2, col:7"),
[]Node{},
0x1ff95b8,
NewPositionFromString("line:78:2, col:7"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestBlockCommandComment(t *testing.T) {
nodes := map[string]testNode{
`0x1069fae60 <col:4, line:163:57> Name="abstract"`:
testNode{&BlockCommandComment{
`0x1069fae60 <col:4, line:163:57> Name="abstract"`: testNode{&BlockCommandComment{
Addr: 0x1069fae60,
Pos: NewPositionFromString("col:4, line:163:57"),
Name: "abstract",
ChildNodes: []Node{},
},
0x1069fae60,
NewPositionFromString("col:4, line:163:57"),
[]Node{},
0x1069fae60,
NewPositionFromString("col:4, line:163:57"),
[]Node{},
},
}

View File

@ -6,25 +6,23 @@ import (
func TestBlockPointerType(t *testing.T) {
nodes := map[string]testNode{
`0x7fa3b88bbb30 'void (^)(void)'`:
testNode{&BlockPointerType{
`0x7fa3b88bbb30 'void (^)(void)'`: testNode{&BlockPointerType{
Addr: 0x7fa3b88bbb30,
Type: `void (^)(void)`,
ChildNodes: []Node{},
},
0x7fa3b88bbb30,
NewPositionFromString(""),
[]Node{},
0x7fa3b88bbb30,
NewPositionFromString(""),
[]Node{},
},
`0x7fa3b88bbb30 'NSComparisonResult (^)(id _Nonnull, id _Nonnull)'`:
testNode{&BlockPointerType{
`0x7fa3b88bbb30 'NSComparisonResult (^)(id _Nonnull, id _Nonnull)'`: testNode{&BlockPointerType{
Addr: 0x7fa3b88bbb30,
Type: `NSComparisonResult (^)(id _Nonnull, id _Nonnull)`,
ChildNodes: []Node{},
},
0x7fa3b88bbb30,
NewPositionFromString(""),
[]Node{},
0x7fa3b88bbb30,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestBreakStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fca2d8070e0 <col:11, col:23>`:
testNode{&BreakStmt{
`0x7fca2d8070e0 <col:11, col:23>`: testNode{&BreakStmt{
Addr: 0x7fca2d8070e0,
Pos: NewPositionFromString("col:11, col:23"),
ChildNodes: []Node{},
},
0x7fca2d8070e0,
NewPositionFromString("col:11, col:23"),
[]Node{},
0x7fca2d8070e0,
NewPositionFromString("col:11, col:23"),
[]Node{},
},
}

View File

@ -6,25 +6,23 @@ import (
func TestBuiltinType(t *testing.T) {
nodes := map[string]testNode{
`0x7f8a43023f40 '__int128'`:
testNode{&BuiltinType{
`0x7f8a43023f40 '__int128'`: testNode{&BuiltinType{
Addr: 0x7f8a43023f40,
Type: "__int128",
ChildNodes: []Node{},
},
0x7f8a43023f40,
NewPositionFromString(""),
[]Node{},
0x7f8a43023f40,
NewPositionFromString(""),
[]Node{},
},
`0x7f8a43023ea0 'unsigned long long'`:
testNode{&BuiltinType{
`0x7f8a43023ea0 'unsigned long long'`: testNode{&BuiltinType{
Addr: 0x7f8a43023ea0,
Type: "unsigned long long",
ChildNodes: []Node{},
},
0x7f8a43023ea0,
NewPositionFromString(""),
[]Node{},
0x7f8a43023ea0,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -26,9 +26,9 @@ func parseCStyleCastExpr(line string) Node {
}
return &CStyleCastExpr{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: groups["type1"],
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: groups["type1"],
//Type2: groups["type2"],
Kind: groups["kind"],
ChildNodes: []Node{},

View File

@ -6,20 +6,18 @@ import (
func TestCStyleCastExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7fddc18fb2e0 <col:50, col:56> 'char' <IntegralCast>`:
testNode{&CStyleCastExpr{
`0x7fddc18fb2e0 <col:50, col:56> 'char' <IntegralCast>`: testNode{&CStyleCastExpr{
Addr: 0x7fddc18fb2e0,
Pos: NewPositionFromString("col:50, col:56"),
Type: "char",
Kind: "IntegralCast",
ChildNodes: []Node{},
},
0x7fddc18fb2e0,
NewPositionFromString("col:50, col:56"),
[]Node{},
0x7fddc18fb2e0,
NewPositionFromString("col:50, col:56"),
[]Node{},
},
`0x2781518 <col:7, col:17> 'T_ENUM':'T_ENUM' <IntegralCast>`:
testNode{&CStyleCastExpr{
`0x2781518 <col:7, col:17> 'T_ENUM':'T_ENUM' <IntegralCast>`: testNode{&CStyleCastExpr{
Addr: 0x2781518,
Pos: NewPositionFromString("col:7, col:17"),
Type: "T_ENUM",
@ -27,9 +25,9 @@ func TestCStyleCastExpr(t *testing.T) {
Kind: "IntegralCast",
ChildNodes: []Node{},
},
0x2781518,
NewPositionFromString("col:7, col:17"),
[]Node{},
0x2781518,
NewPositionFromString("col:7, col:17"),
[]Node{},
},
}

View File

@ -6,27 +6,25 @@ import (
func TestCallExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7f9bf3033240 <col:11, col:25> 'int'`:
testNode{&CallExpr{
`0x7f9bf3033240 <col:11, col:25> 'int'`: testNode{&CallExpr{
Addr: 0x7f9bf3033240,
Pos: NewPositionFromString("col:11, col:25"),
Type: "int",
ChildNodes: []Node{},
},
0x7f9bf3033240,
NewPositionFromString("col:11, col:25"),
[]Node{},
0x7f9bf3033240,
NewPositionFromString("col:11, col:25"),
[]Node{},
},
`0x7f9bf3035c20 <line:7:4, col:64> 'int'`:
testNode{&CallExpr{
`0x7f9bf3035c20 <line:7:4, col:64> 'int'`: testNode{&CallExpr{
Addr: 0x7f9bf3035c20,
Pos: NewPositionFromString("line:7:4, col:64"),
Type: "int",
ChildNodes: []Node{},
},
0x7f9bf3035c20,
NewPositionFromString("line:7:4, col:64"),
[]Node{},
0x7f9bf3035c20,
NewPositionFromString("line:7:4, col:64"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestCaseStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fc8b5094688 <line:11:5, line:12:21>`:
testNode{&CaseStmt{
`0x7fc8b5094688 <line:11:5, line:12:21>`: testNode{&CaseStmt{
Addr: 0x7fc8b5094688,
Pos: NewPositionFromString("line:11:5, line:12:21"),
ChildNodes: []Node{},
},
0x7fc8b5094688,
NewPositionFromString("line:11:5, line:12:21"),
[]Node{},
0x7fc8b5094688,
NewPositionFromString("line:11:5, line:12:21"),
[]Node{},
},
}

View File

@ -13,9 +13,9 @@ func parseCFAuditedTransferAttr(line string) Node {
"<(?P<position>.*)>(?P<content>.*)",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &CFAuditedTransferAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,16 +6,15 @@ import (
func TestCFAuditedTransferAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`:
testNode{&CFAuditedTransferAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`: testNode{&CFAuditedTransferAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
Content: " content",
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -13,9 +13,9 @@ func parseCFConsumedAttr(line string) Node {
"<(?P<position>.*)>(?P<content>.*)",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &CFConsumedAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,16 +6,15 @@ import (
func TestCFConsumedAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`:
testNode{&CFConsumedAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`: testNode{&CFConsumedAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
Content: " content",
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseCFReturnsNotRetainedAttr(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &CFReturnsNotRetainedAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestCFReturnsNotRetainedAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7>`:
testNode{&CFReturnsNotRetainedAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7>`: testNode{&CFReturnsNotRetainedAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseCFReturnsRetainedAttr(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &CFReturnsRetainedAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestCFReturnsRetainedAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7>`:
testNode{&CFReturnsRetainedAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7>`: testNode{&CFReturnsRetainedAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -6,17 +6,16 @@ import (
func TestCharacterLiteral(t *testing.T) {
nodes := map[string]testNode{
`0x7f980b858308 <col:62> 'int' 10`:
testNode{&CharacterLiteral{
`0x7f980b858308 <col:62> 'int' 10`: testNode{&CharacterLiteral{
Addr: 0x7f980b858308,
Pos: NewPositionFromString("col:62"),
Type: "int",
Value: 10,
ChildNodes: []Node{},
},
0x7f980b858308,
NewPositionFromString("col:62"),
[]Node{},
0x7f980b858308,
NewPositionFromString("col:62"),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestCompoundAssignOperator(t *testing.T) {
nodes := map[string]testNode{
`0x2dc5758 <line:5:2, col:7> 'int' '+=' ComputeLHSTy='int' ComputeResultTy='int'`:
testNode{&CompoundAssignOperator{
`0x2dc5758 <line:5:2, col:7> 'int' '+=' ComputeLHSTy='int' ComputeResultTy='int'`: testNode{&CompoundAssignOperator{
Addr: 0x2dc5758,
Pos: NewPositionFromString("line:5:2, col:7"),
Type: "int",
@ -16,9 +15,9 @@ func TestCompoundAssignOperator(t *testing.T) {
ComputationResultType: "int",
ChildNodes: []Node{},
},
0x2dc5758,
NewPositionFromString("line:5:2, col:7"),
[]Node{},
0x2dc5758,
NewPositionFromString("line:5:2, col:7"),
[]Node{},
},
}

View File

@ -6,17 +6,16 @@ import (
func TestCompoundLiteralExpr(t *testing.T) {
nodes := map[string]testNode{
`0x5575acce81f0 <col:21, col:40> 'struct node':'struct node' lvalue`:
testNode{&CompoundLiteralExpr{
`0x5575acce81f0 <col:21, col:40> 'struct node':'struct node' lvalue`: testNode{&CompoundLiteralExpr{
Addr: 0x5575acce81f0,
Pos: NewPositionFromString("col:21, col:40"),
Type1: "struct node",
Type2: "struct node",
ChildNodes: []Node{},
},
0x5575acce81f0,
NewPositionFromString("col:21, col:40"),
[]Node{},
0x5575acce81f0,
NewPositionFromString("col:21, col:40"),
[]Node{},
},
}

View File

@ -6,25 +6,23 @@ import (
func TestCompoundStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fbd0f014f18 <col:54, line:358:1>`:
testNode{&CompoundStmt{
`0x7fbd0f014f18 <col:54, line:358:1>`: testNode{&CompoundStmt{
Addr: 0x7fbd0f014f18,
Pos: NewPositionFromString("col:54, line:358:1"),
ChildNodes: []Node{},
},
0x7fbd0f014f18,
NewPositionFromString("col:54, line:358:1"),
[]Node{},
0x7fbd0f014f18,
NewPositionFromString("col:54, line:358:1"),
[]Node{},
},
`0x7fbd0f8360b8 <line:4:1, line:13:1>`:
testNode{&CompoundStmt{
`0x7fbd0f8360b8 <line:4:1, line:13:1>`: testNode{&CompoundStmt{
Addr: 0x7fbd0f8360b8,
Pos: NewPositionFromString("line:4:1, line:13:1"),
ChildNodes: []Node{},
},
0x7fbd0f8360b8,
NewPositionFromString("line:4:1, line:13:1"),
[]Node{},
0x7fbd0f8360b8,
NewPositionFromString("line:4:1, line:13:1"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestConditionalOperator(t *testing.T) {
nodes := map[string]testNode{
`0x7fc6ae0bc678 <col:6, col:89> 'void'`:
testNode{&ConditionalOperator{
`0x7fc6ae0bc678 <col:6, col:89> 'void'`: testNode{&ConditionalOperator{
Addr: 0x7fc6ae0bc678,
Pos: NewPositionFromString("col:6, col:89"),
Type: "void",
ChildNodes: []Node{},
},
0x7fc6ae0bc678,
NewPositionFromString("col:6, col:89"),
[]Node{},
0x7fc6ae0bc678,
NewPositionFromString("col:6, col:89"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestConstAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fa3b88bbb38 <line:4:1, line:13:1>foo`:
testNode{&ConstAttr{
`0x7fa3b88bbb38 <line:4:1, line:13:1>foo`: testNode{&ConstAttr{
Addr: 0x7fa3b88bbb38,
Pos: NewPositionFromString("line:4:1, line:13:1"),
Tags: "foo",
ChildNodes: []Node{},
},
0x7fa3b88bbb38,
NewPositionFromString("line:4:1, line:13:1"),
[]Node{},
0x7fa3b88bbb38,
NewPositionFromString("line:4:1, line:13:1"),
[]Node{},
},
}

View File

@ -6,27 +6,25 @@ import (
func TestConstantArrayType(t *testing.T) {
nodes := map[string]testNode{
`0x7f94ad016a40 'struct __va_list_tag [1]' 1 `:
testNode{&ConstantArrayType{
`0x7f94ad016a40 'struct __va_list_tag [1]' 1 `: testNode{&ConstantArrayType{
Addr: 0x7f94ad016a40,
Type: "struct __va_list_tag [1]",
Size: 1,
ChildNodes: []Node{},
},
0x7f94ad016a40,
NewPositionFromString(""),
[]Node{},
0x7f94ad016a40,
NewPositionFromString(""),
[]Node{},
},
`0x7f8c5f059d20 'char [37]' 37 `:
testNode{&ConstantArrayType{
`0x7f8c5f059d20 'char [37]' 37 `: testNode{&ConstantArrayType{
Addr: 0x7f8c5f059d20,
Type: "char [37]",
Size: 37,
ChildNodes: []Node{},
},
0x7f8c5f059d20,
NewPositionFromString(""),
[]Node{},
0x7f8c5f059d20,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestContinueStmt(t *testing.T) {
nodes := map[string]testNode{
`0x1e044e0 <col:20>`:
testNode{&ContinueStmt{
`0x1e044e0 <col:20>`: testNode{&ContinueStmt{
Addr: 0x1e044e0,
Pos: NewPositionFromString("col:20"),
ChildNodes: []Node{},
},
0x1e044e0,
NewPositionFromString("col:20"),
[]Node{},
0x1e044e0,
NewPositionFromString("col:20"),
[]Node{},
},
}

View File

@ -2,11 +2,11 @@ package ast
// ConvertVectorExpr
type ConvertVectorExpr struct {
Addr Address
Pos Position
Type string
Type2 string
ChildNodes []Node
Addr Address
Pos Position
Type string
Type2 string
ChildNodes []Node
}
func parseConvertVectorExpr(line string) Node {
@ -16,16 +16,16 @@ func parseConvertVectorExpr(line string) Node {
(?P<type2>:'.*?')?`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &ConvertVectorExpr{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: removeQuotes(groups["type"]),
Type2: groups["type2"],
ChildNodes: []Node{},
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Type: removeQuotes(groups["type"]),
Type2: groups["type2"],
ChildNodes: []Node{},
}
}

View File

@ -6,29 +6,27 @@ import (
func TestConvertVectorExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7fdef0862430 <line:120:1, col:16>`:
testNode{&ConvertVectorExpr{
Addr: 0x7fdef0862430,
Pos: NewPositionFromString("line:120:1, col:16"),
Type: "",
Type2: "",
ChildNodes: []Node{},
`0x7fdef0862430 <line:120:1, col:16>`: testNode{&ConvertVectorExpr{
Addr: 0x7fdef0862430,
Pos: NewPositionFromString("line:120:1, col:16"),
Type: "",
Type2: "",
ChildNodes: []Node{},
},
0x7fdef0862430,
NewPositionFromString("line:120:1, col:16"),
[]Node{},
0x7fdef0862430,
NewPositionFromString("line:120:1, col:16"),
[]Node{},
},
`0x113368318 <line:1354:20, line:1355:70> '__v2df':'__attribute__((__vector_size__(2 * sizeof(double)))) double'`:
testNode{&ConvertVectorExpr{
Addr: 0x113368318,
Pos: NewPositionFromString("line:1354:20, line:1355:70"),
Type: `__v2df`,
Type2: `:'__attribute__((__vector_size__(2 * sizeof(double)))) double'`,
ChildNodes: []Node{},
`0x113368318 <line:1354:20, line:1355:70> '__v2df':'__attribute__((__vector_size__(2 * sizeof(double)))) double'`: testNode{&ConvertVectorExpr{
Addr: 0x113368318,
Pos: NewPositionFromString("line:1354:20, line:1355:70"),
Type: `__v2df`,
Type2: `:'__attribute__((__vector_size__(2 * sizeof(double)))) double'`,
ChildNodes: []Node{},
},
0x113368318,
NewPositionFromString("line:1354:20, line:1355:70"),
[]Node{},
0x113368318,
NewPositionFromString("line:1354:20, line:1355:70"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestDecayedType(t *testing.T) {
nodes := map[string]testNode{
`0x7f1234567890 'struct __va_list_tag *' sugar`:
testNode{&DecayedType{
`0x7f1234567890 'struct __va_list_tag *' sugar`: testNode{&DecayedType{
Addr: 0x7f1234567890,
Type: "struct __va_list_tag *",
ChildNodes: []Node{},
},
0x7f1234567890,
NewPositionFromString(""),
[]Node{},
0x7f1234567890,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestDeclRefExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc972064460 <col:8> 'FILE *' lvalue ParmVar 0x7fc9720642d0 '_p' 'FILE *'`:
testNode{&DeclRefExpr{
`0x7fc972064460 <col:8> 'FILE *' lvalue ParmVar 0x7fc9720642d0 '_p' 'FILE *'`: testNode{&DeclRefExpr{
Addr: 0x7fc972064460,
Pos: NewPositionFromString("col:8"),
Type: "FILE *",
@ -20,12 +19,11 @@ func TestDeclRefExpr(t *testing.T) {
Type3: "",
ChildNodes: []Node{},
},
0x7fc972064460,
NewPositionFromString("col:8"),
[]Node{},
0x7fc972064460,
NewPositionFromString("col:8"),
[]Node{},
},
`0x7fc97206a958 <col:11> 'int (int, FILE *)' Function 0x7fc972064198 '__swbuf' 'int (int, FILE *)'`:
testNode{&DeclRefExpr{
`0x7fc97206a958 <col:11> 'int (int, FILE *)' Function 0x7fc972064198 '__swbuf' 'int (int, FILE *)'`: testNode{&DeclRefExpr{
Addr: 0x7fc97206a958,
Pos: NewPositionFromString("col:11"),
Type: "int (int, FILE *)",
@ -38,12 +36,11 @@ func TestDeclRefExpr(t *testing.T) {
Type3: "",
ChildNodes: []Node{},
},
0x7fc97206a958,
NewPositionFromString("col:11"),
[]Node{},
0x7fc97206a958,
NewPositionFromString("col:11"),
[]Node{},
},
`0x7fa36680f170 <col:19> 'struct programming':'struct programming' lvalue Var 0x7fa36680dc20 'variable' 'struct programming':'struct programming'`:
testNode{&DeclRefExpr{
`0x7fa36680f170 <col:19> 'struct programming':'struct programming' lvalue Var 0x7fa36680dc20 'variable' 'struct programming':'struct programming'`: testNode{&DeclRefExpr{
Addr: 0x7fa36680f170,
Pos: NewPositionFromString("col:19"),
Type: "struct programming",
@ -56,12 +53,11 @@ func TestDeclRefExpr(t *testing.T) {
Type3: "struct programming",
ChildNodes: []Node{},
},
0x7fa36680f170,
NewPositionFromString("col:19"),
[]Node{},
0x7fa36680f170,
NewPositionFromString("col:19"),
[]Node{},
},
`0x35cb438 <col:13> 'int' EnumConstant 0x35ca300 'Jan' 'int'`:
testNode{&DeclRefExpr{
`0x35cb438 <col:13> 'int' EnumConstant 0x35ca300 'Jan' 'int'`: testNode{&DeclRefExpr{
Addr: 0x35cb438,
Pos: NewPositionFromString("col:13"),
Type: "int",
@ -74,12 +70,11 @@ func TestDeclRefExpr(t *testing.T) {
Type3: "",
ChildNodes: []Node{},
},
0x35cb438,
NewPositionFromString("col:13"),
[]Node{},
0x35cb438,
NewPositionFromString("col:13"),
[]Node{},
},
`0x1ff8770 <col:33> 'T_ENUM':'T_ENUM' lvalue Var 0x1ff8600 'cc' 'T_ENUM':'T_ENUM'`:
testNode{&DeclRefExpr{
`0x1ff8770 <col:33> 'T_ENUM':'T_ENUM' lvalue Var 0x1ff8600 'cc' 'T_ENUM':'T_ENUM'`: testNode{&DeclRefExpr{
Addr: 0x1ff8770,
Pos: NewPositionFromString("col:33"),
Type: "T_ENUM",
@ -92,9 +87,9 @@ func TestDeclRefExpr(t *testing.T) {
Type3: "T_ENUM",
ChildNodes: []Node{},
},
0x1ff8770,
NewPositionFromString("col:33"),
[]Node{},
0x1ff8770,
NewPositionFromString("col:33"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestDeclStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fb791846e80 <line:11:4, col:31>`:
testNode{&DeclStmt{
`0x7fb791846e80 <line:11:4, col:31>`: testNode{&DeclStmt{
Addr: 0x7fb791846e80,
Pos: NewPositionFromString("line:11:4, col:31"),
ChildNodes: []Node{},
},
0x7fb791846e80,
NewPositionFromString("line:11:4, col:31"),
[]Node{},
0x7fb791846e80,
NewPositionFromString("line:11:4, col:31"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestDefaultStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7f951308bfb0 <line:17:5, line:18:34>`:
testNode{&DefaultStmt{
`0x7f951308bfb0 <line:17:5, line:18:34>`: testNode{&DefaultStmt{
Addr: 0x7f951308bfb0,
Pos: NewPositionFromString("line:17:5, line:18:34"),
ChildNodes: []Node{},
},
0x7f951308bfb0,
NewPositionFromString("line:17:5, line:18:34"),
[]Node{},
0x7f951308bfb0,
NewPositionFromString("line:17:5, line:18:34"),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestDeprecatedAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fec4b0ab9c0 <line:180:48, col:63> "This function is provided for compatibility reasons only. Due to security concerns inherent in the design of tempnam(3), it is highly recommended that you use mkstemp(3) instead." ""`:
testNode{&DeprecatedAttr{
`0x7fec4b0ab9c0 <line:180:48, col:63> "This function is provided for compatibility reasons only. Due to security concerns inherent in the design of tempnam(3), it is highly recommended that you use mkstemp(3) instead." ""`: testNode{&DeprecatedAttr{
Addr: 0x7fec4b0ab9c0,
Pos: NewPositionFromString("line:180:48, col:63"),
Message1: "This function is provided for compatibility reasons only. Due to security concerns inherent in the design of tempnam(3), it is highly recommended that you use mkstemp(3) instead.",
@ -15,12 +14,11 @@ func TestDeprecatedAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0x7fec4b0ab9c0,
NewPositionFromString("line:180:48, col:63"),
[]Node{},
0x7fec4b0ab9c0,
NewPositionFromString("line:180:48, col:63"),
[]Node{},
},
`0xb75d00 <line:1107:12> "This function or variable may be unsafe. Consider using _snwprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details." ""`:
testNode{&DeprecatedAttr{
`0xb75d00 <line:1107:12> "This function or variable may be unsafe. Consider using _snwprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details." ""`: testNode{&DeprecatedAttr{
Addr: 0xb75d00,
Pos: NewPositionFromString("line:1107:12"),
Message1: "This function or variable may be unsafe. Consider using _snwprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.",
@ -28,12 +26,11 @@ func TestDeprecatedAttr(t *testing.T) {
IsInherited: false,
ChildNodes: []Node{},
},
0xb75d00,
NewPositionFromString("line:1107:12"),
[]Node{},
0xb75d00,
NewPositionFromString("line:1107:12"),
[]Node{},
},
`0xb75d00 <line:1107:12> Inherited "This function or variable may be unsafe. Consider using _snwprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details." ""`:
testNode{&DeprecatedAttr{
`0xb75d00 <line:1107:12> Inherited "This function or variable may be unsafe. Consider using _snwprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details." ""`: testNode{&DeprecatedAttr{
Addr: 0xb75d00,
Pos: NewPositionFromString("line:1107:12"),
Message1: "This function or variable may be unsafe. Consider using _snwprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.",
@ -41,9 +38,9 @@ func TestDeprecatedAttr(t *testing.T) {
IsInherited: true,
ChildNodes: []Node{},
},
0xb75d00,
NewPositionFromString("line:1107:12"),
[]Node{},
0xb75d00,
NewPositionFromString("line:1107:12"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestDisableTailCallsAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc8fa094558 <col:107> `:
testNode{&DisableTailCallsAttr{
`0x7fc8fa094558 <col:107> `: testNode{&DisableTailCallsAttr{
Addr: 0x7fc8fa094558,
Pos: NewPositionFromString("col:107"),
ChildNodes: []Node{},
},
0x7fc8fa094558,
NewPositionFromString("col:107"),
[]Node{},
0x7fc8fa094558,
NewPositionFromString("col:107"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestDoStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7ff36d0a0938 <line:11:5, line:14:23>`:
testNode{&DoStmt{
`0x7ff36d0a0938 <line:11:5, line:14:23>`: testNode{&DoStmt{
Addr: 0x7ff36d0a0938,
Pos: NewPositionFromString("line:11:5, line:14:23"),
ChildNodes: []Node{},
},
0x7ff36d0a0938,
NewPositionFromString("line:11:5, line:14:23"),
[]Node{},
0x7ff36d0a0938,
NewPositionFromString("line:11:5, line:14:23"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestElaboratedType(t *testing.T) {
nodes := map[string]testNode{
`0x7f873686c120 'union __mbstate_t' sugar`:
testNode{&ElaboratedType{
`0x7f873686c120 'union __mbstate_t' sugar`: testNode{&ElaboratedType{
Addr: 0x7f873686c120,
Type: "union __mbstate_t",
Tags: "sugar",
ChildNodes: []Node{},
},
0x7f873686c120,
NewPositionFromString(""),
[]Node{},
0x7f873686c120,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestEmptyDecl(t *testing.T) {
nodes := map[string]testNode{
`0x480bec8 <col:13> col:13`:
testNode{&EmptyDecl{
`0x480bec8 <col:13> col:13`: testNode{&EmptyDecl{
Addr: 0x480bec8,
Pos: NewPositionFromString("col:13"),
Position2: NewPositionFromString("col:13"),
ChildNodes: []Node{},
},
0x480bec8,
NewPositionFromString("col:13"),
[]Node{},
0x480bec8,
NewPositionFromString("col:13"),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestEnumConstantDecl(t *testing.T) {
nodes := map[string]testNode{
`0x1660db0 <line:185:3> __codecvt_noconv 'int'`:
testNode{&EnumConstantDecl{
`0x1660db0 <line:185:3> __codecvt_noconv 'int'`: testNode{&EnumConstantDecl{
Addr: 0x1660db0,
Pos: NewPositionFromString("line:185:3"),
Position2: "",
@ -16,12 +15,11 @@ func TestEnumConstantDecl(t *testing.T) {
Type: "int",
ChildNodes: []Node{},
},
0x1660db0,
NewPositionFromString("line:185:3"),
[]Node{},
0x1660db0,
NewPositionFromString("line:185:3"),
[]Node{},
},
`0x3c77ba8 <line:59:3, col:65> col:3 referenced _ISalnum 'int'`:
testNode{&EnumConstantDecl{
`0x3c77ba8 <line:59:3, col:65> col:3 referenced _ISalnum 'int'`: testNode{&EnumConstantDecl{
Addr: 0x3c77ba8,
Pos: NewPositionFromString("line:59:3, col:65"),
Position2: "col:3",
@ -30,9 +28,9 @@ func TestEnumConstantDecl(t *testing.T) {
Type: "int",
ChildNodes: []Node{},
},
0x3c77ba8,
NewPositionFromString("line:59:3, col:65"),
[]Node{},
0x3c77ba8,
NewPositionFromString("line:59:3, col:65"),
[]Node{},
},
}

View File

@ -35,11 +35,11 @@ func parseEnumDecl(line string) Node {
}*/
return &EnumDecl{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Position2: groups["position2"],
Name: strings.TrimSpace(groups["name"]),
Type: removeQuotes(groups["type"]),
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Position2: groups["position2"],
Name: strings.TrimSpace(groups["name"]),
Type: removeQuotes(groups["type"]),
//Type2: type2,
ChildNodes: []Node{},
}

View File

@ -6,29 +6,27 @@ import (
func TestEnumDecl(t *testing.T) {
nodes := map[string]testNode{
`0x22a6c80 <line:180:1, line:186:1> __codecvt_result`:
testNode{&EnumDecl{
`0x22a6c80 <line:180:1, line:186:1> __codecvt_result`: testNode{&EnumDecl{
Addr: 0x22a6c80,
Pos: NewPositionFromString("line:180:1, line:186:1"),
Position2: "",
Name: "__codecvt_result",
ChildNodes: []Node{},
},
0x22a6c80,
NewPositionFromString("line:180:1, line:186:1"),
[]Node{},
0x22a6c80,
NewPositionFromString("line:180:1, line:186:1"),
[]Node{},
},
`0x32fb5a0 <enum.c:3:1, col:45> col:6 week`:
testNode{&EnumDecl{
`0x32fb5a0 <enum.c:3:1, col:45> col:6 week`: testNode{&EnumDecl{
Addr: 0x32fb5a0,
Pos: NewPositionFromString("enum.c:3:1, col:45"),
Position2: " col:6",
Name: "week",
ChildNodes: []Node{},
},
0x32fb5a0,
NewPositionFromString("enum.c:3:1, col:45"),
[]Node{},
0x32fb5a0,
NewPositionFromString("enum.c:3:1, col:45"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestEnumExtensibilityAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`:
testNode{&EnumExtensibilityAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`: testNode{&EnumExtensibilityAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
Content: " content",
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestEnum(t *testing.T) {
nodes := map[string]testNode{
`0x7f980b858308 'foo'`:
testNode{&Enum{
`0x7f980b858308 'foo'`: testNode{&Enum{
Addr: 0x7f980b858308,
Name: "foo",
ChildNodes: []Node{},
},
0x7f980b858308,
NewPositionFromString(""),
[]Node{},
0x7f980b858308,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestEnumType(t *testing.T) {
nodes := map[string]testNode{
`0x7f980b858309 'foo'`:
testNode{&EnumType{
`0x7f980b858309 'foo'`: testNode{&EnumType{
Addr: 0x7f980b858309,
Name: "foo",
ChildNodes: []Node{},
},
0x7f980b858309,
NewPositionFromString(""),
[]Node{},
0x7f980b858309,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestFieldDecl(t *testing.T) {
nodes := map[string]testNode{
`0x7fef510c4848 <line:141:2, col:6> col:6 _ur 'int'`:
testNode{&FieldDecl{
`0x7fef510c4848 <line:141:2, col:6> col:6 _ur 'int'`: testNode{&FieldDecl{
Addr: 0x7fef510c4848,
Pos: NewPositionFromString("line:141:2, col:6"),
Position2: "col:6",
@ -18,12 +17,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x7fef510c4848,
NewPositionFromString("line:141:2, col:6"),
[]Node{},
0x7fef510c4848,
NewPositionFromString("line:141:2, col:6"),
[]Node{},
},
`0x7fef510c46f8 <line:139:2, col:16> col:16 _ub 'struct __sbuf':'struct __sbuf'`:
testNode{&FieldDecl{
`0x7fef510c46f8 <line:139:2, col:16> col:16 _ub 'struct __sbuf':'struct __sbuf'`: testNode{&FieldDecl{
Addr: 0x7fef510c46f8,
Pos: NewPositionFromString("line:139:2, col:16"),
Position2: "col:16",
@ -34,12 +32,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x7fef510c46f8,
NewPositionFromString("line:139:2, col:16"),
[]Node{},
0x7fef510c46f8,
NewPositionFromString("line:139:2, col:16"),
[]Node{},
},
`0x7fef510c3fe0 <line:134:2, col:19> col:19 _read 'int (* _Nullable)(void *, char *, int)':'int (*)(void *, char *, int)'`:
testNode{&FieldDecl{
`0x7fef510c3fe0 <line:134:2, col:19> col:19 _read 'int (* _Nullable)(void *, char *, int)':'int (*)(void *, char *, int)'`: testNode{&FieldDecl{
Addr: 0x7fef510c3fe0,
Pos: NewPositionFromString("line:134:2, col:19"),
Position2: "col:19",
@ -50,12 +47,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x7fef510c3fe0,
NewPositionFromString("line:134:2, col:19"),
[]Node{},
0x7fef510c3fe0,
NewPositionFromString("line:134:2, col:19"),
[]Node{},
},
`0x7fef51073a60 <line:105:2, col:40> col:40 __cleanup_stack 'struct __darwin_pthread_handler_rec *'`:
testNode{&FieldDecl{
`0x7fef51073a60 <line:105:2, col:40> col:40 __cleanup_stack 'struct __darwin_pthread_handler_rec *'`: testNode{&FieldDecl{
Addr: 0x7fef51073a60,
Pos: NewPositionFromString("line:105:2, col:40"),
Position2: "col:40",
@ -66,12 +62,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x7fef51073a60,
NewPositionFromString("line:105:2, col:40"),
[]Node{},
0x7fef51073a60,
NewPositionFromString("line:105:2, col:40"),
[]Node{},
},
`0x7fef510738e8 <line:100:2, col:43> col:7 __opaque 'char [16]'`:
testNode{&FieldDecl{
`0x7fef510738e8 <line:100:2, col:43> col:7 __opaque 'char [16]'`: testNode{&FieldDecl{
Addr: 0x7fef510738e8,
Pos: NewPositionFromString("line:100:2, col:43"),
Position2: "col:7",
@ -82,12 +77,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x7fef510738e8,
NewPositionFromString("line:100:2, col:43"),
[]Node{},
0x7fef510738e8,
NewPositionFromString("line:100:2, col:43"),
[]Node{},
},
`0x7fe9f5072268 <line:129:2, col:6> col:6 referenced _lbfsize 'int'`:
testNode{&FieldDecl{
`0x7fe9f5072268 <line:129:2, col:6> col:6 referenced _lbfsize 'int'`: testNode{&FieldDecl{
Addr: 0x7fe9f5072268,
Pos: NewPositionFromString("line:129:2, col:6"),
Position2: "col:6",
@ -98,12 +92,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: true,
ChildNodes: []Node{},
},
0x7fe9f5072268,
NewPositionFromString("line:129:2, col:6"),
[]Node{},
0x7fe9f5072268,
NewPositionFromString("line:129:2, col:6"),
[]Node{},
},
`0x7f9bc9083d00 <line:91:5, line:97:8> line:91:5 'unsigned short'`:
testNode{&FieldDecl{
`0x7f9bc9083d00 <line:91:5, line:97:8> line:91:5 'unsigned short'`: testNode{&FieldDecl{
Addr: 0x7f9bc9083d00,
Pos: NewPositionFromString("line:91:5, line:97:8"),
Position2: "line:91:5",
@ -114,12 +107,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x7f9bc9083d00,
NewPositionFromString("line:91:5, line:97:8"),
[]Node{},
0x7f9bc9083d00,
NewPositionFromString("line:91:5, line:97:8"),
[]Node{},
},
`0x30363a0 <col:18, col:29> __val 'int [2]'`:
testNode{&FieldDecl{
`0x30363a0 <col:18, col:29> __val 'int [2]'`: testNode{&FieldDecl{
Addr: 0x30363a0,
Pos: NewPositionFromString("col:18, col:29"),
Position2: "",
@ -130,12 +122,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x30363a0,
NewPositionFromString("col:18, col:29"),
[]Node{},
0x30363a0,
NewPositionFromString("col:18, col:29"),
[]Node{},
},
`0x17aeac0 <line:3:9> col:9 implicit referenced 'struct vec3d_t::(anonymous at main.c:3:9)'`:
testNode{&FieldDecl{
`0x17aeac0 <line:3:9> col:9 implicit referenced 'struct vec3d_t::(anonymous at main.c:3:9)'`: testNode{&FieldDecl{
Addr: 0x17aeac0,
Pos: NewPositionFromString("line:3:9"),
Position2: "col:9",
@ -146,12 +137,11 @@ func TestFieldDecl(t *testing.T) {
Referenced: true,
ChildNodes: []Node{},
},
0x17aeac0,
NewPositionFromString("line:3:9"),
[]Node{},
0x17aeac0,
NewPositionFromString("line:3:9"),
[]Node{},
},
`0x56498bf52160 <line:269:5, col:21> col:21 type 'enum __pid_type':'enum __pid_type'`:
testNode{&FieldDecl{
`0x56498bf52160 <line:269:5, col:21> col:21 type 'enum __pid_type':'enum __pid_type'`: testNode{&FieldDecl{
Addr: 0x56498bf52160,
Pos: NewPositionFromString("line:269:5, col:21"),
Position2: "col:21",
@ -162,9 +152,9 @@ func TestFieldDecl(t *testing.T) {
Referenced: false,
ChildNodes: []Node{},
},
0x56498bf52160,
NewPositionFromString("line:269:5, col:21"),
[]Node{},
0x56498bf52160,
NewPositionFromString("line:269:5, col:21"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestField(t *testing.T) {
nodes := map[string]testNode{
`0x44159a0 '' 'union sigcontext::(anonymous at /usr/include/x86_64-linux-gnu/bits/sigcontext.h:165:17)'`:
testNode{&Field{
`0x44159a0 '' 'union sigcontext::(anonymous at /usr/include/x86_64-linux-gnu/bits/sigcontext.h:165:17)'`: testNode{&Field{
Addr: 0x44159a0,
String1: "",
String2: "union sigcontext::(anonymous at /usr/include/x86_64-linux-gnu/bits/sigcontext.h:165:17)",
ChildNodes: []Node{},
},
0x44159a0,
NewPositionFromString(""),
[]Node{},
0x44159a0,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -2,48 +2,48 @@ package ast
// FlagEnumAttr
type FlagEnumAttr struct {
Addr Address
Pos Position
Content string
ChildNodes []Node
Addr Address
Pos Position
Content string
ChildNodes []Node
}
func parseFlagEnumAttr(line string) Node {
groups := groupsFromRegex(
"<(?P<position>.*)>(?P<content>.*)",
line,
)
if groups == nil {
return &Unknown{}
}
groups := groupsFromRegex(
"<(?P<position>.*)>(?P<content>.*)",
line,
)
if groups == nil {
return &Unknown{}
}
return &FlagEnumAttr{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Content: groups["content"],
ChildNodes: []Node{},
}
return &FlagEnumAttr{
Addr: ParseAddress(groups["address"]),
Pos: NewPositionFromString(groups["position"]),
Content: groups["content"],
ChildNodes: []Node{},
}
}
// AddChild adds a new child node. Child nodes can then be accessed with the
// Children attribute.
func (n *FlagEnumAttr) AddChild(node Node) {
n.ChildNodes = append(n.ChildNodes, 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 *FlagEnumAttr) Address() Address {
return n.Addr
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 *FlagEnumAttr) Children() []Node {
return n.ChildNodes
return n.ChildNodes
}
// Position returns the position in the original source code.
func (n *FlagEnumAttr) Position() Position {
return n.Pos
return n.Pos
}

View File

@ -6,16 +6,15 @@ import (
func TestFlagEnumAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`:
testNode{&FlagEnumAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7> content`: testNode{&FlagEnumAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
Content: " content",
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -1,11 +1,11 @@
package ast
import (
//"errors"
//"fmt"
//"reflect"
//"errors"
//"fmt"
//"reflect"
//"github.com/elliotchance/c2go/cc"
//"github.com/elliotchance/c2go/cc"
)
// FloatingLiteral is type of float literal

View File

@ -6,29 +6,27 @@ import (
func TestFloatingLiteral(t *testing.T) {
nodes := map[string]testNode{
`0x7febe106f5e8 <col:24> 'double' 1.230000e+00`:
testNode{&FloatingLiteral{
`0x7febe106f5e8 <col:24> 'double' 1.230000e+00`: testNode{&FloatingLiteral{
Addr: 0x7febe106f5e8,
Pos: NewPositionFromString("col:24"),
Type: "double",
Value: 1.23,
ChildNodes: []Node{},
},
0x7febe106f5e8,
NewPositionFromString("col:24"),
[]Node{},
0x7febe106f5e8,
NewPositionFromString("col:24"),
[]Node{},
},
`0x21c65b8 <col:41> 'double' 2.718282e+00`:
testNode{&FloatingLiteral{
`0x21c65b8 <col:41> 'double' 2.718282e+00`: testNode{&FloatingLiteral{
Addr: 0x21c65b8,
Pos: NewPositionFromString("col:41"),
Type: "double",
Value: 2.718282e+00,
ChildNodes: []Node{},
},
0x21c65b8,
NewPositionFromString("col:41"),
[]Node{},
0x21c65b8,
NewPositionFromString("col:41"),
[]Node{},
},
}

View File

@ -6,15 +6,14 @@ import (
func TestForStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7f961e018848 <line:9:4, line:10:70>`:
testNode{&ForStmt{
`0x7f961e018848 <line:9:4, line:10:70>`: testNode{&ForStmt{
Addr: 0x7f961e018848,
Pos: NewPositionFromString("line:9:4, line:10:70"),
ChildNodes: []Node{},
},
0x7f961e018848,
NewPositionFromString("line:9:4, line:10:70"),
[]Node{},
0x7f961e018848,
NewPositionFromString("line:9:4, line:10:70"),
[]Node{},
},
}

View File

@ -6,16 +6,15 @@ import (
func TestFormatArgAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7f1234567890 <col:47, col:57> 1`:
testNode{&FormatArgAttr{
`0x7f1234567890 <col:47, col:57> 1`: testNode{&FormatArgAttr{
Addr: 0x7f1234567890,
Pos: NewPositionFromString("col:47, col:57"),
Arg: "1",
ChildNodes: []Node{},
},
0x7f1234567890,
NewPositionFromString("col:47, col:57"),
[]Node{},
0x7f1234567890,
NewPositionFromString("col:47, col:57"),
[]Node{},
},
}

View File

@ -6,8 +6,7 @@ import (
func TestFormatAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fcc8d8ecee8 <col:6> Implicit printf 2 3`:
testNode{&FormatAttr{
`0x7fcc8d8ecee8 <col:6> Implicit printf 2 3`: testNode{&FormatAttr{
Addr: 0x7fcc8d8ecee8,
Pos: NewPositionFromString("col:6"),
Implicit: true,
@ -17,12 +16,11 @@ func TestFormatAttr(t *testing.T) {
Unknown2: 3,
ChildNodes: []Node{},
},
0x7fcc8d8ecee8,
NewPositionFromString("col:6"),
[]Node{},
0x7fcc8d8ecee8,
NewPositionFromString("col:6"),
[]Node{},
},
`0x7fcc8d8ecff8 </usr/include/sys/cdefs.h:351:18, col:61> printf 2 3`:
testNode{&FormatAttr{
`0x7fcc8d8ecff8 </usr/include/sys/cdefs.h:351:18, col:61> printf 2 3`: testNode{&FormatAttr{
Addr: 0x7fcc8d8ecff8,
Pos: NewPositionFromString("/usr/include/sys/cdefs.h:351:18, col:61"),
Implicit: false,
@ -32,12 +30,11 @@ func TestFormatAttr(t *testing.T) {
Unknown2: 3,
ChildNodes: []Node{},
},
0x7fcc8d8ecff8,
NewPositionFromString("/usr/include/sys/cdefs.h:351:18, col:61"),
[]Node{},
0x7fcc8d8ecff8,
NewPositionFromString("/usr/include/sys/cdefs.h:351:18, col:61"),
[]Node{},
},
`0x273b4d0 <line:357:12> Inherited printf 2 3`:
testNode{&FormatAttr{
`0x273b4d0 <line:357:12> Inherited printf 2 3`: testNode{&FormatAttr{
Addr: 0x273b4d0,
Pos: NewPositionFromString("line:357:12"),
Implicit: false,
@ -47,9 +44,9 @@ func TestFormatAttr(t *testing.T) {
Unknown2: 3,
ChildNodes: []Node{},
},
0x273b4d0,
NewPositionFromString("line:357:12"),
[]Node{},
0x273b4d0,
NewPositionFromString("line:357:12"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseFullComment(line string) Node {
`<(?P<position>.*)>`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &FullComment{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestFullComment(t *testing.T) {
nodes := map[string]testNode{
`0x3860920 <line:10176:4, line:10180:45>`:
testNode{&FullComment{
`0x3860920 <line:10176:4, line:10180:45>`: testNode{&FullComment{
Addr: 0x3860920,
Pos: NewPositionFromString("line:10176:4, line:10180:45"),
ChildNodes: []Node{},
},
0x3860920,
NewPositionFromString("line:10176:4, line:10180:45"),
[]Node{},
0x3860920,
NewPositionFromString("line:10176:4, line:10180:45"),
[]Node{},
},
}

View File

@ -41,9 +41,9 @@ func parseFunctionDecl(line string) Node {
`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &FunctionDecl{
Addr: ParseAddress(groups["address"]),

View File

@ -6,8 +6,7 @@ import (
func TestFunctionDecl(t *testing.T) {
nodes := map[string]testNode{
`0x7fb5a90e60d0 <line:231:1, col:22> col:7 clearerr 'void (FILE *)'`:
testNode{&FunctionDecl{
`0x7fb5a90e60d0 <line:231:1, col:22> col:7 clearerr 'void (FILE *)'`: testNode{&FunctionDecl{
Addr: 0x7fb5a90e60d0,
Pos: NewPositionFromString("line:231:1, col:22"),
Prev: "",
@ -23,12 +22,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x7fb5a90e60d0,
NewPositionFromString("line:231:1, col:22"),
[]Node{},
0x7fb5a90e60d0,
NewPositionFromString("line:231:1, col:22"),
[]Node{},
},
`0x7fb5a90e2a50 </usr/include/sys/stdio.h:39:1, /usr/include/AvailabilityInternal.h:21697:126> /usr/include/sys/stdio.h:39:5 renameat 'int (int, const char *, int, const char *)'`:
testNode{&FunctionDecl{
`0x7fb5a90e2a50 </usr/include/sys/stdio.h:39:1, /usr/include/AvailabilityInternal.h:21697:126> /usr/include/sys/stdio.h:39:5 renameat 'int (int, const char *, int, const char *)'`: testNode{&FunctionDecl{
Addr: 0x7fb5a90e2a50,
Pos: NewPositionFromString("/usr/include/sys/stdio.h:39:1, /usr/include/AvailabilityInternal.h:21697:126"),
Prev: "",
@ -44,12 +42,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x7fb5a90e2a50,
NewPositionFromString("/usr/include/sys/stdio.h:39:1, /usr/include/AvailabilityInternal.h:21697:126"),
[]Node{},
0x7fb5a90e2a50,
NewPositionFromString("/usr/include/sys/stdio.h:39:1, /usr/include/AvailabilityInternal.h:21697:126"),
[]Node{},
},
`0x7fb5a90e9b70 </usr/include/stdio.h:244:6> col:6 implicit fprintf 'int (FILE *, const char *, ...)' extern`:
testNode{&FunctionDecl{
`0x7fb5a90e9b70 </usr/include/stdio.h:244:6> col:6 implicit fprintf 'int (FILE *, const char *, ...)' extern`: testNode{&FunctionDecl{
Addr: 0x7fb5a90e9b70,
Pos: NewPositionFromString("/usr/include/stdio.h:244:6"),
Prev: "",
@ -65,12 +62,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x7fb5a90e9b70,
NewPositionFromString("/usr/include/stdio.h:244:6"),
[]Node{},
0x7fb5a90e9b70,
NewPositionFromString("/usr/include/stdio.h:244:6"),
[]Node{},
},
`0x7fb5a90e9d40 prev 0x7fb5a90e9b70 <col:1, /usr/include/sys/cdefs.h:351:63> /usr/include/stdio.h:244:6 fprintf 'int (FILE *, const char *, ...)'`:
testNode{&FunctionDecl{
`0x7fb5a90e9d40 prev 0x7fb5a90e9b70 <col:1, /usr/include/sys/cdefs.h:351:63> /usr/include/stdio.h:244:6 fprintf 'int (FILE *, const char *, ...)'`: testNode{&FunctionDecl{
Addr: 0x7fb5a90e9d40,
Pos: NewPositionFromString("col:1, /usr/include/sys/cdefs.h:351:63"),
Prev: "0x7fb5a90e9b70",
@ -86,12 +82,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x7fb5a90e9d40,
NewPositionFromString("col:1, /usr/include/sys/cdefs.h:351:63"),
[]Node{},
0x7fb5a90e9d40,
NewPositionFromString("col:1, /usr/include/sys/cdefs.h:351:63"),
[]Node{},
},
`0x7fb5a90ec210 <line:259:6> col:6 implicit used printf 'int (const char *, ...)' extern`:
testNode{&FunctionDecl{
`0x7fb5a90ec210 <line:259:6> col:6 implicit used printf 'int (const char *, ...)' extern`: testNode{&FunctionDecl{
Addr: 0x7fb5a90ec210,
Pos: NewPositionFromString("line:259:6"),
Prev: "",
@ -107,12 +102,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x7fb5a90ec210,
NewPositionFromString("line:259:6"),
[]Node{},
0x7fb5a90ec210,
NewPositionFromString("line:259:6"),
[]Node{},
},
`0x2ae30d8 </usr/include/math.h:65:3, /usr/include/x86_64-linux-gnu/sys/cdefs.h:57:54> <scratch space>:17:1 __acos 'double (double)' extern`:
testNode{&FunctionDecl{
`0x2ae30d8 </usr/include/math.h:65:3, /usr/include/x86_64-linux-gnu/sys/cdefs.h:57:54> <scratch space>:17:1 __acos 'double (double)' extern`: testNode{&FunctionDecl{
Addr: 0x2ae30d8,
Pos: NewPositionFromString("/usr/include/math.h:65:3, /usr/include/x86_64-linux-gnu/sys/cdefs.h:57:54"),
Prev: "",
@ -128,12 +122,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x2ae30d8,
NewPositionFromString("/usr/include/math.h:65:3, /usr/include/x86_64-linux-gnu/sys/cdefs.h:57:54"),
[]Node{},
0x2ae30d8,
NewPositionFromString("/usr/include/math.h:65:3, /usr/include/x86_64-linux-gnu/sys/cdefs.h:57:54"),
[]Node{},
},
`0x7fc595071500 <line:26:1, line:69:1> line:26:5 referenced main 'int (int, char **)'`:
testNode{&FunctionDecl{
`0x7fc595071500 <line:26:1, line:69:1> line:26:5 referenced main 'int (int, char **)'`: testNode{&FunctionDecl{
Addr: 0x7fc595071500,
Pos: NewPositionFromString("line:26:1, line:69:1"),
Prev: "",
@ -149,12 +142,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x7fc595071500,
NewPositionFromString("line:26:1, line:69:1"),
[]Node{},
0x7fc595071500,
NewPositionFromString("line:26:1, line:69:1"),
[]Node{},
},
`0x55973a008cb0 <line:93619:1, line:93630:1> line:93619:12 used exprIsConst 'int (Expr *, int, int)' static`:
testNode{&FunctionDecl{
`0x55973a008cb0 <line:93619:1, line:93630:1> line:93619:12 used exprIsConst 'int (Expr *, int, int)' static`: testNode{&FunctionDecl{
Addr: 0x55973a008cb0,
Pos: NewPositionFromString("line:93619:1, line:93630:1"),
Prev: "",
@ -170,12 +162,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x55973a008cb0,
NewPositionFromString("line:93619:1, line:93630:1"),
[]Node{},
0x55973a008cb0,
NewPositionFromString("line:93619:1, line:93630:1"),
[]Node{},
},
`0x563ade547cb8 <safe_math.h:13:1, line:25:1> line:14:2 safe_unary_minus_func_int8_t_s 'int8_t (int8_t)':'int8_t (int8_t)' static`:
testNode{&FunctionDecl{
`0x563ade547cb8 <safe_math.h:13:1, line:25:1> line:14:2 safe_unary_minus_func_int8_t_s 'int8_t (int8_t)':'int8_t (int8_t)' static`: testNode{&FunctionDecl{
Addr: 0x563ade547cb8,
Pos: NewPositionFromString("safe_math.h:13:1, line:25:1"),
Prev: "",
@ -191,12 +182,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x563ade547cb8,
NewPositionFromString("safe_math.h:13:1, line:25:1"),
[]Node{},
0x563ade547cb8,
NewPositionFromString("safe_math.h:13:1, line:25:1"),
[]Node{},
},
`0x556cac571be0 <tests/asm.c:9:1, line:13:1> line:9:26 sqlite3Hwtime1 'unsigned long (void)' inline`:
testNode{&FunctionDecl{
`0x556cac571be0 <tests/asm.c:9:1, line:13:1> line:9:26 sqlite3Hwtime1 'unsigned long (void)' inline`: testNode{&FunctionDecl{
Addr: 0x556cac571be0,
Pos: NewPositionFromString("tests/asm.c:9:1, line:13:1"),
Prev: "",
@ -212,12 +202,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: true,
ChildNodes: []Node{},
},
0x556cac571be0,
NewPositionFromString("tests/asm.c:9:1, line:13:1"),
[]Node{},
0x556cac571be0,
NewPositionFromString("tests/asm.c:9:1, line:13:1"),
[]Node{},
},
`0x21c3da0 <line:8201:1, line:8786:1> line:8201:25 used insertvertex 'enum insertvertexresult (struct mesh *, struct behavior *, vertex, struct otri *, struct osub *, int, int)'`:
testNode{&FunctionDecl{
`0x21c3da0 <line:8201:1, line:8786:1> line:8201:25 used insertvertex 'enum insertvertexresult (struct mesh *, struct behavior *, vertex, struct otri *, struct osub *, int, int)'`: testNode{&FunctionDecl{
Addr: 0x21c3da0,
Pos: NewPositionFromString("line:8201:1, line:8786:1"),
Prev: "",
@ -233,12 +222,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x21c3da0,
NewPositionFromString("line:8201:1, line:8786:1"),
[]Node{},
0x21c3da0,
NewPositionFromString("line:8201:1, line:8786:1"),
[]Node{},
},
`0x30bdba8 parent 0x304fbb0 <col:3, col:38> col:30 used getinfo 'enum countries ()'`:
testNode{&FunctionDecl{
`0x30bdba8 parent 0x304fbb0 <col:3, col:38> col:30 used getinfo 'enum countries ()'`: testNode{&FunctionDecl{
Addr: 0x30bdba8,
Pos: NewPositionFromString("col:3, col:38"),
Prev: "",
@ -255,12 +243,11 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x30bdba8,
NewPositionFromString("col:3, col:38"),
[]Node{},
0x30bdba8,
NewPositionFromString("col:3, col:38"),
[]Node{},
},
`0x353d3b8 parent 0x31e9ba0 prev 0x33b0810 <col:2, col:30> col:22 used dmatrix 'double **(long, long, long, long)'`:
testNode{&FunctionDecl{
`0x353d3b8 parent 0x31e9ba0 prev 0x33b0810 <col:2, col:30> col:22 used dmatrix 'double **(long, long, long, long)'`: testNode{&FunctionDecl{
Addr: 0x353d3b8,
Pos: NewPositionFromString("col:2, col:30"),
Prev: "0x33b0810",
@ -277,9 +264,9 @@ func TestFunctionDecl(t *testing.T) {
IsInline: false,
ChildNodes: []Node{},
},
0x353d3b8,
NewPositionFromString("col:2, col:30"),
[]Node{},
0x353d3b8,
NewPositionFromString("col:2, col:30"),
[]Node{},
},
}

View File

@ -13,9 +13,9 @@ func parseFunctionProtoType(line string) Node {
"'(?P<type>.*?)' (?P<kind>.*)",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &FunctionProtoType{
Addr: ParseAddress(groups["address"]),

View File

@ -6,16 +6,15 @@ import (
func TestFunctionProtoType(t *testing.T) {
nodes := map[string]testNode{
`0x7fa3b88bbb30 'struct _opaque_pthread_t *' foo`:
testNode{&FunctionProtoType{
`0x7fa3b88bbb30 'struct _opaque_pthread_t *' foo`: testNode{&FunctionProtoType{
Addr: 0x7fa3b88bbb30,
Type: "struct _opaque_pthread_t *",
Kind: "foo",
ChildNodes: []Node{},
},
0x7fa3b88bbb30,
NewPositionFromString(""),
[]Node{},
0x7fa3b88bbb30,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseGCCAsmStmt(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &GCCAsmStmt{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestGCCAsmStmtStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fad830c9e38 <line:13:5, col:57>`:
testNode{&GCCAsmStmt{
`0x7fad830c9e38 <line:13:5, col:57>`: testNode{&GCCAsmStmt{
Addr: 0x7fad830c9e38,
Pos: NewPositionFromString("line:13:5, col:57"),
ChildNodes: []Node{},
},
0x7fad830c9e38,
NewPositionFromString("line:13:5, col:57"),
[]Node{},
0x7fad830c9e38,
NewPositionFromString("line:13:5, col:57"),
[]Node{},
},
}

View File

@ -14,9 +14,9 @@ func parseGotoStmt(line string) Node {
"<(?P<position>.*)> '(?P<name>.*)' (?P<position2>.*)",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &GotoStmt{
Addr: ParseAddress(groups["address"]),

View File

@ -6,17 +6,16 @@ import (
func TestGotoStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fb9cc1994d8 <line:18893:9, col:14> 'end_getDigits' 0x7fb9cc199490`:
testNode{&GotoStmt{
`0x7fb9cc1994d8 <line:18893:9, col:14> 'end_getDigits' 0x7fb9cc199490`: testNode{&GotoStmt{
Addr: 0x7fb9cc1994d8,
Pos: NewPositionFromString("line:18893:9, col:14"),
Name: "end_getDigits",
Position2: "0x7fb9cc199490",
ChildNodes: []Node{},
},
0x7fb9cc1994d8,
NewPositionFromString("line:18893:9, col:14"),
[]Node{},
0x7fb9cc1994d8,
NewPositionFromString("line:18893:9, col:14"),
[]Node{},
},
}

View File

@ -13,9 +13,9 @@ func parseHTMLEndTagComment(line string) Node {
`<(?P<position>.*)> Name="(?P<name>.*)"`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &HTMLEndTagComment{
Addr: ParseAddress(groups["address"]),

View File

@ -6,16 +6,15 @@ import (
func TestHTMLEndTagComment(t *testing.T) {
nodes := map[string]testNode{
`0x4259670 <col:27, col:30> Name="i"`:
testNode{&HTMLEndTagComment{
`0x4259670 <col:27, col:30> Name="i"`: testNode{&HTMLEndTagComment{
Addr: 0x4259670,
Pos: NewPositionFromString("col:27, col:30"),
Name: "i",
ChildNodes: []Node{},
},
0x4259670,
NewPositionFromString("col:27, col:30"),
[]Node{},
0x4259670,
NewPositionFromString("col:27, col:30"),
[]Node{},
},
}

View File

@ -13,9 +13,9 @@ func parseHTMLStartTagComment(line string) Node {
`<(?P<position>.*)> Name="(?P<name>.*)"`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &HTMLStartTagComment{
Addr: ParseAddress(groups["address"]),

View File

@ -6,16 +6,15 @@ import (
func TestHTMLStartTagComment(t *testing.T) {
nodes := map[string]testNode{
`0x4259670 <col:27, col:30> Name="i"`:
testNode{&HTMLStartTagComment{
`0x4259670 <col:27, col:30> Name="i"`: testNode{&HTMLStartTagComment{
Addr: 0x4259670,
Pos: NewPositionFromString("col:27, col:30"),
Name: "i",
ChildNodes: []Node{},
},
0x4259670,
NewPositionFromString("col:27, col:30"),
[]Node{},
0x4259670,
NewPositionFromString("col:27, col:30"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseIBActionAttr(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &IBActionAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestIBActionAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7>`:
testNode{&IBActionAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7>`: testNode{&IBActionAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseIBOutletAttr(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &IBOutletAttr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestIBOutletAttr(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d1 <line:11:7, line:18:7>`:
testNode{&IBOutletAttr{
`0x7fc0a69091d1 <line:11:7, line:18:7>`: testNode{&IBOutletAttr{
Addr: 0x7fc0a69091d1,
Pos: NewPositionFromString("line:11:7, line:18:7"),
ChildNodes: []Node{},
},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d1,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseIfStmt(line string) Node {
"<(?P<position>.*)>",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &IfStmt{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestIfStmt(t *testing.T) {
nodes := map[string]testNode{
`0x7fc0a69091d0 <line:11:7, line:18:7>`:
testNode{&IfStmt{
`0x7fc0a69091d0 <line:11:7, line:18:7>`: testNode{&IfStmt{
Addr: 0x7fc0a69091d0,
Pos: NewPositionFromString("line:11:7, line:18:7"),
ChildNodes: []Node{},
},
0x7fc0a69091d0,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
0x7fc0a69091d0,
NewPositionFromString("line:11:7, line:18:7"),
[]Node{},
},
}

View File

@ -6,32 +6,29 @@ import (
func TestImplicitCastExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7f9f5b0a1288 <col:8> 'FILE *' <LValueToRValue>`:
testNode{&ImplicitCastExpr{
`0x7f9f5b0a1288 <col:8> 'FILE *' <LValueToRValue>`: testNode{&ImplicitCastExpr{
Addr: 0x7f9f5b0a1288,
Pos: NewPositionFromString("col:8"),
Type: "FILE *",
Kind: "LValueToRValue",
ChildNodes: []Node{},
},
0x7f9f5b0a1288,
NewPositionFromString("col:8"),
[]Node{},
0x7f9f5b0a1288,
NewPositionFromString("col:8"),
[]Node{},
},
`0x7f9f5b0a7828 <col:11> 'int (*)(int, FILE *)' <FunctionToPointerDecay>`:
testNode{&ImplicitCastExpr{
`0x7f9f5b0a7828 <col:11> 'int (*)(int, FILE *)' <FunctionToPointerDecay>`: testNode{&ImplicitCastExpr{
Addr: 0x7f9f5b0a7828,
Pos: NewPositionFromString("col:11"),
Type: "int (*)(int, FILE *)",
Kind: "FunctionToPointerDecay",
ChildNodes: []Node{},
},
0x7f9f5b0a7828,
NewPositionFromString("col:11"),
[]Node{},
0x7f9f5b0a7828,
NewPositionFromString("col:11"),
[]Node{},
},
`0x21267c8 <col:8> 'enum week1':'enum week2' <IntegralCast>`:
testNode{&ImplicitCastExpr{
`0x21267c8 <col:8> 'enum week1':'enum week2' <IntegralCast>`: testNode{&ImplicitCastExpr{
Addr: 0x21267c8,
Pos: NewPositionFromString("col:8"),
Type: "enum week1",
@ -39,12 +36,11 @@ func TestImplicitCastExpr(t *testing.T) {
Kind: "IntegralCast",
ChildNodes: []Node{},
},
0x21267c8,
NewPositionFromString("col:8"),
[]Node{},
0x21267c8,
NewPositionFromString("col:8"),
[]Node{},
},
`0x26fd2d8 <col:20, col:32> 'extCoord':'extCoord' <LValueToRValue>`:
testNode{&ImplicitCastExpr{
`0x26fd2d8 <col:20, col:32> 'extCoord':'extCoord' <LValueToRValue>`: testNode{&ImplicitCastExpr{
Addr: 0x26fd2d8,
Pos: NewPositionFromString("col:20, col:32"),
Type: "extCoord",
@ -52,9 +48,9 @@ func TestImplicitCastExpr(t *testing.T) {
Kind: "LValueToRValue",
ChildNodes: []Node{},
},
0x26fd2d8,
NewPositionFromString("col:20, col:32"),
[]Node{},
0x26fd2d8,
NewPositionFromString("col:20, col:32"),
[]Node{},
},
}

View File

@ -14,9 +14,9 @@ func parseImplicitValueInitExpr(line string) Node {
"<(?P<position>.*)> '(?P<type1>.*?)'(:'(?P<type2>.*)')?",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &ImplicitValueInitExpr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,29 +6,27 @@ import (
func TestImplicitValueInitExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7f8c3396fbd8 <<invalid sloc>> 'sqlite3StatValueType':'long long'`:
testNode{&ImplicitValueInitExpr{
`0x7f8c3396fbd8 <<invalid sloc>> 'sqlite3StatValueType':'long long'`: testNode{&ImplicitValueInitExpr{
Addr: 0x7f8c3396fbd8,
Pos: NewPositionFromString("<invalid sloc>"),
Type1: "sqlite3StatValueType",
Type2: "long long",
ChildNodes: []Node{},
},
0x7f8c3396fbd8,
NewPositionFromString("<invalid sloc>"),
[]Node{},
0x7f8c3396fbd8,
NewPositionFromString("<invalid sloc>"),
[]Node{},
},
`0x7feecb0d6af0 <<invalid sloc>> 'char'`:
testNode{&ImplicitValueInitExpr{
`0x7feecb0d6af0 <<invalid sloc>> 'char'`: testNode{&ImplicitValueInitExpr{
Addr: 0x7feecb0d6af0,
Pos: NewPositionFromString("<invalid sloc>"),
Type1: "char",
Type2: "",
ChildNodes: []Node{},
},
0x7feecb0d6af0,
NewPositionFromString("<invalid sloc>"),
[]Node{},
0x7feecb0d6af0,
NewPositionFromString("<invalid sloc>"),
[]Node{},
},
}

View File

@ -12,9 +12,9 @@ func parseIncompleteArrayType(line string) Node {
"'(?P<type>.*)' ",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &IncompleteArrayType{
Addr: ParseAddress(groups["address"]),

View File

@ -6,15 +6,14 @@ import (
func TestIncompleteArrayType(t *testing.T) {
nodes := map[string]testNode{
`0x7fcb7d005c20 'int []' `:
testNode{&IncompleteArrayType{
`0x7fcb7d005c20 'int []' `: testNode{&IncompleteArrayType{
Addr: 0x7fcb7d005c20,
Type: "int []",
ChildNodes: []Node{},
},
0x7fcb7d005c20,
NewPositionFromString(""),
[]Node{},
0x7fcb7d005c20,
NewPositionFromString(""),
[]Node{},
},
}

View File

@ -22,9 +22,9 @@ func parseIndirectFieldDecl(line string) Node {
'(?P<type>.+?)'`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &IndirectFieldDecl{
Addr: ParseAddress(groups["address"]),

View File

@ -6,8 +6,7 @@ import (
func TestIndirectFieldDecl(t *testing.T) {
nodes := map[string]testNode{
`0x2be19a8 <line:167:25> col:25 implicit fpstate 'struct _fpstate *'`:
testNode{&IndirectFieldDecl{
`0x2be19a8 <line:167:25> col:25 implicit fpstate 'struct _fpstate *'`: testNode{&IndirectFieldDecl{
Addr: 0x2be19a8,
Pos: NewPositionFromString("line:167:25"),
Position2: "col:25",
@ -16,9 +15,9 @@ func TestIndirectFieldDecl(t *testing.T) {
Type: "struct _fpstate *",
ChildNodes: []Node{},
},
0x2be19a8,
NewPositionFromString("line:167:25"),
[]Node{},
0x2be19a8,
NewPositionFromString("line:167:25"),
[]Node{},
},
}

View File

@ -14,9 +14,9 @@ func parseInitListExpr(line string) Node {
"<(?P<position>.*)> '(?P<type1>.*?)'(:'(?P<type2>.*)')?",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &InitListExpr{
Addr: ParseAddress(groups["address"]),

View File

@ -6,39 +6,36 @@ import (
func TestInitListExpr(t *testing.T) {
nodes := map[string]testNode{
`0x7fbdd1906c20 <col:52, line:17160:1> 'const unsigned char [256]'`:
testNode{&InitListExpr{
`0x7fbdd1906c20 <col:52, line:17160:1> 'const unsigned char [256]'`: testNode{&InitListExpr{
Addr: 0x7fbdd1906c20,
Pos: NewPositionFromString("col:52, line:17160:1"),
Type1: "const unsigned char [256]",
ChildNodes: []Node{},
},
0x7fbdd1906c20,
NewPositionFromString("col:52, line:17160:1"),
[]Node{},
0x7fbdd1906c20,
NewPositionFromString("col:52, line:17160:1"),
[]Node{},
},
`0x32017f0 <col:24, col:41> 'struct node [2]'`:
testNode{&InitListExpr{
`0x32017f0 <col:24, col:41> 'struct node [2]'`: testNode{&InitListExpr{
Addr: 0x32017f0,
Pos: NewPositionFromString("col:24, col:41"),
Type1: "struct node [2]",
ChildNodes: []Node{},
},
0x32017f0,
NewPositionFromString("col:24, col:41"),
[]Node{},
0x32017f0,
NewPositionFromString("col:24, col:41"),
[]Node{},
},
`0x3201840 <col:25, col:31> 'struct node':'struct node'`:
testNode{&InitListExpr{
`0x3201840 <col:25, col:31> 'struct node':'struct node'`: testNode{&InitListExpr{
Addr: 0x3201840,
Pos: NewPositionFromString("col:25, col:31"),
Type1: "struct node",
Type2: "struct node",
ChildNodes: []Node{},
},
0x3201840,
NewPositionFromString("col:25, col:31"),
[]Node{},
0x3201840,
NewPositionFromString("col:25, col:31"),
[]Node{},
},
}

View File

@ -13,9 +13,9 @@ func parseInlineCommandComment(line string) Node {
`<(?P<position>.*)> (?P<other>.*)`,
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &InlineCommandComment{
Addr: ParseAddress(groups["address"]),

View File

@ -6,16 +6,15 @@ import (
func TestInlineCommandComment(t *testing.T) {
nodes := map[string]testNode{
`0x22e3510 <col:2, col:6> Name="NOTE" RenderNormal`:
testNode{&InlineCommandComment{
`0x22e3510 <col:2, col:6> Name="NOTE" RenderNormal`: testNode{&InlineCommandComment{
Addr: 0x22e3510,
Pos: NewPositionFromString("col:2, col:6"),
Other: "Name=\"NOTE\" RenderNormal",
ChildNodes: []Node{},
},
0x22e3510,
NewPositionFromString("col:2, col:6"),
[]Node{},
0x22e3510,
NewPositionFromString("col:2, col:6"),
[]Node{},
},
}

View File

@ -14,9 +14,9 @@ func parseIntegerLiteral(line string) Node {
"<(?P<position>.*)> '(?P<type>.*?)' (?P<value>\\d+)",
line,
)
if groups == nil {
return &Unknown{}
}
if groups == nil {
return &Unknown{}
}
return &IntegerLiteral{
Addr: ParseAddress(groups["address"]),

Some files were not shown because too many files have changed in this diff Show More