diff options
author | Spencer Janssen <sjanssen@cse.unl.edu> | 2007-03-07 07:42:23 +0100 |
---|---|---|
committer | Spencer Janssen <sjanssen@cse.unl.edu> | 2007-03-07 07:42:23 +0100 |
commit | 94608f2544104e334bb3e60d433c17f93927863c (patch) | |
tree | 896a131e809341d93ac50ef8a09d90e9e4771750 | |
parent | b870835f621f1936676960b934941a1d2950c3b2 (diff) | |
download | metatile-94608f2544104e334bb3e60d433c17f93927863c.tar metatile-94608f2544104e334bb3e60d433c17f93927863c.zip |
Plan for statusbar/multithreading
darcs-hash:20070307064223-a5988-0580a4fe6cc01238e55f00d9dc637212afc3d165
-rw-r--r-- | TODO | 16 |
1 files changed, 16 insertions, 0 deletions
@@ -0,0 +1,16 @@ +- think about the statusbar/multithreading. + Three shared TVars: + windowTitle :: TVar String + workspace :: TVar Int + statusText :: TVar String + Three threads: + Main thread, handles all of the events that it handles now. When + necessary, it writes to workspace or windowTitle + + Status IO thread, the algorithm is something like this: + forever $ do + s <- getLine + atomic (writeTVar statusText s) + + Statusbar drawing thread, waits for changes in all three TVars, and + redraws whenever it finds a change. |