mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-11 19:48:54 +01:00
internal/shaderir: refactoring
This commit is contained in:
parent
e2c25dbc6d
commit
7dbb078a9e
@ -19,7 +19,6 @@ import (
|
|||||||
"go/constant"
|
"go/constant"
|
||||||
"go/token"
|
"go/token"
|
||||||
"regexp"
|
"regexp"
|
||||||
"sort"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
"github.com/hajimehoshi/ebiten/v2/internal/shaderir"
|
||||||
@ -99,12 +98,6 @@ func Compile(p *shaderir.Program, version GLSLVersion) (vertexShader, fragmentSh
|
|||||||
structNames: map[string]string{},
|
structNames: map[string]string{},
|
||||||
}
|
}
|
||||||
|
|
||||||
indexToFunc := map[int]*shaderir.Func{}
|
|
||||||
for _, f := range p.Funcs {
|
|
||||||
f := f
|
|
||||||
indexToFunc[f.Index] = &f
|
|
||||||
}
|
|
||||||
|
|
||||||
// Vertex func
|
// Vertex func
|
||||||
var vslines []string
|
var vslines []string
|
||||||
{
|
{
|
||||||
@ -136,12 +129,7 @@ func Compile(p *shaderir.Program, version GLSLVersion) (vertexShader, fragmentSh
|
|||||||
|
|
||||||
var funcs []*shaderir.Func
|
var funcs []*shaderir.Func
|
||||||
if p.VertexFunc.Block != nil {
|
if p.VertexFunc.Block != nil {
|
||||||
indices := p.ReachableFuncIndicesFromVertexShader()
|
funcs = p.ReachableFuncsFromVertexShader()
|
||||||
sort.Ints(indices)
|
|
||||||
funcs = make([]*shaderir.Func, 0, len(indices))
|
|
||||||
for _, idx := range indices {
|
|
||||||
funcs = append(funcs, indexToFunc[idx])
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
// When a vertex entry point is not defined, allow to put all the functions. This is useful for testing.
|
// When a vertex entry point is not defined, allow to put all the functions. This is useful for testing.
|
||||||
funcs = make([]*shaderir.Func, 0, len(p.Funcs))
|
funcs = make([]*shaderir.Func, 0, len(p.Funcs))
|
||||||
@ -234,12 +222,7 @@ func Compile(p *shaderir.Program, version GLSLVersion) (vertexShader, fragmentSh
|
|||||||
|
|
||||||
var funcs []*shaderir.Func
|
var funcs []*shaderir.Func
|
||||||
if p.VertexFunc.Block != nil {
|
if p.VertexFunc.Block != nil {
|
||||||
indices := p.ReachableFuncIndicesFromFragmentShader()
|
funcs = p.ReachableFuncsFromFragmentShader()
|
||||||
sort.Ints(indices)
|
|
||||||
funcs = make([]*shaderir.Func, 0, len(indices))
|
|
||||||
for _, idx := range indices {
|
|
||||||
funcs = append(funcs, indexToFunc[idx])
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
// When a fragment entry point is not defined, allow to put all the functions. This is useful for testing.
|
// When a fragment entry point is not defined, allow to put all the functions. This is useful for testing.
|
||||||
funcs = make([]*shaderir.Func, 0, len(p.Funcs))
|
funcs = make([]*shaderir.Func, 0, len(p.Funcs))
|
||||||
|
@ -18,6 +18,7 @@ package shaderir
|
|||||||
import (
|
import (
|
||||||
"go/constant"
|
"go/constant"
|
||||||
"go/token"
|
"go/token"
|
||||||
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -363,22 +364,28 @@ func IsValidSwizzling(s string) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Program) ReachableFuncIndicesFromVertexShader() []int {
|
func (p *Program) ReachableFuncsFromVertexShader() []*Func {
|
||||||
return p.reachableFuncIndicesFromBlockEntryPoint(p.VertexFunc.Block)
|
return p.reachableFuncsFromBlockEntryPoint(p.VertexFunc.Block)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Program) ReachableFuncIndicesFromFragmentShader() []int {
|
func (p *Program) ReachableFuncsFromFragmentShader() []*Func {
|
||||||
return p.reachableFuncIndicesFromBlockEntryPoint(p.FragmentFunc.Block)
|
return p.reachableFuncsFromBlockEntryPoint(p.FragmentFunc.Block)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Program) reachableFuncIndicesFromBlockEntryPoint(b *Block) []int {
|
func (p *Program) reachableFuncsFromBlockEntryPoint(b *Block) []*Func {
|
||||||
indexToFunc := map[int]*Func{}
|
indexToFunc := map[int]*Func{}
|
||||||
for _, f := range p.Funcs {
|
for _, f := range p.Funcs {
|
||||||
f := f
|
f := f
|
||||||
indexToFunc[f.Index] = &f
|
indexToFunc[f.Index] = &f
|
||||||
}
|
}
|
||||||
visited := map[int]struct{}{}
|
visited := map[int]struct{}{}
|
||||||
return reachableFuncIndicesFromBlock(b, indexToFunc, visited)
|
indices := reachableFuncIndicesFromBlock(b, indexToFunc, visited)
|
||||||
|
sort.Ints(indices)
|
||||||
|
funcs := make([]*Func, 0, len(indices))
|
||||||
|
for _, i := range indices {
|
||||||
|
funcs = append(funcs, indexToFunc[i])
|
||||||
|
}
|
||||||
|
return funcs
|
||||||
}
|
}
|
||||||
|
|
||||||
func reachableFuncIndicesFromBlock(b *Block, indexToFunc map[int]*Func, visited map[int]struct{}) []int {
|
func reachableFuncIndicesFromBlock(b *Block, indexToFunc map[int]*Func, visited map[int]struct{}) []int {
|
||||||
|
Loading…
Reference in New Issue
Block a user