X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=Devices%2FmTaskDevice.dcl;h=f254a22f2f16b20552580d40019b004b93397f2c;hb=a2b8b2a0de173f92092bf6cbbed23551e674ca3c;hp=f21e6540887f6dd56fbe96814be7d62b1a404987;hpb=7fec7868123d56d410e807042cb3e031ebda12b9;p=mTask.git diff --git a/Devices/mTaskDevice.dcl b/Devices/mTaskDevice.dcl index f21e654..f254a22 100644 --- a/Devices/mTaskDevice.dcl +++ b/Devices/mTaskDevice.dcl @@ -4,6 +4,8 @@ from Data.Maybe import :: Maybe import iTasks import Devices.mTaskSerial import Devices.mTaskTCP +import Utils.SDS +import Tasks.mTaskTask import mTaskInterpret import Generics.gCons import iTasksTTY @@ -12,8 +14,8 @@ derive class iTask MTaskDevice, MTaskResource, MTaskMSGRecv, MTaskMSGSend derive conses MTaskResource, TCPSettings derive consName MTaskResource, TCPSettings -channels :: MTaskDevice -> Shared Channels +channels :: MTaskDevice -> Shared Channels :: Channels :== ([MTaskMSGRecv], [MTaskMSGSend], Bool) :: MTaskResource @@ -22,18 +24,23 @@ channels :: MTaskDevice -> Shared Channels :: MTaskDevice = { deviceTask :: Maybe TaskId + ,deviceError :: Maybe String ,deviceChannels :: String ,deviceName :: String - ,deviceTasks :: [(String, Int)] + ,deviceTasks :: [MTaskTask] ,deviceData :: MTaskResource } +instance == MTaskDevice + 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 :: (Map String (Main (ByteCode () Stmt))) String (MTaskDevice, Int) -> Task () +sendToDevice :: String (Main (ByteCode () Stmt)) (MTaskDevice, MTaskInterval) -> Task () -deviceTaskDelete :: MTaskDevice Int -> Task () +deviceTaskDelete :: MTaskDevice MTaskTask -> Task () deviceTaskAcked :: MTaskDevice Int -> Task () deviceTaskDeleteAcked :: MTaskDevice Int -> Task ()