summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Min Yun <min.yun@lge.com> 2024-09-03 20:36:47 +0900
committer Min Yun <min.yun@lge.com> 2024-09-03 20:36:47 +0900
commite9cc403553a2886a608a59c24f2ee7aab12946fd (patch)
tree63b097651fdd6efce77779c3842f46fee27a9c51
parentcdd70d268a25626651ace46e56a327e366697fdb (diff)
Fix End() of Rule
If a directive appears in the middle of a Rule, the Rule does not reflect its length. This must be reflected to obtain the correct End() position of the Rule. Change-Id: I67a78f95487829c639b0c1414ac4cc096faa6363
-rw-r--r--androidmk/parser/ast.go3
-rw-r--r--androidmk/parser/parser.go1
-rw-r--r--androidmk/parser/parser_test.go22
3 files changed, 25 insertions, 1 deletions
diff --git a/androidmk/parser/ast.go b/androidmk/parser/ast.go
index d5d135443..c3d198f94 100644
--- a/androidmk/parser/ast.go
+++ b/androidmk/parser/ast.go
@@ -84,6 +84,7 @@ type Rule struct {
Prerequisites *MakeString
RecipePos Pos
Recipe string
+ RecipeEndPos Pos
}
func (x *Rule) Dump() string {
@@ -95,7 +96,7 @@ func (x *Rule) Dump() string {
}
func (x *Rule) Pos() Pos { return x.Target.Pos() }
-func (x *Rule) End() Pos { return Pos(int(x.RecipePos) + len(x.Recipe)) }
+func (x *Rule) End() Pos { return x.RecipeEndPos }
type Variable struct {
Name *MakeString
diff --git a/androidmk/parser/parser.go b/androidmk/parser/parser.go
index 8a20bb052..f2477db3a 100644
--- a/androidmk/parser/parser.go
+++ b/androidmk/parser/parser.go
@@ -448,6 +448,7 @@ loop:
Prerequisites: prerequisites,
Recipe: recipe,
RecipePos: recipePos,
+ RecipeEndPos: p.pos(),
})
}
}
diff --git a/androidmk/parser/parser_test.go b/androidmk/parser/parser_test.go
index fb03c2324..e238f8b11 100644
--- a/androidmk/parser/parser_test.go
+++ b/androidmk/parser/parser_test.go
@@ -124,3 +124,25 @@ func TestParse(t *testing.T) {
})
}
}
+
+func TestRuleEnd(t *testing.T) {
+ name := "ruleEndTest"
+ in := `all:
+ifeq (A, A)
+ echo foo
+ echo foo
+ echo foo
+ echo foo
+endif
+ echo bar
+`
+ p := NewParser(name, bytes.NewBufferString(in))
+ got, errs := p.Parse()
+ if len(errs) != 0 {
+ t.Fatalf("Unexpected errors while parsing: %v", errs)
+ }
+
+ if got[0].End() < got[len(got) -1].Pos() {
+ t.Errorf("Rule's end (%d) is smaller than directive that inside of rule's start (%v)\n", got[0].End(), got[len(got) -1].Pos())
+ }
+}