aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Roundy <droundy@darcs.net>2007-06-17 17:23:40 +0200
committerDavid Roundy <droundy@darcs.net>2007-06-17 17:23:40 +0200
commitff0b27c83754d70c2922632201ddf26362999d5e (patch)
tree739aac25b7455fae692aed80762198c6e046933f
parentec3e73600701273ef5f377dcd7cf4171aceb565e (diff)
downloadXMonadContrib-ff0b27c83754d70c2922632201ddf26362999d5e.tar.gz
XMonadContrib-ff0b27c83754d70c2922632201ddf26362999d5e.tar.xz
XMonadContrib-ff0b27c83754d70c2922632201ddf26362999d5e.zip
shrink window names to fit tabs.
darcs-hash:20070617152340-72aca-31e28c0deb224de9951b3778ccd4e9d7232b9917.gz
-rw-r--r--Tabbed.hs34
1 files changed, 25 insertions, 9 deletions
diff --git a/Tabbed.hs b/Tabbed.hs
index f98fb0b..d81ccbc 100644
--- a/Tabbed.hs
+++ b/Tabbed.hs
@@ -15,7 +15,8 @@
module XMonadContrib.Tabbed (
-- * Usage:
-- $usage
- tabbed
+ tabbed
+ , Shrinker, shrinkText
) where
import Control.Monad ( forM, liftM )
@@ -35,16 +36,16 @@ import XMonadContrib.NamedWindows
-- > import XMonadContrib.Tabbed
--
-- > defaultLayouts :: [Layout]
--- > defaultLayouts = [ tabbed
+-- > defaultLayouts = [ tabbed shrinkText
-- > , ... ]
-tabbed :: Layout
-tabbed = Layout { doLayout = dolay, modifyLayout = const (return Nothing) }
+tabbed :: Shrinker -> Layout
+tabbed shrinkT = Layout { doLayout = dolay shrinkT, modifyLayout = const (return Nothing) }
-dolay :: Rectangle -> W.Stack Window -> X [(Window, Rectangle)]
-dolay sc (W.Stack w [] []) = return [(w,sc)]
-dolay sc@(Rectangle x y wid _) s@(W.Stack w _ _) = withDisplay $ \dpy ->
+dolay :: Shrinker -> Rectangle -> W.Stack Window -> X [(Window, Rectangle)]
+dolay _ sc (W.Stack w [] []) = return [(w,sc)]
+dolay shr sc@(Rectangle x y wid _) s@(W.Stack w _ _) = withDisplay $ \dpy ->
do activecolor <- io $ initColor dpy "#BBBBBB"
inactivecolor <- io $ initColor dpy "#888888"
textcolor <- io $ initColor dpy "#000000"
@@ -64,13 +65,28 @@ dolay sc@(Rectangle x y wid _) s@(W.Stack w _ _) = withDisplay $ \dpy ->
do fontst <- io $ loadQueryFont d "-misc-fixed-*-*-*-*-*-*-*-*-*-*-*-*"
io $ setFont d gc (fontFromFontStruct fontst)
let (_,asc,_,_) = textExtents fontst name
- width = textWidth fontst name
+ name' = shrinkWhile shr (\n -> textWidth fontst n >
+ fromIntegral wt - fromIntegral (ht `div` 2)) name
+ width = textWidth fontst name'
io $ drawString d w' gc
(fromIntegral (wt `div` 2) - fromIntegral (width `div` 2))
- (fromIntegral ht - fromIntegral (asc `div` 2)) name
+ (fromIntegral ht - fromIntegral (asc `div` 2)) name'
forM tws maketab
return [ (w,shrink sc) ]
+type Shrinker = String -> [String]
+
+shrinkWhile :: Shrinker -> (String -> Bool) -> String -> String
+shrinkWhile sh p x = sw $ sh x
+ where sw [n] = n
+ sw [] = ""
+ sw (n:ns) | p n = sw ns
+ | otherwise = n
+
+shrinkText :: Shrinker
+shrinkText "" = [""]
+shrinkText cs = cs : shrinkText (init cs)
+
shrink :: Rectangle -> Rectangle
shrink (Rectangle x y w h) = Rectangle x (y+tabsize) w (h-tabsize)