parser: add support for normal and nested objects

This commit is contained in:
Fatih Arslan 2015-10-17 01:39:49 +03:00
parent 16d5eb5f08
commit 0ed9465e4b
2 changed files with 17 additions and 11 deletions

View File

@ -42,8 +42,13 @@ func (p *Parser) parseObjectList() (*ast.ObjectList, error) {
if err == errEofToken {
break // we are finished
}
if err != nil {
return nil, err
if p.tok.Type != token.RBRACE {
return nil, err
} else {
break
}
}
// we successfully parsed a node, add it to the final source node
@ -62,9 +67,9 @@ func (p *Parser) parseObjectItem() (*ast.ObjectItem, error) {
return nil, err
}
// either an assignment or object
switch p.tok.Type {
case token.ASSIGN:
// assignments
o := &ast.ObjectItem{
Keys: keys,
Assign: p.tok.Pos,
@ -74,16 +79,18 @@ func (p *Parser) parseObjectItem() (*ast.ObjectItem, error) {
if err != nil {
return nil, err
}
return o, nil
case token.LBRACE:
if len(keys) > 1 {
// nested object
panic("nested object is not implemented")
// object or nested objects
o := &ast.ObjectItem{
Keys: keys,
}
// object
panic("normal object is not implemented")
o.Val, err = p.parseObjectType()
if err != nil {
return nil, err
}
return o, nil
}
return nil, fmt.Errorf("not yet implemented: %s", p.tok.Type)

View File

@ -12,9 +12,8 @@ import (
)
func TestParseType(t *testing.T) {
src := `foo = {
src := `foo {
fatih = "true"
arslan = "deneme"
}`
p := New([]byte(src))
@ -28,12 +27,12 @@ func TestParseType(t *testing.T) {
ast.Walk(node, func(n ast.Node) bool {
if list, ok := n.(*ast.ObjectList); ok {
for _, l := range list.Items {
fmt.Printf("l = %+v\n", l)
for _, k := range l.Keys {
fmt.Printf("key = %+v\n", k)
}
fmt.Printf("val = %+v\n", l.Val)
}
return false
}
return true
})