Difference between revisions of "Xmonad/Using xmonad in KDE"

From HaskellWiki
Jump to navigation Jump to search
(Set KDEWM in ~/.kde/env)
Line 8: Line 8:
   
 
Ability to browse all programs and utitlities with desktop bar (kicker)
 
Ability to browse all programs and utitlities with desktop bar (kicker)
  +
  +
Easy integration of Xmonad on a system using kdm for logins
   
 
== Related reading ==
 
== Related reading ==
Line 13: Line 15:
 
The [http://haskell.org/haskellwiki/Xmonad/Using_xmonad_in_Gnome GNOME/xmonad] page.
 
The [http://haskell.org/haskellwiki/Xmonad/Using_xmonad_in_Gnome GNOME/xmonad] page.
   
== Starting xmonad ==
+
== Make xmonad your window manager in KDE ==
   
  +
Create the directory <code>~/.kde/env</code> if it does not
Set the KDEWM variable
 
  +
already exist. Create a file there called <code>set_window_manager.sh</code>
  +
containing only the following line of text:
   
 
<code>
 
<code>
KDEWM=/home/$USER/bin/xmonad
+
KDEWM=/path/to/xmonad
 
</code>
 
</code>
   
  +
where "<code>/path/to/xmonad</code>" is the path to the xmonad
I don't know where the right place is to do this, so I just inserted this line
 
  +
binary on your system. For example, on Debian systems this
in /usr/bin/startkde
 
  +
is <code>/usr/bin/xmonad</code>, and if you compiled xmonad
  +
by hand it may be something like <code>/home/$USER/bin/xmonad</code>.
  +
   
 
== Dealing with KDE windows ==
 
== Dealing with KDE windows ==
  +
 
Without doing anything, you now have a working KDE environment.
 
Without doing anything, you now have a working KDE environment.
 
One nice thing is that system notification windows will pop-up as small windows in the upper left window.
 
One nice thing is that system notification windows will pop-up as small windows in the upper left window.
  +
 
=== Xmonad Configuration ===
 
=== Xmonad Configuration ===
  +
 
<code>
 
<code>
 
import XMonad
 
import XMonad
Line 56: Line 66:
   
 
== KDE Configuration ==
 
== KDE Configuration ==
  +
 
If you don't use the KDE kicker bar much, you may want to configure the kicker bar to autohide, and show when the mouse touches the lower left corner of the screen. Right click on the bar, select "Configure Panel", select "Hiding" on the left, select "Hide Automatically", select "Raise when the pointer touches the screen's", select "Lower left Corner"
 
If you don't use the KDE kicker bar much, you may want to configure the kicker bar to autohide, and show when the mouse touches the lower left corner of the screen. Right click on the bar, select "Configure Panel", select "Hiding" on the left, select "Hide Automatically", select "Raise when the pointer touches the screen's", select "Lower left Corner"

Revision as of 13:10, 8 April 2008

Below configuration is for xmonad 0.5, known to work on Kubuntu

Screen-sjanssen-kde-kicker.png

Motivation

Easier system monitoring on laptops with networking widget.

Ability to browse all programs and utitlities with desktop bar (kicker)

Easy integration of Xmonad on a system using kdm for logins

Related reading

The GNOME/xmonad page.

Make xmonad your window manager in KDE

Create the directory ~/.kde/env if it does not already exist. Create a file there called set_window_manager.sh containing only the following line of text:

KDEWM=/path/to/xmonad

where "/path/to/xmonad" is the path to the xmonad binary on your system. For example, on Debian systems this is /usr/bin/xmonad, and if you compiled xmonad by hand it may be something like /home/$USER/bin/xmonad.


Dealing with KDE windows

Without doing anything, you now have a working KDE environment. One nice thing is that system notification windows will pop-up as small windows in the upper left window.

Xmonad Configuration

import XMonad

import XMonad.Config

import qualified XMonad.StackSet as W

main = xmonad $ defaultConfig

   {
   , manageHook            = manageHook defaultConfig <+> myManageHook
   }
   where
          myManageHook = composeAll . concat $
          [ [ className   =? c                 --> doFloat | c <- myFloats]
          , [ title       =? t                 --> doFloat | t <- myOtherFloats]
          , [ resource    =? r                 --> doIgnore | r <- myIgnores]
          , [ className   =? "Firefox-bin"     --> doF (W.shift "2:web") ]
          , [ className   =? "Opera"           --> doF (W.shift "2:web") ]
          ]
          where
              myIgnores       = ["gnome-panel", "desktop_window", "kicker", "KDE Desktop", "KNetworkManager", "KMix", "Power Manager", "KPowersave", "klipper", "knotes", "panel", "stalonetray", "trayer"]
              myFloats        = ["MPlayer", "Gimp", "kdesktop"]
              myOtherFloats   = ["alsamixer"]

After ignoring the KDE kicker and panels, they will all be placed on the first desktop, which should be reserved for these items. It looks kind of odd, but it works.

KDE Configuration

If you don't use the KDE kicker bar much, you may want to configure the kicker bar to autohide, and show when the mouse touches the lower left corner of the screen. Right click on the bar, select "Configure Panel", select "Hiding" on the left, select "Hide Automatically", select "Raise when the pointer touches the screen's", select "Lower left Corner"