mirror of
https://github.com/ilyakooo0/urbit.git
synced 2024-12-16 10:49:26 +03:00
Make king shutdown cleanly on a new line.
This makes canceling the persistance thread not rethrow an exception which kills the process, and makes the terminal driver write one final newline before giving control back to the terminal so the bash prompt writes to its own line.
This commit is contained in:
parent
721945d1ba
commit
7c6a3c2300
@ -7,18 +7,18 @@ module Vere.Pier
|
|||||||
import UrbitPrelude
|
import UrbitPrelude
|
||||||
|
|
||||||
import Arvo
|
import Arvo
|
||||||
import Vere.Pier.Types
|
|
||||||
import System.Random
|
import System.Random
|
||||||
|
import Vere.Pier.Types
|
||||||
|
|
||||||
import System.Directory (createDirectoryIfMissing)
|
import System.Directory (createDirectoryIfMissing)
|
||||||
import System.Posix.Files (ownerModes, setFileMode)
|
import System.Posix.Files (ownerModes, setFileMode)
|
||||||
import Vere.Ames (ames)
|
import Vere.Ames (ames)
|
||||||
import Vere.Behn (behn)
|
import Vere.Behn (behn)
|
||||||
|
import Vere.Clay (clay)
|
||||||
import Vere.Http.Client (client)
|
import Vere.Http.Client (client)
|
||||||
import Vere.Http.Server (serv)
|
import Vere.Http.Server (serv)
|
||||||
import Vere.Log (EventLog)
|
import Vere.Log (EventLog)
|
||||||
import Vere.Serf (Serf, sStderr, SerfState(..), doJob)
|
import Vere.Serf (Serf, SerfState(..), doJob, sStderr)
|
||||||
import Vere.Clay (clay)
|
|
||||||
import Vere.Term
|
import Vere.Term
|
||||||
|
|
||||||
import qualified System.Entropy as Ent
|
import qualified System.Entropy as Ent
|
||||||
@ -329,16 +329,14 @@ instance Exception PersistExn where
|
|||||||
, "\tExpected " <> show expected <> " but got " <> show got
|
, "\tExpected " <> show expected <> " but got " <> show got
|
||||||
]
|
]
|
||||||
|
|
||||||
runPersist :: EventLog
|
runPersist :: ∀e. HasLogFunc e
|
||||||
|
=> EventLog
|
||||||
-> TQueue (Job, FX)
|
-> TQueue (Job, FX)
|
||||||
-> (FX -> STM ())
|
-> (FX -> STM ())
|
||||||
-> RAcquire e (Async ())
|
-> RAcquire e (Async ())
|
||||||
runPersist log inpQ out =
|
runPersist log inpQ out =
|
||||||
mkRAcquire runThread cancelWait
|
mkRAcquire runThread cancel
|
||||||
where
|
where
|
||||||
cancelWait :: Async () -> RIO e ()
|
|
||||||
cancelWait tid = cancel tid >> wait tid
|
|
||||||
|
|
||||||
runThread :: RIO e (Async ())
|
runThread :: RIO e (Async ())
|
||||||
runThread = asyncBound $ forever $ do
|
runThread = asyncBound $ forever $ do
|
||||||
writs <- atomically getBatchFromQueue
|
writs <- atomically getBatchFromQueue
|
||||||
|
@ -55,6 +55,7 @@ data TerminalSystem e = TerminalSystem
|
|||||||
data Private = Private
|
data Private = Private
|
||||||
{ pReaderThread :: Async ()
|
{ pReaderThread :: Async ()
|
||||||
, pWriterThread :: Async ()
|
, pWriterThread :: Async ()
|
||||||
|
, pTerminal :: Terminal
|
||||||
, pPreviousConfiguration :: TerminalAttributes
|
, pPreviousConfiguration :: TerminalAttributes
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -101,11 +102,11 @@ initializeLocalTerminal = do
|
|||||||
start = do
|
start = do
|
||||||
-- Initialize the writing side of the terminal
|
-- Initialize the writing side of the terminal
|
||||||
--
|
--
|
||||||
t <- io $ setupTermFromEnv
|
pTerminal <- io $ setupTermFromEnv
|
||||||
-- TODO: We still need to actually get the size from the terminal somehow.
|
-- TODO: We still need to actually get the size from the terminal somehow.
|
||||||
|
|
||||||
tsWriteQueue <- newTQueueIO
|
tsWriteQueue <- newTQueueIO
|
||||||
pWriterThread <- asyncBound (writeTerminal t tsWriteQueue)
|
pWriterThread <- asyncBound (writeTerminal pTerminal tsWriteQueue)
|
||||||
|
|
||||||
pPreviousConfiguration <- io $ getTerminalAttributes stdInput
|
pPreviousConfiguration <- io $ getTerminalAttributes stdInput
|
||||||
|
|
||||||
@ -134,8 +135,11 @@ initializeLocalTerminal = do
|
|||||||
-- can't kill. If we were to cancel here, the internal `waitCatch` would
|
-- can't kill. If we were to cancel here, the internal `waitCatch` would
|
||||||
-- block until the next piece of keyboard input. Since this only happens
|
-- block until the next piece of keyboard input. Since this only happens
|
||||||
-- at shutdown, just leak the file descriptor.
|
-- at shutdown, just leak the file descriptor.
|
||||||
|
|
||||||
cancel pWriterThread
|
cancel pWriterThread
|
||||||
|
|
||||||
|
-- inject one final newline, as we're usually on the prompt.
|
||||||
|
io $ runTermOutput pTerminal $ termText "\r\n"
|
||||||
|
|
||||||
-- take the terminal out of raw mode
|
-- take the terminal out of raw mode
|
||||||
io $ setTerminalAttributes stdInput pPreviousConfiguration Immediately
|
io $ setTerminalAttributes stdInput pPreviousConfiguration Immediately
|
||||||
|
|
||||||
@ -356,15 +360,12 @@ term TerminalSystem{..} shutdownSTM pierPath king enqueueEv =
|
|||||||
|
|
||||||
runTerm :: RAcquire e (EffCb e TermEf)
|
runTerm :: RAcquire e (EffCb e TermEf)
|
||||||
runTerm = do
|
runTerm = do
|
||||||
tim <- mkRAcquire start stop
|
tim <- mkRAcquire start cancel
|
||||||
pure handleEffect
|
pure handleEffect
|
||||||
|
|
||||||
start :: RIO e (Async ())
|
start :: RIO e (Async ())
|
||||||
start = async readBelt
|
start = async readBelt
|
||||||
|
|
||||||
stop :: Async () -> RIO e ()
|
|
||||||
stop rb = cancel rb
|
|
||||||
|
|
||||||
readBelt :: RIO e ()
|
readBelt :: RIO e ()
|
||||||
readBelt = forever $ do
|
readBelt = forever $ do
|
||||||
b <- atomically $ readTQueue tsReadQueue
|
b <- atomically $ readTQueue tsReadQueue
|
||||||
|
Loading…
Reference in New Issue
Block a user