import iTasks
import Devices.mTaskSerial
import Devices.mTaskTCP
+import Utils.SDS
import Tasks.mTaskTask
import mTaskInterpret
import Generics.gCons
:: MTaskDevice = {
deviceTask :: Maybe TaskId
+ ,deviceError :: Maybe String
,deviceChannels :: String
,deviceName :: String
,deviceTasks :: [MTaskTask]
class MTaskDuplex a where
synFun :: a (Shared Channels) -> Task ()
+startupDevices :: Task [MTaskDevice]
+connectDevice :: (MTaskDevice (Shared Channels) -> Task ()) MTaskDevice -> Task ()
manageDevices :: (MTaskDevice (Shared Channels) -> Task ()) [MTaskDevice] -> Task ()
sendToDevice :: String (Main (ByteCode () Stmt)) (MTaskDevice, MTaskInterval) -> Task ()
sendMessages :: [MTaskMSGSend] -> (MTaskDevice -> Task Channels)