mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-11 19:48:54 +01:00
shaderir: Use auto names for variables
This commit is contained in:
parent
ea0f2c9085
commit
71ee622997
@ -38,14 +38,14 @@ func (p *Program) Glsl() string {
|
||||
p.structTypes = nil
|
||||
|
||||
var lines []string
|
||||
for _, u := range p.Uniforms {
|
||||
lines = append(lines, fmt.Sprintf("uniform %s;", p.glslVarDecl(&u.Type, u.Name)))
|
||||
for i, t := range p.Uniforms {
|
||||
lines = append(lines, fmt.Sprintf("uniform %s;", p.glslVarDecl(&t, fmt.Sprintf("U%d", i))))
|
||||
}
|
||||
for _, a := range p.Attributes {
|
||||
lines = append(lines, fmt.Sprintf("attribute %s;", p.glslVarDecl(&a.Type, a.Name)))
|
||||
for i, t := range p.Attributes {
|
||||
lines = append(lines, fmt.Sprintf("attribute %s;", p.glslVarDecl(&t, fmt.Sprintf("A%d", i))))
|
||||
}
|
||||
for _, v := range p.Varyings {
|
||||
lines = append(lines, fmt.Sprintf("varying %s;", p.glslVarDecl(&v.Type, v.Name)))
|
||||
for i, t := range p.Varyings {
|
||||
lines = append(lines, fmt.Sprintf("varying %s;", p.glslVarDecl(&t, fmt.Sprintf("V%d", i))))
|
||||
}
|
||||
for _, f := range p.Funcs {
|
||||
lines = append(lines, p.glslFunc(&f)...)
|
||||
@ -121,6 +121,19 @@ func (p *Program) glslBlock(b *Block, f *Func, level int, localVarIndex int) []s
|
||||
switch e.Type {
|
||||
case Literal:
|
||||
return e.Value
|
||||
case VarName:
|
||||
switch e.Variable.Type {
|
||||
case Uniform:
|
||||
return fmt.Sprintf("U%d", e.Variable.Index)
|
||||
case Attribute:
|
||||
return fmt.Sprintf("A%d", e.Variable.Index)
|
||||
case Varying:
|
||||
return fmt.Sprintf("V%d", e.Variable.Index)
|
||||
case Local:
|
||||
return fmt.Sprintf("l%d", e.Variable.Index)
|
||||
default:
|
||||
return fmt.Sprintf("?(unexpected variable type: %d)", e.Variable.Type)
|
||||
}
|
||||
case Ident:
|
||||
return e.Value
|
||||
case Unary:
|
||||
|
@ -20,6 +20,31 @@ import (
|
||||
. "github.com/hajimehoshi/ebiten/internal/shaderir"
|
||||
)
|
||||
|
||||
func assignStmt(lhs Expr, rhs Expr) Stmt {
|
||||
return Stmt{
|
||||
Type: Assign,
|
||||
Exprs: []Expr{lhs, rhs},
|
||||
}
|
||||
}
|
||||
|
||||
func varNameExpr(vt VariableType, index int) Expr {
|
||||
return Expr{
|
||||
Type: VarName,
|
||||
Variable: Variable{
|
||||
Type: vt,
|
||||
Index: index,
|
||||
},
|
||||
}
|
||||
}
|
||||
|
||||
func binaryExpr(op Op, exprs ...Expr) Expr {
|
||||
return Expr{
|
||||
Type: Binary,
|
||||
Op: op,
|
||||
Exprs: exprs,
|
||||
}
|
||||
}
|
||||
|
||||
func TestOutput(t *testing.T) {
|
||||
tests := []struct {
|
||||
Name string
|
||||
@ -34,11 +59,8 @@ func TestOutput(t *testing.T) {
|
||||
{
|
||||
Name: "Uniform",
|
||||
Program: Program{
|
||||
Uniforms: []Variable{
|
||||
{
|
||||
Name: "U0",
|
||||
Type: Type{Main: Float},
|
||||
},
|
||||
Uniforms: []Type{
|
||||
{Main: Float},
|
||||
},
|
||||
},
|
||||
Glsl: `uniform float U0;`,
|
||||
@ -46,10 +68,8 @@ func TestOutput(t *testing.T) {
|
||||
{
|
||||
Name: "UniformStruct",
|
||||
Program: Program{
|
||||
Uniforms: []Variable{
|
||||
Uniforms: []Type{
|
||||
{
|
||||
Name: "U0",
|
||||
Type: Type{
|
||||
Main: Struct,
|
||||
Sub: []Type{
|
||||
{Main: Float},
|
||||
@ -57,7 +77,6 @@ func TestOutput(t *testing.T) {
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
Glsl: `struct S0 {
|
||||
float M0;
|
||||
};
|
||||
@ -66,23 +85,14 @@ uniform S0 U0;`,
|
||||
{
|
||||
Name: "Vars",
|
||||
Program: Program{
|
||||
Uniforms: []Variable{
|
||||
{
|
||||
Name: "U0",
|
||||
Type: Type{Main: Float},
|
||||
Uniforms: []Type{
|
||||
{Main: Float},
|
||||
},
|
||||
Attributes: []Type{
|
||||
{Main: Vec2},
|
||||
},
|
||||
Attributes: []Variable{
|
||||
{
|
||||
Name: "A0",
|
||||
Type: Type{Main: Vec2},
|
||||
},
|
||||
},
|
||||
Varyings: []Variable{
|
||||
{
|
||||
Name: "V0",
|
||||
Type: Type{Main: Vec3},
|
||||
},
|
||||
Varyings: []Type{
|
||||
{Main: Vec3},
|
||||
},
|
||||
},
|
||||
Glsl: `uniform float U0;
|
||||
@ -212,29 +222,13 @@ varying vec3 V0;`,
|
||||
},
|
||||
Block: Block{
|
||||
Stmts: []Stmt{
|
||||
{
|
||||
Type: Assign,
|
||||
Exprs: []Expr{
|
||||
{
|
||||
Type: Ident,
|
||||
Value: "l2",
|
||||
},
|
||||
{
|
||||
Type: Binary,
|
||||
Op: Add,
|
||||
Exprs: []Expr{
|
||||
{
|
||||
Type: Ident,
|
||||
Value: "l0",
|
||||
},
|
||||
{
|
||||
Type: Ident,
|
||||
Value: "l1",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
assignStmt(
|
||||
varNameExpr(Local, 2),
|
||||
binaryExpr(Add,
|
||||
varNameExpr(Local, 0),
|
||||
varNameExpr(Local, 1),
|
||||
),
|
||||
),
|
||||
},
|
||||
},
|
||||
},
|
||||
|
@ -15,9 +15,9 @@
|
||||
package shaderir
|
||||
|
||||
type Program struct {
|
||||
Uniforms []Variable
|
||||
Attributes []Variable
|
||||
Varyings []Variable
|
||||
Uniforms []Type
|
||||
Attributes []Type
|
||||
Varyings []Type
|
||||
Funcs []Func
|
||||
VertexEntry string
|
||||
FragmentEntry string
|
||||
@ -26,11 +26,6 @@ type Program struct {
|
||||
structTypes []Type
|
||||
}
|
||||
|
||||
type Variable struct {
|
||||
Name string
|
||||
Type Type
|
||||
}
|
||||
|
||||
type Func struct {
|
||||
Name string
|
||||
InParams []Type
|
||||
@ -71,6 +66,7 @@ const (
|
||||
type Expr struct {
|
||||
Type ExprType
|
||||
Exprs []Expr
|
||||
Variable Variable
|
||||
Value string
|
||||
Op Op
|
||||
}
|
||||
@ -79,6 +75,7 @@ type ExprType int
|
||||
|
||||
const (
|
||||
Literal ExprType = iota
|
||||
VarName
|
||||
Ident
|
||||
Unary
|
||||
Binary
|
||||
@ -87,6 +84,20 @@ const (
|
||||
Index
|
||||
)
|
||||
|
||||
type Variable struct {
|
||||
Type VariableType
|
||||
Index int
|
||||
}
|
||||
|
||||
type VariableType int
|
||||
|
||||
const (
|
||||
Uniform VariableType = iota
|
||||
Attribute
|
||||
Varying
|
||||
Local
|
||||
)
|
||||
|
||||
type Op string
|
||||
|
||||
const (
|
||||
|
Loading…
Reference in New Issue
Block a user