move script loading to root
This commit is contained in:
parent
5c95c5346f
commit
86ef3a0e82
45
cmd/root.go
45
cmd/root.go
|
@ -17,6 +17,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
|
@ -27,6 +29,31 @@ import (
|
||||||
var preset string
|
var preset string
|
||||||
var scriptPath string
|
var scriptPath string
|
||||||
|
|
||||||
|
type script struct {
|
||||||
|
Presets []string
|
||||||
|
Times []float64
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *script) load(path string) error {
|
||||||
|
f, err := os.Open(path)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
data, err := io.ReadAll(f)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = json.Unmarshal(data, s)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func handleWindowEvent(event *sdl.WindowEvent, m *milkDropWindow) {
|
func handleWindowEvent(event *sdl.WindowEvent, m *milkDropWindow) {
|
||||||
switch event.Event {
|
switch event.Event {
|
||||||
case sdl.WINDOWEVENT_RESIZED:
|
case sdl.WINDOWEVENT_RESIZED:
|
||||||
|
@ -67,22 +94,30 @@ func milkbucket(cmd *cobra.Command, args []string) {
|
||||||
log.Fatal("nothing to read from stdin")
|
log.Fatal("nothing to read from stdin")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var presets []string
|
||||||
|
|
||||||
|
if preset != "" {
|
||||||
|
presets = []string{preset}
|
||||||
|
}
|
||||||
|
|
||||||
|
if scriptPath != "" {
|
||||||
|
var s script
|
||||||
|
s.load(scriptPath)
|
||||||
|
presets = s.Presets
|
||||||
|
}
|
||||||
|
|
||||||
err = sdl.Init(sdl.INIT_VIDEO)
|
err = sdl.Init(sdl.INIT_VIDEO)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
defer sdl.Quit()
|
defer sdl.Quit()
|
||||||
|
|
||||||
m, err := newMilkDropWindow(800, 600, scriptPath)
|
m, err := newMilkDropWindow(800, 600, presets)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
defer m.destroy()
|
defer m.destroy()
|
||||||
|
|
||||||
if preset != "" {
|
|
||||||
m.setupPresets([]string{preset})
|
|
||||||
}
|
|
||||||
|
|
||||||
m.loadPreset(false)
|
m.loadPreset(false)
|
||||||
|
|
||||||
running := true
|
running := true
|
||||||
|
|
|
@ -26,7 +26,6 @@ import "C"
|
||||||
import (
|
import (
|
||||||
"container/ring"
|
"container/ring"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"encoding/json"
|
|
||||||
"errors"
|
"errors"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
|
@ -44,34 +43,6 @@ type milkDropWindow struct {
|
||||||
preset *ring.Ring
|
preset *ring.Ring
|
||||||
}
|
}
|
||||||
|
|
||||||
type script struct {
|
|
||||||
Presets []string
|
|
||||||
Times []float64
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *milkDropWindow) loadScript(scriptPath string) error {
|
|
||||||
f, err := os.Open(scriptPath)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
defer f.Close()
|
|
||||||
|
|
||||||
data, err := io.ReadAll(f)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
var s script
|
|
||||||
err = json.Unmarshal(data, &s)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
m.setupPresets(s.Presets)
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *milkDropWindow) setupPresets(presets []string) {
|
func (m *milkDropWindow) setupPresets(presets []string) {
|
||||||
m.preset = ring.New(len(presets))
|
m.preset = ring.New(len(presets))
|
||||||
for _, preset := range presets {
|
for _, preset := range presets {
|
||||||
|
@ -90,16 +61,11 @@ func (m *milkDropWindow) prevPreset() {
|
||||||
m.loadPreset(true)
|
m.loadPreset(true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func newMilkDropWindow(width, height int32, scriptPath string) (*milkDropWindow, error) {
|
func newMilkDropWindow(width, height int32, presets []string) (*milkDropWindow, error) {
|
||||||
var m milkDropWindow
|
var m milkDropWindow
|
||||||
var err error
|
var err error
|
||||||
|
|
||||||
if scriptPath != "" {
|
m.setupPresets(presets)
|
||||||
err = m.loadScript(scriptPath)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m.window, err = sdl.CreateWindow("milkbucket", sdl.WINDOWPOS_UNDEFINED, sdl.WINDOWPOS_UNDEFINED, width, height, sdl.WINDOW_OPENGL|sdl.WINDOW_RESIZABLE)
|
m.window, err = sdl.CreateWindow("milkbucket", sdl.WINDOWPOS_UNDEFINED, sdl.WINDOWPOS_UNDEFINED, width, height, sdl.WINDOW_OPENGL|sdl.WINDOW_RESIZABLE)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in New Issue