-- | scsynth server command-line options. module Sound.Sc3.Server.Options where import Data.List {- base -} -- | (short-option, long-option, default-value) type Sc3_Opt i = (Char, String, i) -- | Get value from option. sc3_opt_value :: Sc3_Opt i -> i sc3_opt_value (_, _, v) = v -- | Default host name string. sc3_host_name_def :: String sc3_host_name_def = "127.0.0.1" -- | Default port number, either a 'u' or a 't' option is required. sc3_port_def :: Num i => i sc3_port_def = 57110 -- | Protocol is either Udp or Tcp. data Sc3_Protocol = Sc3_Udp | Sc3_Tcp sc3_protocol_def :: Sc3_Protocol sc3_protocol_def = Sc3_Tcp -- | Default port option. sc3_opt_port_def :: Num i => Sc3_Protocol -> Sc3_Opt i sc3_opt_port_def p = case p of Sc3_Udp -> ('u', "udp-port-number", sc3_port_def) Sc3_Tcp -> ('t', "tcp-port-number", sc3_port_def) -- | Sc3 default options. sc3_opt_def :: Num i => Sc3_Protocol -> [Sc3_Opt i] sc3_opt_def p = sc3_opt_port_def p : [ ('a', "number-of-audio-bus-channels", 1024) , ('b', "number-of-sample-buffers", 1024) , -- ,('B',"bind-to-address","127.0.0.1") ('c', "number-of-control-bus-channels", 16384) , ('D', "load-synthdefs?", 1) , ('d', "max-number-of-synth-defs", 1024) , ('i', "number-of-input-bus-channels", 8) , ('l', "max-logins", 64) , ('m', "real-time-memory-size", 8192) , ('n', "max-number-of-nodes", 1024) , ('o', "number-of-output-bus-channels", 8) , ('r', "number-of-random-seeds", 64) , ('R', "publish-to-rendezvous?", 1) , ('S', "hardware-sample-rate", 0) , ('V', "verbosity", 0) , ('w', "number-of-wire-buffers", 64) , ('z', "block-size", 64) , ('Z', "hardware-buffer-size", 0) ] -- | SC3 default options for Udp. sc3_opt_def_udp :: Num i => [Sc3_Opt i] sc3_opt_def_udp = sc3_opt_def Sc3_Udp {- | Is option boolean, ie. 0=False and 1=True. >>> filter sc3_opt_bool sc3_opt_def_udp [('D',"load-synthdefs?",1),('R',"publish-to-rendezvous?",1)] -} sc3_opt_bool :: Sc3_Opt i -> Bool sc3_opt_bool (_, s, _) = last s == '?' -- | Lookup option given either short or long name. sc3_opt_get :: [Sc3_Opt i] -> Either Char String -> Maybe i sc3_opt_get opt k = case k of Left c -> fmap sc3_opt_value (find (\(o, _, _) -> o == c) opt) Right s -> fmap sc3_opt_value (find (\(_, o, _) -> o == s) opt) {- | Set option given either short or long name. >>> sc3_opt_get (sc3_opt_set sc3_opt_def_udp (Left 'w',256)) (Right "number-of-wire-buffers") Just 256 -} sc3_opt_set :: [Sc3_Opt i] -> (Either Char String, i) -> [Sc3_Opt i] sc3_opt_set opt (k, v) = case k of Left x -> map (\(c, s, y) -> if c == x then (c, s, v) else (c, s, y)) opt Right x -> map (\(c, s, y) -> if s == x then (c, s, v) else (c, s, y)) opt {- | Apply set of edits to options. >>> unwords (sc3_opt_arg (sc3_opt_edit sc3_opt_def_udp [(Left 'w',256),(Left 'm',2 ^ 16)])) "-u 57110 -a 1024 -b 1024 -c 16384 -D 1 -d 1024 -i 8 -l 64 -m 65536 -n 1024 -o 8 -r 64 -R 1 -S 0 -V 0 -w 256 -z 64 -Z 0" -} sc3_opt_edit :: [Sc3_Opt i] -> [(Either Char String, i)] -> [Sc3_Opt i] sc3_opt_edit opt edt = case edt of [] -> opt x : rst -> sc3_opt_edit (sc3_opt_set opt x) rst {- | Generate scsynth argument list. >>> unwords (sc3_opt_arg sc3_opt_def_udp) "-u 57110 -a 1024 -b 1024 -c 16384 -D 1 -d 1024 -i 8 -l 64 -m 8192 -n 1024 -o 8 -r 64 -R 1 -S 0 -V 0 -w 64 -z 64 -Z 0" -} sc3_opt_arg :: Show i => [Sc3_Opt i] -> [String] sc3_opt_arg = concatMap (\(c, _, v) -> [['-', c], show v]) {- | Generate arguments for 'System.Process.callProcess' or related functions. >>> let o = sc3_opt_def_udp in sc3_opt_cmd o == ("scsynth", sc3_opt_arg o) True -} sc3_opt_cmd :: Show i => [Sc3_Opt i] -> (FilePath, [String]) sc3_opt_cmd opt = ("scsynth", sc3_opt_arg opt)