From 5ed417c7a6403c5a7acc26647bd03a018971f3bf Mon Sep 17 00:00:00 2001 From: Gustaf Rydholm Date: Sun, 26 Dec 2021 14:17:44 +0100 Subject: Format, update colorscheme --- config.h | 358 +++++++++++++++++++++++++++++++++------------------------------ 1 file changed, 188 insertions(+), 170 deletions(-) diff --git a/config.h b/config.h index b2f49ce..f7f9e51 100644 --- a/config.h +++ b/config.h @@ -5,221 +5,239 @@ #define TERMCLASS "St" /* appearance */ -static unsigned int borderpx = 1; /* border pixel of windows */ -static unsigned int snap = 32; /* snap pixel */ -static unsigned int gappih = 20; /* horiz inner gap between windows */ -static unsigned int gappiv = 10; /* vert inner gap between windows */ -static unsigned int gappoh = 10; /* horiz outer gap between windows and screen edge */ -static unsigned int gappov = 30; /* vert outer gap between windows and screen edge */ -static int swallowfloating = 0; /* 1 means swallow floating windows by default */ -static int smartgaps = 0; /* 1 means no outer gap when there is only one window */ -static int showbar = 1; /* 0 means no bar */ -static int topbar = 1; /* 0 means bottom bar */ -static const char *fonts[] = { - "SpaceMono Nerd Font:size=8", - "FontAwesome:pixelsize=8:antialias=true:autohint=true" - }; -static char normbgcolor[] = "#000000"; -static char normbordercolor[] = "#000000"; -static char normfgcolor[] = "#eeeeee"; -static char selfgcolor[] = "#eeeeee"; -static char selbordercolor[] = "#000000"; -static char selbgcolor[] = "#000000"; +static unsigned int borderpx = 1; /* border pixel of windows */ +static unsigned int snap = 32; /* snap pixel */ +static unsigned int gappih = 20; /* horiz inner gap between windows */ +static unsigned int gappiv = 10; /* vert inner gap between windows */ +static unsigned int gappoh = + 10; /* horiz outer gap between windows and screen edge */ +static unsigned int gappov = + 30; /* vert outer gap between windows and screen edge */ +static int swallowfloating = + 0; /* 1 means swallow floating windows by default */ +static int smartgaps = + 0; /* 1 means no outer gap when there is only one window */ +static int showbar = 1; /* 0 means no bar */ +static int topbar = 1; /* 0 means bottom bar */ +static const char *fonts[] = { + "SpaceMono Nerd Font:size=8", + "FontAwesome:pixelsize=8:antialias=true:autohint=true"}; +static char normbgcolor[] = "#000000"; +static char normbordercolor[] = "#000000"; +static char normfgcolor[] = "#eeeeee"; +static char selfgcolor[] = "#eeeeee"; +static char selbordercolor[] = "#000000"; +static char selbgcolor[] = "#000000"; static char *colors[][3] = { - /* fg bg border */ - [SchemeNorm] = { normfgcolor, normbgcolor, normbordercolor }, - [SchemeSel] = { selfgcolor, selbgcolor, selbordercolor }, + /* fg bg border */ + [SchemeNorm] = {normfgcolor, normbgcolor, normbordercolor}, + [SchemeSel] = {selfgcolor, selbgcolor, selbordercolor}, }; typedef struct { - const char *name; - const void *cmd; + const char *name; + const void *cmd; } Sp; -const char *spcmd1[] = {TERMINAL, "-n", "spterm", "-g", "120x34", NULL }; -const char *spcmd2[] = {TERMINAL, "-n", "spcalc", "-f", "monospace:size=16", "-g", "50x20", "-e", "bc", "-lq", NULL }; +const char *spcmd1[] = {TERMINAL, "-n", "spterm", "-g", "120x34", NULL}; +const char *spcmd2[] = {TERMINAL, "-n", "spcalc", "-f", "monospace:size=16", + "-g", "50x20", "-e", "bc", "-lq", + NULL}; static Sp scratchpads[] = { - /* name cmd */ - {"spterm", spcmd1}, - {"spcalc", spcmd2}, + /* name cmd */ + {"spterm", spcmd1}, + {"spcalc", spcmd2}, }; /* tagging */ -static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" }; +static const char *tags[] = {"1", "2", "3", "4", "5", "6", "7", "8", "9"}; static const Rule rules[] = { - /* xprop(1): - * WM_CLASS(STRING) = instance, class - * WM_NAME(STRING) = title - */ - /* class instance title tags mask isfloating monitor */ - { "$BROWSER", NULL, NULL, 1 << 8, 0, -1 }, + /* xprop(1): + * WM_CLASS(STRING) = instance, class + * WM_NAME(STRING) = title + */ + /* class instance title tags mask isfloating isterminal + noswallow monitor */ + {"$BROWSER", NULL, NULL, 1 << 8, 0, 0, -1, -1}, + {"St", NULL, NULL, 0, 0, 1, 0, -1}, + {NULL, NULL, "Event Tester", 0, 0, 0, 1, -1}, /* xev */ }; /* layout(s) */ -static float mfact = 0.55; /* factor of master area size [0.05..0.95] */ -static int nmaster = 1; /* number of clients in master area */ -static int resizehints = 0; /* 1 means respect size hints in tiled resizals */ +static float mfact = 0.55; /* factor of master area size [0.05..0.95] */ +static int nmaster = 1; /* number of clients in master area */ +static int resizehints = 0; /* 1 means respect size hints in tiled resizals */ -#define FORCE_VSPLIT 1 /* nrowgrid layout: force two clients to always split vertically */ +#define FORCE_VSPLIT \ + 1 /* nrowgrid layout: force two clients to always split vertically */ #include "vanitygaps.c" static const Layout layouts[] = { - /* symbol arrange function */ - { "[]=", tile }, /* Default: Master on left, slaves on right */ - { "TTT", bstack }, /* Master on top, slaves on bottom */ + /* symbol arrange function */ + {"[]=", tile}, /* Default: Master on left, slaves on right */ + {"TTT", bstack}, /* Master on top, slaves on bottom */ - { "[@]", spiral }, /* Fibonacci spiral */ - { "[\\]", dwindle }, /* Decreasing in size right and leftward */ + {"[@]", spiral}, /* Fibonacci spiral */ + {"[\\]", dwindle}, /* Decreasing in size right and leftward */ - { "[D]", deck }, /* Master on left, slaves in monocle-like mode on right */ - { "[M]", monocle }, /* All windows on top of eachother */ + {"[D]", deck}, /* Master on left, slaves in monocle-like mode on right */ + {"[M]", monocle}, /* All windows on top of eachother */ - { "|M|", centeredmaster }, /* Master in middle, slaves on sides */ - { ">M>", centeredfloatingmaster }, /* Same but master floats */ + {"|M|", centeredmaster}, /* Master in middle, slaves on sides */ + {">M>", centeredfloatingmaster}, /* Same but master floats */ - { "><>", NULL }, /* no layout function means floating behavior */ - { NULL, NULL }, + {"><>", NULL}, /* no layout function means floating behavior */ + {NULL, NULL}, }; /* key definitions */ #define MODKEY Mod4Mask -#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} }, -#define STACKKEYS(MOD,ACTION) \ - { MOD, XK_j, ACTION##stack, {.i = INC(+1) } }, \ - { MOD, XK_k, ACTION##stack, {.i = INC(-1) } }, \ - { MOD, XK_v, ACTION##stack, {.i = 0 } }, \ +#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}}, +#define STACKKEYS(MOD, ACTION) \ + {MOD, XK_j, ACTION##stack, {.i = INC(+1)}}, \ + {MOD, XK_k, ACTION##stack, {.i = INC(-1)}}, \ + {MOD, XK_v, ACTION##stack, {.i = 0}}, /* helper for spawning shell commands in the pre dwm-5.0 fashion */ -#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } } +#define SHCMD(cmd) \ + { \ + .v = (const char *[]) { "/bin/sh", "-c", cmd, NULL } \ + } /* commands */ -static const char *termcmd[] = { TERMINAL, NULL }; +static const char *termcmd[] = {TERMINAL, NULL}; /* * Xresources preferences to load at startup */ ResourcePref resources[] = { - { "color0", STRING, &normbordercolor }, - { "color8", STRING, &selbordercolor }, - { "color0", STRING, &normbgcolor }, - { "color4", STRING, &normfgcolor }, - { "color0", STRING, &selfgcolor }, - { "color4", STRING, &selbgcolor }, - { "borderpx", INTEGER, &borderpx }, - { "snap", INTEGER, &snap }, - { "showbar", INTEGER, &showbar }, - { "topbar", INTEGER, &topbar }, - { "nmaster", INTEGER, &nmaster }, - { "resizehints", INTEGER, &resizehints }, - { "mfact", FLOAT, &mfact }, - { "gappih", INTEGER, &gappih }, - { "gappiv", INTEGER, &gappiv }, - { "gappoh", INTEGER, &gappoh }, - { "gappov", INTEGER, &gappov }, - { "swallowfloating", INTEGER, &swallowfloating }, - { "smartgaps", INTEGER, &smartgaps }, + {"background", STRING, &normbordercolor}, + {"background", STRING, &selbordercolor}, + {"background", STRING, &normbgcolor}, + {"color7", STRING, &normfgcolor}, + {"color7", STRING, &selfgcolor}, + {"background", STRING, &selbgcolor}, + {"borderpx", INTEGER, &borderpx}, + {"snap", INTEGER, &snap}, + {"showbar", INTEGER, &showbar}, + {"topbar", INTEGER, &topbar}, + {"nmaster", INTEGER, &nmaster}, + {"resizehints", INTEGER, &resizehints}, + {"mfact", FLOAT, &mfact}, + {"gappih", INTEGER, &gappih}, + {"gappiv", INTEGER, &gappiv}, + {"gappoh", INTEGER, &gappoh}, + {"gappov", INTEGER, &gappov}, + {"swallowfloating", INTEGER, &swallowfloating}, + {"smartgaps", INTEGER, &smartgaps}, }; -#include #include "shiftview.c" +#include static Key keys[] = { - /* modifier key function argument */ - STACKKEYS(MODKEY, focus) - STACKKEYS(MODKEY|ShiftMask, push) - { MODKEY, XK_grave, spawn, SHCMD("dmenuunicode") }, - 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, XK_0, view, {.ui = ~0 } }, - { MODKEY|ShiftMask, XK_0, tag, {.ui = ~0 } }, - { MODKEY, XK_BackSpace, spawn, SHCMD("sysact") }, - { MODKEY|ShiftMask, XK_BackSpace, spawn, SHCMD("sysact") }, - { MODKEY|ShiftMask, XK_q, spawn, SHCMD("sysact") }, - { MODKEY, XK_Tab, view, {0} }, - { MODKEY, XK_q, killclient, {0} }, - - { MODKEY, XK_w, spawn, SHCMD("$BROWSER") }, - { MODKEY, XK_r, spawn, SHCMD(TERMINAL " -e ranger") }, - { MODKEY|ShiftMask, XK_r, spawn, SHCMD(TERMINAL " -e btm") }, - { MODKEY, XK_n, spawn, SHCMD(TERMINAL " -e gpuwatch") }, - { MODKEY, XK_space, spawn, SHCMD("dmenu_run") }, - - { MODKEY, XK_t, setlayout, {.v = &layouts[0]} }, /* tile */ - { MODKEY|ShiftMask, XK_t, setlayout, {.v = &layouts[1]} }, /* bstack */ - { MODKEY, XK_y, setlayout, {.v = &layouts[2]} }, /* spiral */ - { MODKEY|ShiftMask, XK_y, setlayout, {.v = &layouts[3]} }, /* dwindle */ - { MODKEY, XK_u, setlayout, {.v = &layouts[4]} }, /* deck */ - { MODKEY|ShiftMask, XK_u, setlayout, {.v = &layouts[5]} }, /* monocle */ - { MODKEY, XK_i, setlayout, {.v = &layouts[6]} }, /* centeredmaster */ - { MODKEY|ShiftMask, XK_i, setlayout, {.v = &layouts[7]} }, /* centeredfloatingmaster */ - { MODKEY, XK_o, incnmaster, {.i = +1 } }, - { MODKEY|ShiftMask, XK_o, incnmaster, {.i = -1 } }, - { MODKEY, XK_backslash, view, {0} }, - { MODKEY, XK_a, togglegaps, {0} }, - { MODKEY|ShiftMask, XK_a, defaultgaps, {0} }, - { MODKEY, XK_s, togglesticky, {0} }, - { MODKEY, XK_f, togglefullscr, {0} }, - { MODKEY|ShiftMask, XK_f, setlayout, {.v = &layouts[8]} }, - { MODKEY, XK_g, shiftview, { .i = -1 } }, - { MODKEY|ShiftMask, XK_g, shifttag, { .i = -1 } }, - { MODKEY, XK_h, setmfact, {.f = -0.05} }, - { MODKEY, XK_l, setmfact, {.f = +0.05} }, - { MODKEY, XK_semicolon, shiftview, { .i = 1 } }, - { MODKEY|ShiftMask, XK_semicolon, shifttag, { .i = 1 } }, - { MODKEY, XK_apostrophe, togglescratch, {.ui = 1} }, - { MODKEY, XK_Return, spawn, {.v = termcmd } }, - { MODKEY|ShiftMask, XK_Return, togglescratch, {.ui = 0} }, - { MODKEY, XK_z, incrgaps, {.i = +3 } }, - { MODKEY, XK_x, incrgaps, {.i = -3 } }, - { MODKEY, XK_b, togglebar, {0} }, - { MODKEY|ShiftMask, XK_space, togglefloating, {0} }, - - { MODKEY|ShiftMask, XK_m, spawn, SHCMD("pamixer -t; kill -44 $(pidof dwmblocks)") }, - { MODKEY, XK_minus, spawn, SHCMD("pamixer --allow-boost -d 5; kill -44 $(pidof dwmblocks)") }, - { MODKEY|ShiftMask, XK_minus, spawn, SHCMD("pamixer --allow-boost -d 15; kill -44 $(pidof dwmblocks)") }, - { MODKEY, XK_equal, spawn, SHCMD("pamixer --allow-boost -i 5; kill -44 $(pidof dwmblocks)") }, - { MODKEY|ShiftMask, XK_equal, spawn, SHCMD("pamixer --allow-boost -i 15; kill -44 $(pidof dwmblocks)") }, - { 0, XF86XK_AudioMute, spawn, SHCMD("pamixer -t; kill -44 $(pidof dwmblocks)") }, - { 0, XF86XK_AudioRaiseVolume, spawn, SHCMD("pamixer --allow-boost -i 3; kill -44 $(pidof dwmblocks)") }, - { 0, XF86XK_AudioLowerVolume, spawn, SHCMD("pamixer --allow-boost -d 3; kill -44 $(pidof dwmblocks)") }, + /* modifier key function argument */ + STACKKEYS(MODKEY, focus) STACKKEYS(MODKEY | ShiftMask, push){ + MODKEY, XK_grave, spawn, SHCMD("dmenuunicode")}, + 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, XK_0, view, {.ui = ~0}}, + {MODKEY | ShiftMask, XK_0, tag, {.ui = ~0}}, + {MODKEY, XK_BackSpace, spawn, SHCMD("sysact")}, + {MODKEY | ShiftMask, XK_BackSpace, spawn, SHCMD("sysact")}, + {MODKEY | ShiftMask, XK_q, spawn, SHCMD("sysact")}, + {MODKEY, XK_Tab, view, {0}}, + {MODKEY, XK_q, killclient, {0}}, + + {MODKEY, XK_w, spawn, SHCMD("$BROWSER")}, + {MODKEY, XK_r, spawn, SHCMD(TERMINAL " -e ranger")}, + {MODKEY | ShiftMask, XK_r, spawn, SHCMD(TERMINAL " -e btm")}, + {MODKEY, XK_n, spawn, SHCMD(TERMINAL " -e gpuwatch")}, + {MODKEY, XK_space, spawn, SHCMD("dmenu_run")}, + + {MODKEY, XK_t, setlayout, {.v = &layouts[0]}}, /* tile */ + {MODKEY | ShiftMask, XK_t, setlayout, {.v = &layouts[1]}}, /* bstack */ + {MODKEY, XK_y, setlayout, {.v = &layouts[2]}}, /* spiral */ + {MODKEY | ShiftMask, XK_y, setlayout, {.v = &layouts[3]}}, /* dwindle */ + {MODKEY, XK_u, setlayout, {.v = &layouts[4]}}, /* deck */ + {MODKEY | ShiftMask, XK_u, setlayout, {.v = &layouts[5]}}, /* monocle */ + {MODKEY, XK_i, setlayout, {.v = &layouts[6]}}, /* centeredmaster */ + {MODKEY | ShiftMask, + XK_i, + setlayout, + {.v = &layouts[7]}}, /* centeredfloatingmaster */ + {MODKEY, XK_o, incnmaster, {.i = +1}}, + {MODKEY | ShiftMask, XK_o, incnmaster, {.i = -1}}, + {MODKEY, XK_backslash, view, {0}}, + {MODKEY, XK_a, togglegaps, {0}}, + {MODKEY | ShiftMask, XK_a, defaultgaps, {0}}, + {MODKEY, XK_s, togglesticky, {0}}, + {MODKEY, XK_f, togglefullscr, {0}}, + {MODKEY | ShiftMask, XK_f, setlayout, {.v = &layouts[8]}}, + {MODKEY, XK_g, shiftview, {.i = -1}}, + {MODKEY | ShiftMask, XK_g, shifttag, {.i = -1}}, + {MODKEY, XK_h, setmfact, {.f = -0.05}}, + {MODKEY, XK_l, setmfact, {.f = +0.05}}, + {MODKEY, XK_semicolon, shiftview, {.i = 1}}, + {MODKEY | ShiftMask, XK_semicolon, shifttag, {.i = 1}}, + {MODKEY, XK_apostrophe, togglescratch, {.ui = 1}}, + {MODKEY, XK_Return, spawn, {.v = termcmd}}, + {MODKEY | ShiftMask, XK_Return, togglescratch, {.ui = 0}}, + {MODKEY, XK_z, incrgaps, {.i = +3}}, + {MODKEY, XK_x, incrgaps, {.i = -3}}, + {MODKEY, XK_b, togglebar, {0}}, + {MODKEY | ShiftMask, XK_space, togglefloating, {0}}, + + {MODKEY | ShiftMask, XK_m, spawn, + SHCMD("pamixer -t; kill -44 $(pidof dwmblocks)")}, + {MODKEY, XK_minus, spawn, + SHCMD("pamixer --allow-boost -d 5; kill -44 $(pidof dwmblocks)")}, + {MODKEY | ShiftMask, XK_minus, spawn, + SHCMD("pamixer --allow-boost -d 15; kill -44 $(pidof dwmblocks)")}, + {MODKEY, XK_equal, spawn, + SHCMD("pamixer --allow-boost -i 5; kill -44 $(pidof dwmblocks)")}, + {MODKEY | ShiftMask, XK_equal, spawn, + SHCMD("pamixer --allow-boost -i 15; kill -44 $(pidof dwmblocks)")}, + {0, XF86XK_AudioMute, spawn, + SHCMD("pamixer -t; kill -44 $(pidof dwmblocks)")}, + {0, XF86XK_AudioRaiseVolume, spawn, + SHCMD("pamixer --allow-boost -i 3; kill -44 $(pidof dwmblocks)")}, + {0, XF86XK_AudioLowerVolume, spawn, + SHCMD("pamixer --allow-boost -d 3; kill -44 $(pidof dwmblocks)")}, }; /* button definitions */ -/* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */ +/* click can be ClkTagBar, ClkLtSymbol, ClkStatusText, ClkWinTitle, + * ClkClientWin, or ClkRootWin */ static Button buttons[] = { - /* click event mask button function argument */ +/* click event mask button function argument + */ #ifndef __OpenBSD__ - { ClkWinTitle, 0, Button2, zoom, {0} }, - { ClkStatusText, 0, Button1, sigdwmblocks, {.i = 1} }, - { ClkStatusText, 0, Button2, sigdwmblocks, {.i = 2} }, - { ClkStatusText, 0, Button3, sigdwmblocks, {.i = 3} }, - { ClkStatusText, 0, Button4, sigdwmblocks, {.i = 4} }, - { ClkStatusText, 0, Button5, sigdwmblocks, {.i = 5} }, - { ClkStatusText, ShiftMask, Button1, sigdwmblocks, {.i = 6} }, + {ClkWinTitle, 0, Button2, zoom, {0}}, + {ClkStatusText, 0, Button1, sigdwmblocks, {.i = 1}}, + {ClkStatusText, 0, Button2, sigdwmblocks, {.i = 2}}, + {ClkStatusText, 0, Button3, sigdwmblocks, {.i = 3}}, + {ClkStatusText, 0, Button4, sigdwmblocks, {.i = 4}}, + {ClkStatusText, 0, Button5, sigdwmblocks, {.i = 5}}, + {ClkStatusText, ShiftMask, Button1, sigdwmblocks, {.i = 6}}, #endif - { ClkStatusText, ShiftMask, Button3, spawn, SHCMD(TERMINAL " -e nvim ~/.local/src/dwmblocks/config.h") }, - { ClkClientWin, MODKEY, Button1, movemouse, {0} }, - { ClkClientWin, MODKEY, Button2, defaultgaps, {0} }, - { ClkClientWin, MODKEY, Button3, resizemouse, {0} }, - { ClkClientWin, MODKEY, Button4, incrgaps, {.i = +1} }, - { ClkClientWin, MODKEY, Button5, incrgaps, {.i = -1} }, - { ClkTagBar, 0, Button1, view, {0} }, - { ClkTagBar, 0, Button3, toggleview, {0} }, - { ClkTagBar, MODKEY, Button1, tag, {0} }, - { ClkTagBar, MODKEY, Button3, toggletag, {0} }, - { ClkTagBar, 0, Button4, shiftview, {.i = -1} }, - { ClkTagBar, 0, Button5, shiftview, {.i = 1} }, - { ClkRootWin, 0, Button2, togglebar, {0} }, + {ClkStatusText, ShiftMask, Button3, spawn, + SHCMD(TERMINAL " -e nvim ~/.local/src/dwmblocks/config.h")}, + {ClkClientWin, MODKEY, Button1, movemouse, {0}}, + {ClkClientWin, MODKEY, Button2, defaultgaps, {0}}, + {ClkClientWin, MODKEY, Button3, resizemouse, {0}}, + {ClkClientWin, MODKEY, Button4, incrgaps, {.i = +1}}, + {ClkClientWin, MODKEY, Button5, incrgaps, {.i = -1}}, + {ClkTagBar, 0, Button1, view, {0}}, + {ClkTagBar, 0, Button3, toggleview, {0}}, + {ClkTagBar, MODKEY, Button1, tag, {0}}, + {ClkTagBar, MODKEY, Button3, toggletag, {0}}, + {ClkTagBar, 0, Button4, shiftview, {.i = -1}}, + {ClkTagBar, 0, Button5, shiftview, {.i = 1}}, + {ClkRootWin, 0, Button2, togglebar, {0}}, }; -- cgit v1.2.3-70-g09d2