Commit 799ba4a
2016-05-29 02:24:37
Changed files (7)
files/.Xmodmap
@@ -0,0 +1,2 @@
+remove mod4 = Super_L
+add control = Super_L
files/dwm-config.h
@@ -0,0 +1,115 @@
+/* See LICENSE file for copyright and license details. */
+
+/* appearance */
+static const char *fonts[] = {
+ "monospace:size=8"
+};
+static const char dmenufont[] = "monospace:size=10";
+static const char normbordercolor[] = "#444444";
+static const char normbgcolor[] = "#222222";
+static const char normfgcolor[] = "#bbbbbb";
+static const char selbordercolor[] = "#005577";
+static const char selbgcolor[] = "#005577";
+static const char selfgcolor[] = "#eeeeee";
+static const unsigned int borderpx = 0; /* border pixel of windows */
+static const unsigned int snap = 32; /* snap pixel */
+static const int showbar = 1; /* 0 means no bar */
+static const int topbar = 1; /* 0 means bottom bar */
+
+/* tagging */
+static const char *tags[] = { "t", "f"};
+
+static const Rule rules[] = {
+ /* xprop(1):
+ * WM_CLASS(STRING) = instance, class
+ * WM_NAME(STRING) = title
+ */
+ /* class instance title tags mask isfloating monitor */
+ /*{ "Gimp", NULL, NULL, 0, 1, -1 },*/
+ { "Firefox", NULL, NULL, 1 << 8, 0, -1 },
+};
+
+/* layout(s) */
+static const float mfact = 0.55; /* factor of master area size [0.05..0.95] */
+static const int nmaster = 1; /* number of clients in master area */
+static const int resizehints = 1; /* 1 means respect size hints in tiled resizals */
+
+static const Layout layouts[] = {
+ /* symbol arrange function */
+ { "[]=", tile }, /* first entry is default */
+ //{ "><>", NULL }, /* no layout function means floating behavior */
+ { "[M]", monocle },
+};
+
+/* key definitions */
+#define MODKEY Mod1Mask
+#define TAGKEYS(KEY,TAG) \
+ { MODKEY, KEY, view, {.ui = 1 << TAG} }, \
+ { MODKEY|ControlMask, KEY, toggleview, {.ui = 1 << TAG} }, \
+ { MODKEY|ShiftMask, KEY, tag, {.ui = 1 << TAG} }, \
+ { MODKEY|ControlMask|ShiftMask, KEY, toggletag, {.ui = 1 << TAG} },
+
+/* helper for spawning shell commands in the pre dwm-5.0 fashion */
+#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
+
+/* commands */
+static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() */
+static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", normbgcolor, "-nf", normfgcolor, "-sb", selbgcolor, "-sf", selfgcolor, NULL };
+static const char *termcmd[] = { "xterm", "-rv", NULL };
+static const char *firefox[] = { "firefox", NULL };
+
+static Key keys[] = {
+ /* modifier key function argument */
+ { MODKEY, XK_p, spawn, {.v = dmenucmd } },
+ { MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
+ { MODKEY|ShiftMask, XK_f, spawn, {.v = firefox } },
+ { MODKEY, XK_b, togglebar, {0} },
+ { MODKEY, XK_j, focusstack, {.i = +1 } },
+ { MODKEY, XK_k, focusstack, {.i = -1 } },
+ { MODKEY, XK_i, incnmaster, {.i = +1 } },
+ { MODKEY, XK_d, incnmaster, {.i = -1 } },
+ { MODKEY, XK_h, setmfact, {.f = -0.05} },
+ { MODKEY, XK_l, setmfact, {.f = +0.05} },
+ { MODKEY, XK_Return, zoom, {0} },
+ { MODKEY, XK_Tab, view, {0} },
+ { MODKEY|ShiftMask, XK_c, killclient, {0} },
+ { MODKEY, XK_t, setlayout, {.v = &layouts[0]} },
+ //{ MODKEY, XK_f, setlayout, {.v = &layouts[1]} },
+ { MODKEY, XK_m, setlayout, {.v = &layouts[1]} },
+ { MODKEY, XK_space, setlayout, {0} },
+ //{ MODKEY|ShiftMask, XK_space, togglefloating, {0} },
+ { MODKEY, XK_0, view, {.ui = ~0 } },
+ { MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } },
+ { MODKEY, XK_comma, focusmon, {.i = -1 } },
+ { MODKEY, XK_period, focusmon, {.i = +1 } },
+ { MODKEY|ShiftMask, XK_comma, tagmon, {.i = -1 } },
+ { MODKEY|ShiftMask, XK_period, tagmon, {.i = +1 } },
+ TAGKEYS( XK_1, 0)
+ TAGKEYS( XK_2, 1)
+ TAGKEYS( XK_3, 2)
+ TAGKEYS( XK_4, 3)
+ TAGKEYS( XK_5, 4)
+ TAGKEYS( XK_6, 5)
+ TAGKEYS( XK_7, 6)
+ TAGKEYS( XK_8, 7)
+ TAGKEYS( XK_9, 8)
+ { MODKEY|ShiftMask, XK_q, quit, {0} },
+};
+
+/* button definitions */
+/* click can be ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
+static Button buttons[] = {
+ /* click event mask button function argument */
+ { ClkLtSymbol, 0, Button1, setlayout, {0} },
+ { ClkLtSymbol, 0, Button3, setlayout, {.v = &layouts[2]} },
+ { ClkWinTitle, 0, Button2, zoom, {0} },
+ { ClkStatusText, 0, Button2, spawn, {.v = termcmd } },
+ { ClkClientWin, MODKEY, Button1, movemouse, {0} },
+ { ClkClientWin, MODKEY, Button2, togglefloating, {0} },
+ { ClkClientWin, MODKEY, Button3, resizemouse, {0} },
+ { ClkTagBar, 0, Button1, view, {0} },
+ { ClkTagBar, 0, Button3, toggleview, {0} },
+ { ClkTagBar, MODKEY, Button1, tag, {0} },
+ { ClkTagBar, MODKEY, Button3, toggletag, {0} },
+};
+
files/shiftview.patch
@@ -0,0 +1,34 @@
+diff --git a/dwm.c b/dwm.c
+index ff7e096..7b7456f 100644
+--- a/dwm.c
++++ b/dwm.c
+@@ -203,6 +203,7 @@ static void setfullscreen(Client *c, int fullscreen);
+ static void setlayout(const Arg *arg);
+ static void setmfact(const Arg *arg);
+ static void setup(void);
++static void shiftview(const Arg *arg);
+ static void showhide(Client *c);
+ static void sigchld(int unused);
+ static void spawn(const Arg *arg);
+@@ -1609,6 +1610,21 @@ setup(void)
+ }
+
+ void
++shiftview(const Arg *arg) {
++ Arg shifted;
++
++ if(arg->i > 0) // left circular shift
++ shifted.ui = (selmon->tagset[selmon->seltags] << arg->i)
++ | (selmon->tagset[selmon->seltags] >> (LENGTH(tags) - arg->i));
++
++ else // right circular shift
++ shifted.ui = selmon->tagset[selmon->seltags] >> (- arg->i)
++ | selmon->tagset[selmon->seltags] << (LENGTH(tags) + arg->i);
++
++ view(&shifted);
++}
++
++void
+ showhide(Client *c)
+ {
+ if (!c)
ansible.cfg
@@ -0,0 +1,2 @@
+[defaults]
+inventory = hosts
hosts
@@ -0,0 +1,2 @@
+[local]
+localhost ansible_connection=local
main.yml
@@ -0,0 +1,117 @@
+---
+- hosts: local
+
+ vars:
+ dwm_dir: "{{ ansible_env.HOME }}/git/dwm"
+ lastpass_dir: "{{ ansible_env.HOME }}/git/lastpass-cli"
+
+ tasks:
+
+ - name: apt - update && upgrade && autoremove
+ apt:
+ update_cache: yes
+ cache_valid_time: 3600
+ upgrade: full
+ autoremove: yes
+ become: yes
+ tags: apt
+
+ - name: dwm - apt dependenices
+ apt:
+ name: "{{ item }}"
+ state: latest
+ become: yes
+ tags: [dwm, apt]
+ with_items:
+ - xinit
+ - build-essential
+ - libx11-dev
+ - libxft-dev
+ - libxinerama-dev
+ - sharutils
+ - suckless-tools
+
+
+ - name: dwm - git clone
+ git:
+ repo: http://git.suckless.org/dwm
+ dest: "{{ dwm_dir }}"
+ tags: dwm
+
+ - name: dwm - configure
+ copy:
+ src: files/dwm-config.h
+ dest: "{{ dwm_dir }}/config.h"
+ tags: [dwm, config]
+
+ - name: dwm - compile
+ command: "{{ item }}"
+ args:
+ chdir: "{{ dwm_dir }}"
+ tags: dwm
+ with_items:
+ - make clean
+ - make
+
+ - name: dwm - install
+ command: make install
+ args:
+ chdir: "{{ dwm_dir }}"
+ tags: dwm
+ become: true
+
+ - name: apt - utilities
+ apt:
+ name: "{{ item }}"
+ state: latest
+ become: yes
+ tags: apt
+ with_items:
+ - xbacklight
+ - powertop
+ - htop
+ - vim
+ - git
+ - screen
+
+ - name: lastpass - apt dependencies
+ apt:
+ name: "{{ item }}"
+ state: latest
+ become: yes
+ tags: [lastpass, apt]
+ with_items:
+ - openssl
+ - libcurl4-openssl-dev
+ - libxml2
+ - libssl-dev
+ - libxml2-dev
+ - libxml2
+ - pinentry-curses
+ - xclip
+ - asciidoc
+
+ - name: lastpass - git clone
+ git:
+ repo: https://github.com/lastpass/lastpass-cli.git
+ dest: "{{ lastpass_dir }}"
+ tags: lastpass
+
+ - name: lastpass - compile
+ command: "{{ item }}"
+ args:
+ chdir: "{{ lastpass_dir }}"
+ tags: lastpass
+ with_items:
+ - make clean
+ - make
+
+ - name: lastpass - install
+ command: "{{ item }}"
+ args:
+ chdir: "{{ lastpass_dir }}"
+ become: true
+ tags: lastpass
+ with_items:
+ - make install
+ - make install-doc
README.md
@@ -0,0 +1,12 @@
+# ansible-chromebook
+
+An ansible playbook for setting up Ubuntu 16.04 (server + dwm) on a Dell Chromebook 11
+
+## raw commands
+
+ * `sudo apt-get install python python-yaml python-jinja2 aptitude`
+
+## TODO
+
+ * `git config --global user.email "bryon@fryer.io"`
+ * `git config --global user.name "bryfry"`