State.hs 807 B

1234567891011121314151617181920212223242526272829303132333435363738
  1. module State where
  2. import Data.Sequence (Seq)
  3. import qualified Data.Sequence as S
  4. import Data.Text (Text)
  5. data Instrument = Instrument
  6. { instrSource :: Oscillator }
  7. deriving (Eq, Show)
  8. newtype InstrRef = InstrRef { fromInstrRef :: Int }
  9. deriving (Eq, Show)
  10. data Oscillator
  11. = OscSine
  12. | OscSquare
  13. deriving (Eq, Show)
  14. data Note = Note
  15. { noteCents :: Double
  16. , noteAppearance :: Text
  17. } deriving (Eq, Show)
  18. newtype NoteRef = NoteRef { fromNoteRef :: Int }
  19. deriving (Eq, Show)
  20. data State = State
  21. { stateFile :: Maybe FilePath
  22. , stateInstruments :: Seq Instrument
  23. , stateScale :: Seq Note
  24. } deriving (Show)
  25. newState :: State
  26. newState = State
  27. { stateFile = Nothing
  28. , stateInstruments = S.empty
  29. , stateScale = S.empty
  30. }