+ addDevice :: (Shared [MTaskDevice]) -> Task SerTCP
+ addDevice devices = enterInformation "Device type" []
+ >&^ \sh->whileUnchanged sh $ \mty->case mty of
+ Nothing = viewInformation "No type selected yet" [] "" @! ()
+ Just ty = case ty of
+ TCPDevice = (enterInformation "Name" [] -&&- enterInformation "Hostname" [] -&&- enterInformation "Port" [])
+ >>= \(name, (host, port))->cont name (syncNetworkChannel host port)
+ SerialDevice = (enterInformation "Name" [] -&&- enterTTYSettings)
+ >>= \(name, set)->cont name (syncSerialChannel set encode decode)
+ where
+ cont :: String ((Shared Channels) -> Task ()) -> Task ()
+ cont name synfun = get randomInt
+ @ (\randint->{deviceConnected=Just (name +++ toString randint), deviceName=name, deviceTasks=[], deviceTask=Nothing})
+ >>= \dev->appendTopLevelTask 'DM'.newMap True (let ch = channels dev in process ch -||- synfun ch)
+ >>= \tid->upd (\l->[{dev & deviceTask=Just tid}:l]) devices
+ @! ()
+
+ process :: (Shared Channels) -> Task ()
+ process ch = forever (watch ch >>* [OnValue (
+ ifValue (not o isEmpty o fst3)
+ (\t->upd (appFst3 (const [])) ch >>| process (fst3 t)))])
+ where
+ process :: [MTaskMSGRecv] -> Task ()
+ process [] = treturn ()
+ process [m:ms] = (case m of
+ MTTaskAck i = traceValue (toString m) @! ()
+ MTTaskDelAck i = traceValue (toString m) @! ()
+ MTSDSAck i = traceValue (toString m) @! ()
+ MTSDSDelAck i = traceValue (toString m) @! ()
+ MTPub i val = getSDSRecord i >>= set (toInt val.[0]*256 + toInt val.[1]) o getSDSStore @! ()
+ MTMessage val = traceValue (toString m) @! ()
+ MTEmpty = treturn ()
+ ) >>| process ms
+
+ deviceviewer :: [MTaskDevice] -> [MTaskDeviceStatus]
+ deviceviewer ds = [{MTaskDeviceStatus | name = d.deviceName,
+ connected = if (isNothing d.deviceConnected) False True,
+ tasks = [s +++ toString i\\(s, i)<-d.deviceTasks]}\\d<-ds]
+
+ mapPar :: (a -> Task a) [a] -> Task ()
+ mapPar f l = foldr1 (\x y->f x ||- y) l <<@ ArrangeWithTabs @! ()
+ allAtOnce t = foldr1 (||-) t @! ()
+ //allAtOnce = (flip (@!) ()) o foldr1 (||-)
+
+sendMsg :: [MTaskMSGSend] (Shared ([MTaskMSGRecv],[MTaskMSGSend],Bool)) -> Task ()
+sendMsg m ch = upd (\(r,s,ss)->(r,s ++ m,True)) ch @! ()
+
+syncNetworkChannel :: String Int (Shared ([MTaskMSGRecv], [MTaskMSGSend], Bool)) -> Task ()
+syncNetworkChannel server port channel = catchAll
+ (tcpconnect server port channel {ConnectionHandlers|onConnect=onConnect,whileConnected=whileConnected,onDisconnect=onDisconnect} @! ())
+ (\v->traceValue v @! ())