1
0
mirror of https://github.com/golang/go synced 2024-11-25 07:07:57 -07:00

goyacc: make more gofmt-compliant

Adjust goyacc.go to produce code that is gofmt-compliant whenever it is easy to do so. Also changed two lines in cpyact that appeared to be bugs.

Also updated units.y to remove a few other errors.

After this change, units.go has only two style errors: an extra newline at the top of the file, and yys misaligned in yySymType.

R=rsc
CC=golang-dev
https://golang.org/cl/5265047
This commit is contained in:
Chris Hundt 2011-10-14 13:10:02 -04:00 committed by Russ Cox
parent b9faf5ff7d
commit 550fa3fa2d
2 changed files with 54 additions and 49 deletions

View File

@ -506,19 +506,20 @@ outer:
// non-literals
c := tokset[i].name[0]
if c != ' ' && c != '$' {
fmt.Fprintf(ftable, "const\t%v\t= %v\n", tokset[i].name, tokset[i].value)
fmt.Fprintf(ftable, "const %v = %v\n", tokset[i].name, tokset[i].value)
}
}
// put out names of token names
fmt.Fprintf(ftable, "var\t%sToknames\t =[]string {\n", prefix)
ftable.WriteRune('\n')
fmt.Fprintf(ftable, "var %sToknames = []string{\n", prefix)
for i := TOKSTART; i <= ntokens; i++ {
fmt.Fprintf(ftable, "\t\"%v\",\n", tokset[i].name)
}
fmt.Fprintf(ftable, "}\n")
// put out names of state names
fmt.Fprintf(ftable, "var\t%sStatenames\t =[]string {\n", prefix)
fmt.Fprintf(ftable, "var %sStatenames = []string{", prefix)
// for i:=TOKSTART; i<=ntokens; i++ {
// fmt.Fprintf(ftable, "\t\"%v\",\n", tokset[i].name);
// }
@ -595,7 +596,7 @@ outer:
break
}
levprd[nprod] |= ACTFLAG
fmt.Fprintf(fcode, "\ncase %v:", nprod)
fmt.Fprintf(fcode, "\n\tcase %v:", nprod)
cpyact(curprod, mem)
// action within rule...
@ -652,8 +653,8 @@ outer:
if tempty != nontrst[curprod[0]-NTBASE].value {
errorf("default action causes potential type clash")
}
fmt.Fprintf(fcode, "\ncase %v:", nprod)
fmt.Fprintf(fcode, "\n\t%sVAL.%v = %sS[%spt-0].%v;",
fmt.Fprintf(fcode, "\n\tcase %v:", nprod)
fmt.Fprintf(fcode, "\n\t\t%sVAL.%v = %sS[%spt-0].%v",
prefix, typeset[tempty], prefix, prefix, typeset[tempty])
}
moreprod()
@ -671,9 +672,10 @@ outer:
fmt.Fprintf(fcode, "\n\t}")
fmt.Fprintf(ftable, "const %sEofCode = 1\n", prefix)
fmt.Fprintf(ftable, "const %sErrCode = 2\n", prefix)
fmt.Fprintf(ftable, "const %sMaxDepth = %v\n", prefix, stacksize)
ftable.WriteRune('\n')
fmt.Fprintf(ftable, "const %sEofCode = 1\n", prefix)
fmt.Fprintf(ftable, "const %sErrCode = 2\n", prefix)
fmt.Fprintf(ftable, "const %sMaxDepth = %v\n", prefix, stacksize)
//
// copy any postfix code
@ -1039,7 +1041,7 @@ func cpyunion() {
if !lflag {
fmt.Fprintf(ftable, "\n//line %v:%v\n", infile, lineno)
}
fmt.Fprintf(ftable, "type\t%sSymType\tstruct", prefix)
fmt.Fprintf(ftable, "type %sSymType struct", prefix)
level := 0
@ -1055,7 +1057,7 @@ out:
lineno++
case '{':
if level == 0 {
fmt.Fprintf(ftable, "\n\tyys\tint;")
fmt.Fprintf(ftable, "\n\tyys int")
}
level++
case '}':
@ -1065,7 +1067,7 @@ out:
}
}
}
fmt.Fprintf(ftable, "\n")
fmt.Fprintf(ftable, "\n\n")
}
//
@ -1163,7 +1165,7 @@ func dumpprod(curprod []int, max int) {
func cpyact(curprod []int, max int) {
if !lflag {
fmt.Fprintf(fcode, "\n//line %v:%v\n", infile, lineno)
fmt.Fprintf(fcode, "\n\t\t//line %v:%v\n\t\t", infile, lineno)
}
lno := lineno
@ -1177,14 +1179,13 @@ loop:
switch c {
case ';':
if brac == 0 {
ftable.WriteRune(c)
fcode.WriteRune(c)
return
}
case '{':
if brac == 0 {
}
ftable.WriteRune('\t')
brac++
case '$':
@ -1345,7 +1346,9 @@ loop:
errorf("action does not terminate")
case '\n':
fmt.Fprint(fcode, "\n\t")
lineno++
continue loop
}
fcode.WriteRune(c)
@ -2072,7 +2075,7 @@ func output() {
var c, u, v int
fmt.Fprintf(ftable, "\n//line yacctab:1\n")
fmt.Fprintf(ftable, "var\t%sExca = []int {\n", prefix)
fmt.Fprintf(ftable, "var %sExca = []int{\n", prefix)
noset := mkset()
@ -2145,10 +2148,12 @@ func output() {
}
fmt.Fprintf(ftable, "}\n")
fmt.Fprintf(ftable, "const\t%sNprod\t= %v\n", prefix, nprod)
fmt.Fprintf(ftable, "const\t%sPrivate\t= %v\n", prefix, PRIVATE)
fmt.Fprintf(ftable, "var\t%sTokenNames []string\n", prefix)
fmt.Fprintf(ftable, "var\t%sStates []string\n", prefix)
ftable.WriteRune('\n')
fmt.Fprintf(ftable, "const %sNprod = %v\n", prefix, nprod)
fmt.Fprintf(ftable, "const %sPrivate = %v\n", prefix, PRIVATE)
ftable.WriteRune('\n')
fmt.Fprintf(ftable, "var %sTokenNames []string\n", prefix)
fmt.Fprintf(ftable, "var %sStates []string\n", prefix)
}
//
@ -2264,7 +2269,7 @@ func wract(i int) {
continue
}
if flag == 0 {
fmt.Fprintf(ftable, "-1, %v,\n", i)
fmt.Fprintf(ftable, "\t-1, %v,\n", i)
}
flag++
fmt.Fprintf(ftable, "\t%v, %v,\n", p, p1)
@ -2723,7 +2728,8 @@ nextn:
// write out the optimized parser
//
func aoutput() {
fmt.Fprintf(ftable, "const\t%sLast\t= %v\n", prefix, maxa+1)
ftable.WriteRune('\n')
fmt.Fprintf(ftable, "const %sLast = %v\n\n", prefix, maxa+1)
arout("Act", amem, maxa+1)
arout("Pact", indgo, nstate)
arout("Pgo", pgo, nnonter+1)
@ -2805,7 +2811,7 @@ func others() {
arout("Tok2", temp1, c+1)
// table 3 has everything else
fmt.Fprintf(ftable, "var\t%sTok3\t= []int {\n", prefix)
fmt.Fprintf(ftable, "var %sTok3 = []int{\n\t", prefix)
c = 0
for i = 1; i <= ntokens; i++ {
j = tokset[i].value
@ -2816,13 +2822,19 @@ func others() {
continue
}
fmt.Fprintf(ftable, "%4d,%4d,", j, i)
if c%5 != 0 {
ftable.WriteRune(' ')
}
fmt.Fprintf(ftable, "%d, %d,", j, i)
c++
if c%5 == 0 {
ftable.WriteRune('\n')
fmt.Fprint(ftable, "\n\t")
}
}
fmt.Fprintf(ftable, "%4d,\n };\n", 0)
if c%5 != 0 {
ftable.WriteRune(' ')
}
fmt.Fprintf(ftable, "%d,\n}\n", 0)
// copy parser text
c = getrune(finput)
@ -2842,15 +2854,16 @@ func others() {
func arout(s string, v []int, n int) {
s = prefix + s
fmt.Fprintf(ftable, "var\t%v\t= []int {\n", s)
fmt.Fprintf(ftable, "var %v = []int{\n", s)
for i := 0; i < n; i++ {
if i%10 == 0 {
ftable.WriteRune('\n')
fmt.Fprintf(ftable, "\n\t")
} else {
ftable.WriteRune(' ')
}
fmt.Fprintf(ftable, "%4d", v[i])
ftable.WriteRune(',')
fmt.Fprintf(ftable, "%d,", v[i])
}
fmt.Fprintf(ftable, "\n};\n")
fmt.Fprintf(ftable, "\n}\n")
}
//
@ -3286,7 +3299,7 @@ $$default:
$$nt := $$n
$$pt := $$p
_ = $$pt // guard against "declared and not used"
_ = $$pt // guard against "declared and not used"
$$p -= $$R2[$$n]
$$VAL = $$S[$$p+1]

View File

@ -64,15 +64,13 @@ var retnode2 Node
var retnode Node
var sym string
var vflag bool
%}
%union
{
node Node
vvar *Var
numb int
vval float64
%union {
node Node
vvar *Var
numb int
vval float64
}
%type <node> prog expr expr0 expr1 expr2 expr3 expr4
@ -85,7 +83,6 @@ prog:
':' VAR expr
{
var f int
f = int($2.node.dim[0])
$2.node = $3
$2.node.dim[0] = 1
@ -98,26 +95,23 @@ prog:
| ':' VAR '#'
{
var f, i int
for i=1; i<Ndim; i++ {
for i = 1; i < Ndim; i++ {
if fund[i] == nil {
break
}
}
if i >= Ndim {
Error("too many dimensions")
i = Ndim-1
i = Ndim - 1
}
fund[i] = $2
f = int($2.node.dim[0])
$2.node = one
$2.node.dim[0] = 1
$2.node.dim[i] = 1
if f != 0 {
Errorf("redefinition of %v", $2.name)
} else
if vflag {
} else if vflag {
fmt.Printf("%v\t#\n", $2.name)
}
}
@ -171,8 +165,7 @@ expr2:
| expr2 '^' expr1
{
var i int
for i=1; i<Ndim; i++ {
for i = 1; i < Ndim; i++ {
if $3.dim[i] != 0 {
Error("exponent has units")
$$ = $1
@ -690,7 +683,6 @@ func pname() float64 {
return 0
}
// careful multiplication
// exponents (log) are checked before multiply
func fmul(a, b float64) float64 {