[hackers] [wmii] Fixed and cleaned up rc.wmii. Updated rc/welcome

From: Kris Maglione <jg_AT_suckless.org>
Date: Mon Feb 26 05:31:19 2007

changeset: 1959:8593ba0b74d9
tag: tip
user: Kris Maglione <jg_AT_suckless.org>
date: Sun Feb 25 23:29:16 2007 -0500
summary: Fixed and cleaned up rc.wmii. Updated rc/welcome

diff -r dd725f2d8d38 -r 8593ba0b74d9 rc/rc.wmii
--- a/rc/rc.wmii Sun Feb 25 15:29:27 2007 -0500
+++ b/rc/rc.wmii Sun Feb 25 23:29:16 2007 -0500
@@ -29,9 +29,9 @@ fn config_whatis {
         echo `{{path=$confpath whatis $prog} | grep -v '=|^fn '} $*
 }
 
+# Source Variables, &c
 local = `{config_whatis rc.wmii.local}
-if(! ~ $#local 0)
- . <{awk '// /^# Overrides/ { exit }' $local}
+. <{awk '// /^# Overrides/ { exit }' $local}
 
 # Column Rules
 wmiir write /colrules <<!
@@ -42,7 +42,6 @@ wmiir write /tagrules <<!
 wmiir write /tagrules <<!
 /Firefox/ -> www
 /XMMS.*/ -> ~
-/Gimp.*/ -> ~
 /MPlayer.*/ -> ~
 /.*/ -> !
 /.*/ -> 1
@@ -55,58 +54,36 @@ fn status {
 
 # Events
 fn Event-Start {
- if(~ $1 wmiirc) {
+ switch($1) {
+ case wmiirc
                 rm -f $progs_file
                 exit
         }
 }
-fn Event-Key {
- eval Key-$1 $1
-}
-fn Event-CreateTag {
- echo $WMII_NORMCOLORS $* | wmiir create /lbar/$*
-}
-fn Event-DestroyTag {
- wmiir remove /lbar/$*
-}
-fn Event-FocusTag {
- wmiir xwrite /lbar/$* $WMII_FOCUSCOLORS $*
-}
-fn Event-UnfocusTag {
- wmiir xwrite /lbar/$* $WMII_NORMCOLORS $*
-}
-fn Event-UrgentTag {
- shift
- wmiir xwrite "/lbar/\$@" "*\$@"
-}
-fn Event-NotUrgentTag {
- shift
- wmiir xwrite "/lbar/\$@" "\$@"
-}
-fn Event-LeftBarClick {
- shift
- wmiir xwrite /ctl view $*
-}
+
+fn Event-Key { eval Key-$1 $1 }
+
+fn Event-CreateTag { echo $WMII_NORMCOLORS $* | wmiir create /lbar/$"* }
+fn Event-DestroyTag { wmiir remove /lbar/$"* }
+fn Event-FocusTag { wmiir xwrite /lbar/$"* $WMII_FOCUSCOLORS $* }
+fn Event-UnfocusTag { wmiir xwrite /lbar/$"* $WMII_NORMCOLORS $* }
+fn Event-UrgentTag { shift; wmiir xwrite /lbar/$"* '*'$"* }
+fn Event-NotUrgentTag { shift; wmiir xwrite /lbar/$"* $"* }
+
+fn Event-LeftBarClick { shift; wmiir xwrite /ctl view $* }
 
 # Actions
 fn Action {
         action=$1; shift
         if(whatis Action-$action | 9 grep -s '^fn ') {
                 Action-$action $* &
- }
- if not {
+ };if not {
                 run_command `{config_whatis $action} $* &
         }
 }
-fn Action-rehash {
- proglist $PATH >$progs_file
-}
-fn Action-quit {
- wmiir xwrite /ctl quit
-}
+fn Action-rehash { proglist $PATH >$progs_file }
+fn Action-quit { wmiir xwrite /ctl quit }
 fn Action-status {
- flag x -
- flag r -
         if(wmiir remove /rbar/status >[2]/dev/null)
                 sleep 2
         echo $WMII_NORMCOLORS | wmiir create /rbar/status
@@ -116,93 +93,67 @@ fn Action-status {
 
 # Key Bindings
 fn Key-$MODKEY-Control-t {
- if(~ `{wmiir read /keys | wc -l} 0) {
+ switch(`{wmiir read /keys | wc -l}) {
+ case 0 1
                 initkeys
                 wmiir xwrite /ctl grabmod $MODKEY
- }
- if not {
- wmiir xwrite /ctl keys $MODKEY-Control-t
+ case *
+ wmiir xwrite /keys $MODKEY-Control-t
                 wmiir xwrite /ctl grabmod Mod3
         }
 }
-fn Key-$MODKEY-$LEFT {
- wmiir xwrite /tag/sel/ctl select left
-}
-fn Key-$MODKEY-$RIGHT {
- wmiir xwrite /tag/sel/ctl select right
-}
-fn Key-$MODKEY-$DOWN {
- wmiir xwrite /tag/sel/ctl select down
-}
-fn Key-$MODKEY-$UP {
- wmiir xwrite /tag/sel/ctl select up
-}
-fn Key-$MODKEY-space {
- wmiir xwrite /tag/sel/ctl select toggle
-}
-fn Key-$MODKEY-d {
- wmiir xwrite /tag/sel/ctl colmode sel default
-}
-fn Key-$MODKEY-s {
- wmiir xwrite /tag/sel/ctl colmode sel stack
-}
-fn Key-$MODKEY-m {
- wmiir xwrite /tag/sel/ctl colmode sel max
-}
-fn Key-$MODKEY-a {
- Action `{actionlist | wmiimenu} &
-}
-fn Key-$MODKEY-p {
- run_command `{wmiimenu <$progs_file} &
-}
-fn Key-$MODKEY-Return {
- run_command $WMII_TERM &
-}
-fn Key-$MODKEY-t {
- wmiir xwrite /ctl view `{read_tags | wmiimenu} &
-}
-fn Key-$MODKEY-Shift-$LEFT {
- wmiir xwrite /tag/sel/ctl send sel left
-}
-fn Key-$MODKEY-Shift-$RIGHT {
- wmiir xwrite /tag/sel/ctl send sel right
-}
-fn Key-$MODKEY-Shift-$DOWN {
- wmiir xwrite /tag/sel/ctl send sel down
-}
-fn Key-$MODKEY-Shift-$UP {
- wmiir xwrite /tag/sel/ctl send sel up
-}
-fn Key-$MODKEY-Shift-space {
- wmiir xwrite /tag/sel/ctl send sel toggle
-}
-fn Key-$MODKEY-Shift-c {
- wmiir xwrite /client/sel/ctl kill
-}
+
+fn Key-$MODKEY-$LEFT { wmiir xwrite /tag/sel/ctl select left }
+fn Key-$MODKEY-$RIGHT { wmiir xwrite /tag/sel/ctl select right }
+fn Key-$MODKEY-$DOWN { wmiir xwrite /tag/sel/ctl select down }
+fn Key-$MODKEY-$UP { wmiir xwrite /tag/sel/ctl select up }
+
+fn Key-$MODKEY-Shift-$LEFT { wmiir xwrite /tag/sel/ctl send sel left }
+fn Key-$MODKEY-Shift-$RIGHT { wmiir xwrite /tag/sel/ctl send sel right }
+fn Key-$MODKEY-Shift-$DOWN { wmiir xwrite /tag/sel/ctl send sel down }
+fn Key-$MODKEY-Shift-$UP { wmiir xwrite /tag/sel/ctl send sel up }
+
+fn Key-$MODKEY-space { wmiir xwrite /tag/sel/ctl select toggle }
+fn Key-$MODKEY-Shift-space { wmiir xwrite /tag/sel/ctl send sel toggle }
+
+fn Key-$MODKEY-d { wmiir xwrite /tag/sel/ctl colmode sel default }
+fn Key-$MODKEY-s { wmiir xwrite /tag/sel/ctl colmode sel stack }
+fn Key-$MODKEY-m { wmiir xwrite /tag/sel/ctl colmode sel max }
+
+fn Key-$MODKEY-Shift-c { wmiir xwrite /client/sel/ctl kill }
+
+fn Key-$MODKEY-a { Action `{actionlist | wmiimenu} & }
+fn Key-$MODKEY-p { run_command `{wmiimenu <$progs_file} & }
+fn Key-$MODKEY-Return { run_command $WMII_TERM & }
+fn Key-$MODKEY-t { wmiir xwrite /ctl view `{read_tags | wmiimenu} & }
 fn Key-$MODKEY-Shift-t {
         wmiir xwrite /client/`{wmiir read /client/sel/ctl}^/tags `{read_tags | wmiimenu} &
 }
 
 for(i in `{seq 0 9}) {
- fn Key-$MODKEY-$i {
- wmiir xwrite /ctl view `{echo $1 | sed 's/.*-//'}
- }
- fn Key-Shift-$MODKEY-$i {
- wmiir xwrite /client/sel/tags `{echo $1 | sed 's/.*-//'}
- }
+ fn Key-$MODKEY-$i { wmiir xwrite /ctl view `{echo $1 | sed 's/.*-//'} }
+ fn Key-Shift-$MODKEY-$i {wmiir xwrite /client/sel/tags `{echo $1 | sed 's/.*-//'} }
 }
 
 # Functions
 fn proglist {
- /bin/ls -lL `{echo $* | tr : ' '} >[2]/dev/null |
- awk '$1 ~ /^[^d].*x/ { print $NF }' |
- sort | uniq
+ /bin/ls -lL `{echo $* | sed 'y/ /:'} >[2]/dev/null \
+ | awk '$1 ~ /^[^d].*x/ { print $NF }' \
+ | sort | uniq
+}
+
+fn getfuns {
+ env | sed -n 's/^fn#'^$1^'-([^=]+).*/\1/p'
 }
 
 fn actionlist {
- { proglist $WMII_CONFPATH;
- env | sed -n 's/^fn#Action-([^=]+).*/\1/p'
+ { proglist $WMII_CONFPATH
+ getfuns Action
         } | sort | uniq
+}
+
+fn initkeys {
+ getfuns Key | wmiir write /keys
 }
 
 fn read_tags {
@@ -210,13 +161,14 @@ fn read_tags {
 }
 
 fn run_command {
- rfork ens
- path=$oldpath \
- eval exec $* </dev/null
-}
-
-if(! ~ $#local 0)
- . <{awk '/^# Overrides/, 0' $local}
+ @{ rfork ens
+ path=$oldpath
+ eval exec $* </dev/null
+ }
+}
+
+# Source Overrides
+. <{awk '/^# Overrides/, 0' $local}
 
 # WM Configuration
 wmiir write /ctl <<!
@@ -233,20 +185,12 @@ progs_file=$WMII_NS_DIR/proglist.$pid
 progs_file=$WMII_NS_DIR/proglist.$pid
 proglist $PATH >$progs_file &
 
-fn initkeys {
- env | sed -n 's/^fn#Key-([^=]+).*/\1/p' \
- | wmiir write /keys
-}
-
-initkeys
-
-# Tag Bar
+# Tag Bar Setup
 ifs='#
-'{
- for(bar in `{wmiir ls /lbar})
+'{ for(bar in `{wmiir ls /lbar})
                 wmiir remove /lbar/$bar
         seltag=`{wmiir read /tag/sel/ctl}
- for(tag in `{wmiir ls /tag | sed -e 's,/,,; /^sel$/d'}) {
+ for(tag in `{read_tags}) {
                 if(~ $tag $seltag)
                         echo $WMII_FOCUSCOLORS $tag | wmiir create /lbar/$tag
                 if not
@@ -254,6 +198,8 @@ ifs='#
         }
 }
 
+# Keygrab Setup
+initkeys
 
 if(echo Start wmiirc | ! wmiir write /event >[2]/dev/null)
         exit 1
@@ -261,8 +207,6 @@ if(echo Start wmiirc | ! wmiir write /ev
 # Event Loop
 wmiir read /event |
         while(*=`{read}) {
- if(~ $debug true)
- echo $*
                 event = $1; shift
- eval Event-$event $* >[2]/dev/null
- }
+ Event-$event $* >[2]/dev/null
+ }
diff -r dd725f2d8d38 -r 8593ba0b74d9 rc/welcome
--- a/rc/welcome Sun Feb 25 15:29:27 2007 -0500
+++ b/rc/welcome Sun Feb 25 23:29:16 2007 -0500
@@ -2,46 +2,46 @@
 # display a welcome message that contains the wmii tutorial
 
 xmessage -file - <<'EOF'
-Welcome to wmii, the non-wimp environment of the WMI Project.
+Welcome to wmii, the non-wimp environment of the Suckless Project.
 
 This is a small step by step tutorial, intended to make you a
 little bit familiar with wmii.
 
-Note: $MODKEY is the Alt-key by default.
+From here on, keypresses will be described such that M-a refers to
+pressing $MODKEY and a at the same time. $MODKEY refers to a
+configuratin variable which contains the Alt key by default.
 
 Let's go!
 
-- Start two xterms by pressing $MODKEY-Return twice.
-- Switch between the three windows: $MODKEY-j, $MODKEY-k,
- $MODKEY-h, $MODKEY-l
- If you prefer the mouse, then just move the pointer to
+- Start two xterms by pressing M-Return twice.
+- Switch between the three windows: M-j, M-k,
+ M-h, M-l
+ If you prefer to use the mouse, then just move the pointer to
   the desired window.
-- Try the other column modes: $MODKEY-s for stack mode,
- $MODKEY-m for max mode Press $MODKEY-d to return to default
+- Try the other column modes: M-s for stack mode,
+ M-m for max mode Press M-d to return to default
   mode.
-- Create a new column with: $MODKEY-Shift-l
- This moves the client right-wards.
-- Tag the selected client with another tag: $MODKEY-Shift-2
+- Create a new column with: M-Shift-l
+ This moves the client rightwards.
+- Tag the selected client with another tag: M-Shift-2
   IMPORTANT: before you do the next step, note that you
- can select the current tag with $MODKEY-1.
-- Select the new tag: $MODKEY-2
-- Select the floating area: $MODKEY-space
-- Open the programs menu: $MODKEY-p
+ can select the current tag with M-1.
+- Select the new tag: M-2
+- Select the floating area: M-Space
+- Open the programs menu: M-p
   Type 'xclock' and press Enter.
-- Move the xclock window: Press $MODKEY, left-click on the
- window and, while holding the button down, move the cursor
- around.
-- Resize the xclock window: Press $MODKEY, right-click the
- window and, while holding the button down, move the cursor
- around.
-- Open the actions menu: $MODKEY-a
+- Move the xclock window: Hold $MODKEY, left-click on the
+ window and move the cursor around.
+- Resize the xclock window: Hold $MODKEY, right-click the
+ window and move the cursor around.
+- Open the actions menu: M-a
   Rerun wmiirc by selecting 'wmiirc'.
 - We'll now have a look at the internal filesystem used by
   wmii. Executing
           wmiir ls /
   in the shell of the terminal will list all the files in the
   root directory.
- Entries beginning with a 'd' are directories.
+ Entries ending with / are directories.
   If you are curious, you can now dig deeper into the
   directory trees. For instance,
           wmiir ls /rbar/
@@ -52,5 +52,5 @@ selecting 'welcome'.
 selecting 'welcome'.
 
 You should now take a look at the wmii(1) man page. A FAQ is
-available on <http://wmii.suckless.org>.
+available at <http://wmii.suckless.org>.
 EOF
Received on Mon Feb 26 2007 - 05:31:19 UTC

This archive was generated by hypermail 2.2.0 : Sun Jul 13 2008 - 15:55:56 UTC