Commit 799ba4a

bryfry <bryon@fryer.io>
2016-05-29 02:24:37
add TODO
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"`