internal/shaderir/glsl, internal/shaderir/msl: refactoring

This commit is contained in:
Hajime Hoshi 2022-03-11 15:18:38 +09:00
parent e63709a2a5
commit 5715539a0f
2 changed files with 28 additions and 28 deletions

View File

@ -478,8 +478,8 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
lines = append(lines, c.initVariable(p, topBlock, block, block.LocalVarIndexOffset+i, true, level)...) lines = append(lines, c.initVariable(p, topBlock, block, block.LocalVarIndexOffset+i, true, level)...)
} }
var glslExpr func(e *shaderir.Expr) string var expr func(e *shaderir.Expr) string
glslExpr = func(e *shaderir.Expr) string { expr = func(e *shaderir.Expr) string {
switch e.Type { switch e.Type {
case shaderir.NumberExpr: case shaderir.NumberExpr:
return constantToNumberLiteral(e.ConstType, e.Const) return constantToNumberLiteral(e.ConstType, e.Const)
@ -508,26 +508,26 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
default: default:
op = fmt.Sprintf("?(unexpected op: %s)", string(e.Op)) op = fmt.Sprintf("?(unexpected op: %s)", string(e.Op))
} }
return fmt.Sprintf("%s(%s)", op, glslExpr(&e.Exprs[0])) return fmt.Sprintf("%s(%s)", op, expr(&e.Exprs[0]))
case shaderir.Binary: case shaderir.Binary:
if e.Op == shaderir.ModOp && (c.version == GLSLVersionDefault || c.version == GLSLVersionES100) { if e.Op == shaderir.ModOp && (c.version == GLSLVersionDefault || c.version == GLSLVersionES100) {
// '%' is not defined. // '%' is not defined.
return fmt.Sprintf("modInt((%s), (%s))", glslExpr(&e.Exprs[0]), glslExpr(&e.Exprs[1])) return fmt.Sprintf("modInt((%s), (%s))", expr(&e.Exprs[0]), expr(&e.Exprs[1]))
} }
return fmt.Sprintf("(%s) %s (%s)", glslExpr(&e.Exprs[0]), e.Op, glslExpr(&e.Exprs[1])) return fmt.Sprintf("(%s) %s (%s)", expr(&e.Exprs[0]), e.Op, expr(&e.Exprs[1]))
case shaderir.Selection: case shaderir.Selection:
return fmt.Sprintf("(%s) ? (%s) : (%s)", glslExpr(&e.Exprs[0]), glslExpr(&e.Exprs[1]), glslExpr(&e.Exprs[2])) return fmt.Sprintf("(%s) ? (%s) : (%s)", expr(&e.Exprs[0]), expr(&e.Exprs[1]), expr(&e.Exprs[2]))
case shaderir.Call: case shaderir.Call:
var args []string var args []string
for _, exp := range e.Exprs[1:] { for _, exp := range e.Exprs[1:] {
args = append(args, glslExpr(&exp)) args = append(args, expr(&exp))
} }
// Using parentheses at the callee is illegal. // Using parentheses at the callee is illegal.
return fmt.Sprintf("%s(%s)", glslExpr(&e.Exprs[0]), strings.Join(args, ", ")) return fmt.Sprintf("%s(%s)", expr(&e.Exprs[0]), strings.Join(args, ", "))
case shaderir.FieldSelector: case shaderir.FieldSelector:
return fmt.Sprintf("(%s).%s", glslExpr(&e.Exprs[0]), glslExpr(&e.Exprs[1])) return fmt.Sprintf("(%s).%s", expr(&e.Exprs[0]), expr(&e.Exprs[1]))
case shaderir.Index: case shaderir.Index:
return fmt.Sprintf("(%s)[%s]", glslExpr(&e.Exprs[0]), glslExpr(&e.Exprs[1])) return fmt.Sprintf("(%s)[%s]", expr(&e.Exprs[0]), expr(&e.Exprs[1]))
default: default:
return fmt.Sprintf("?(unexpected expr: %d)", e.Type) return fmt.Sprintf("?(unexpected expr: %d)", e.Type)
} }
@ -537,7 +537,7 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
for _, s := range block.Stmts { for _, s := range block.Stmts {
switch s.Type { switch s.Type {
case shaderir.ExprStmt: case shaderir.ExprStmt:
lines = append(lines, fmt.Sprintf("%s%s;", idt, glslExpr(&s.Exprs[0]))) lines = append(lines, fmt.Sprintf("%s%s;", idt, expr(&s.Exprs[0])))
case shaderir.BlockStmt: case shaderir.BlockStmt:
lines = append(lines, idt+"{") lines = append(lines, idt+"{")
lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...) lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...)
@ -548,16 +548,16 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
if lhs.Type == shaderir.LocalVariable { if lhs.Type == shaderir.LocalVariable {
if t := p.LocalVariableType(topBlock, block, lhs.Index); t.Main == shaderir.Array { if t := p.LocalVariableType(topBlock, block, lhs.Index); t.Main == shaderir.Array {
for i := 0; i < t.Length; i++ { for i := 0; i < t.Length; i++ {
lines = append(lines, fmt.Sprintf("%[1]s%[2]s[%[3]d] = %[4]s[%[3]d];", idt, glslExpr(&lhs), i, glslExpr(&rhs))) lines = append(lines, fmt.Sprintf("%[1]s%[2]s[%[3]d] = %[4]s[%[3]d];", idt, expr(&lhs), i, expr(&rhs)))
} }
continue continue
} }
} }
lines = append(lines, fmt.Sprintf("%s%s = %s;", idt, glslExpr(&lhs), glslExpr(&rhs))) lines = append(lines, fmt.Sprintf("%s%s = %s;", idt, expr(&lhs), expr(&rhs)))
case shaderir.Init: case shaderir.Init:
lines = append(lines, c.initVariable(p, topBlock, block, s.InitIndex, false, level)...) lines = append(lines, c.initVariable(p, topBlock, block, s.InitIndex, false, level)...)
case shaderir.If: case shaderir.If:
lines = append(lines, fmt.Sprintf("%sif (%s) {", idt, glslExpr(&s.Exprs[0]))) lines = append(lines, fmt.Sprintf("%sif (%s) {", idt, expr(&s.Exprs[0])))
lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...) lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...)
if len(s.Blocks) > 1 { if len(s.Blocks) > 1 {
lines = append(lines, fmt.Sprintf("%s} else {", idt)) lines = append(lines, fmt.Sprintf("%s} else {", idt))
@ -614,7 +614,7 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
if len(s.Exprs) == 0 { if len(s.Exprs) == 0 {
lines = append(lines, idt+"return;") lines = append(lines, idt+"return;")
} else { } else {
lines = append(lines, fmt.Sprintf("%sreturn %s;", idt, glslExpr(&s.Exprs[0]))) lines = append(lines, fmt.Sprintf("%sreturn %s;", idt, expr(&s.Exprs[0])))
} }
case shaderir.Discard: case shaderir.Discard:
lines = append(lines, idt+"discard;") lines = append(lines, idt+"discard;")

View File

@ -345,8 +345,8 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
} }
} }
var metalExpr func(e *shaderir.Expr) string var expr func(e *shaderir.Expr) string
metalExpr = func(e *shaderir.Expr) string { expr = func(e *shaderir.Expr) string {
switch e.Type { switch e.Type {
case shaderir.NumberExpr: case shaderir.NumberExpr:
return constantToNumberLiteral(e.ConstType, e.Const) return constantToNumberLiteral(e.ConstType, e.Const)
@ -375,11 +375,11 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
default: default:
op = fmt.Sprintf("?(unexpected op: %s)", string(e.Op)) op = fmt.Sprintf("?(unexpected op: %s)", string(e.Op))
} }
return fmt.Sprintf("%s(%s)", op, metalExpr(&e.Exprs[0])) return fmt.Sprintf("%s(%s)", op, expr(&e.Exprs[0]))
case shaderir.Binary: case shaderir.Binary:
return fmt.Sprintf("(%s) %s (%s)", metalExpr(&e.Exprs[0]), e.Op, metalExpr(&e.Exprs[1])) return fmt.Sprintf("(%s) %s (%s)", expr(&e.Exprs[0]), e.Op, expr(&e.Exprs[1]))
case shaderir.Selection: case shaderir.Selection:
return fmt.Sprintf("(%s) ? (%s) : (%s)", metalExpr(&e.Exprs[0]), metalExpr(&e.Exprs[1]), metalExpr(&e.Exprs[2])) return fmt.Sprintf("(%s) ? (%s) : (%s)", expr(&e.Exprs[0]), expr(&e.Exprs[1]), expr(&e.Exprs[2]))
case shaderir.Call: case shaderir.Call:
callee := e.Exprs[0] callee := e.Exprs[0]
var args []string var args []string
@ -392,16 +392,16 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
} }
} }
for _, exp := range e.Exprs[1:] { for _, exp := range e.Exprs[1:] {
args = append(args, metalExpr(&exp)) args = append(args, expr(&exp))
} }
if callee.Type == shaderir.BuiltinFuncExpr && callee.BuiltinFunc == shaderir.Texture2DF { if callee.Type == shaderir.BuiltinFuncExpr && callee.BuiltinFunc == shaderir.Texture2DF {
return fmt.Sprintf("%s.sample(texture_sampler, %s)", args[0], strings.Join(args[1:], ", ")) return fmt.Sprintf("%s.sample(texture_sampler, %s)", args[0], strings.Join(args[1:], ", "))
} }
return fmt.Sprintf("%s(%s)", metalExpr(&callee), strings.Join(args, ", ")) return fmt.Sprintf("%s(%s)", expr(&callee), strings.Join(args, ", "))
case shaderir.FieldSelector: case shaderir.FieldSelector:
return fmt.Sprintf("(%s).%s", metalExpr(&e.Exprs[0]), metalExpr(&e.Exprs[1])) return fmt.Sprintf("(%s).%s", expr(&e.Exprs[0]), expr(&e.Exprs[1]))
case shaderir.Index: case shaderir.Index:
return fmt.Sprintf("(%s)[%s]", metalExpr(&e.Exprs[0]), metalExpr(&e.Exprs[1])) return fmt.Sprintf("(%s)[%s]", expr(&e.Exprs[0]), expr(&e.Exprs[1]))
default: default:
return fmt.Sprintf("?(unexpected expr: %d)", e.Type) return fmt.Sprintf("?(unexpected expr: %d)", e.Type)
} }
@ -410,13 +410,13 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
for _, s := range block.Stmts { for _, s := range block.Stmts {
switch s.Type { switch s.Type {
case shaderir.ExprStmt: case shaderir.ExprStmt:
lines = append(lines, fmt.Sprintf("%s%s;", idt, metalExpr(&s.Exprs[0]))) lines = append(lines, fmt.Sprintf("%s%s;", idt, expr(&s.Exprs[0])))
case shaderir.BlockStmt: case shaderir.BlockStmt:
lines = append(lines, idt+"{") lines = append(lines, idt+"{")
lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...) lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...)
lines = append(lines, idt+"}") lines = append(lines, idt+"}")
case shaderir.Assign: case shaderir.Assign:
lines = append(lines, fmt.Sprintf("%s%s = %s;", idt, metalExpr(&s.Exprs[0]), metalExpr(&s.Exprs[1]))) lines = append(lines, fmt.Sprintf("%s%s = %s;", idt, expr(&s.Exprs[0]), expr(&s.Exprs[1])))
case shaderir.Init: case shaderir.Init:
init := true init := true
if topBlock == p.VertexFunc.Block { if topBlock == p.VertexFunc.Block {
@ -432,7 +432,7 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
lines = append(lines, c.initVariable(p, topBlock, block, s.InitIndex, false, level)...) lines = append(lines, c.initVariable(p, topBlock, block, s.InitIndex, false, level)...)
} }
case shaderir.If: case shaderir.If:
lines = append(lines, fmt.Sprintf("%sif (%s) {", idt, metalExpr(&s.Exprs[0]))) lines = append(lines, fmt.Sprintf("%sif (%s) {", idt, expr(&s.Exprs[0])))
lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...) lines = append(lines, c.block(p, topBlock, s.Blocks[0], level+1)...)
if len(s.Blocks) > 1 { if len(s.Blocks) > 1 {
lines = append(lines, fmt.Sprintf("%s} else {", idt)) lines = append(lines, fmt.Sprintf("%s} else {", idt))
@ -494,7 +494,7 @@ func (c *compileContext) block(p *shaderir.Program, topBlock, block *shaderir.Bl
case len(s.Exprs) == 0: case len(s.Exprs) == 0:
lines = append(lines, idt+"return;") lines = append(lines, idt+"return;")
default: default:
lines = append(lines, fmt.Sprintf("%sreturn %s;", idt, metalExpr(&s.Exprs[0]))) lines = append(lines, fmt.Sprintf("%sreturn %s;", idt, expr(&s.Exprs[0])))
} }
case shaderir.Discard: case shaderir.Discard:
lines = append(lines, idt+"discard;") lines = append(lines, idt+"discard;")