Procházet zdrojové kódy

Initial commit

master
= před 4 roky
revize
ef1a29d90e
57 změnil soubory, kde provedl 4982 přidání a 0 odebrání
  1. binární
      .TODO.swp
  2. binární
      .drw.c.swp
  3. binární
      .dwm.1.swp
  4. binární
      .dwm.c.swp
  5. +1
    -0
      .pc/.quilt_patches
  6. +1
    -0
      .pc/.quilt_series
  7. +1
    -0
      .pc/.version
  8. +113
    -0
      .pc/2001_replace_term_cmd.patch/config.def.h
  9. +38
    -0
      .pc/2002_inject_hardening_flags.patch/config.mk
  10. +60
    -0
      .pc/2003_transparent_makefile.patch/Makefile
  11. +38
    -0
      .pc/2004_use_system_searchpaths.patch/config.mk
  12. +4
    -0
      .pc/applied-patches
  13. binární
      .transient.c.swp
  14. binární
      .util.c.swp
  15. +44
    -0
      BUGS
  16. +33
    -0
      LICENSE
  17. +60
    -0
      Makefile
  18. +51
    -0
      README
  19. +4
    -0
      TODO
  20. +112
    -0
      config.def.h
  21. +35
    -0
      config.mk
  22. +863
    -0
      debian/changelog
  23. +1
    -0
      debian/clean
  24. +1
    -0
      debian/compat
  25. +39
    -0
      debian/control
  26. +45
    -0
      debian/copyright
  27. +7
    -0
      debian/desktop/dwm.desktop
  28. +1
    -0
      debian/dwm.docs
  29. +2
    -0
      debian/dwm.install
  30. +1
    -0
      debian/dwm.lintian-overrides
  31. +4
    -0
      debian/dwm.menu
  32. +29
    -0
      debian/dwm.postinst.in
  33. +29
    -0
      debian/dwm.prerm.in
  34. +1
    -0
      debian/dwm.wm
  35. binární
      debian/icons/dwm.png
  36. +120
    -0
      debian/local/config.maintainer.h
  37. +52
    -0
      debian/local/config.web.h
  38. +113
    -0
      debian/local/config.winkey.h
  39. +35
    -0
      debian/patches/2001_replace_term_cmd.patch
  40. +23
    -0
      debian/patches/2002_inject_hardening_flags.patch
  41. +71
    -0
      debian/patches/2003_transparent_makefile.patch
  42. +33
    -0
      debian/patches/2004_use_system_searchpaths.patch
  43. +3
    -0
      debian/patches/README
  44. +4
    -0
      debian/patches/series
  45. +32
    -0
      debian/rules
  46. +1
    -0
      debian/source/format
  47. +1
    -0
      debian/source/include-binaries
  48. +2
    -0
      debian/source/options
  49. +2
    -0
      debian/watch
  50. +398
    -0
      drw.c
  51. +74
    -0
      drw.h
  52. +176
    -0
      dwm.1
  53. +2141
    -0
      dwm.c
  54. binární
      dwm.png
  55. +42
    -0
      transient.c
  56. +33
    -0
      util.c
  57. +8
    -0
      util.h

binární
.TODO.swp Zobrazit soubor


binární
.drw.c.swp Zobrazit soubor


binární
.dwm.1.swp Zobrazit soubor


binární
.dwm.c.swp Zobrazit soubor


+ 1
- 0
.pc/.quilt_patches Zobrazit soubor

@@ -0,0 +1 @@
debian/patches

+ 1
- 0
.pc/.quilt_series Zobrazit soubor

@@ -0,0 +1 @@
series

+ 1
- 0
.pc/.version Zobrazit soubor

@@ -0,0 +1 @@
2

+ 113
- 0
.pc/2001_replace_term_cmd.patch/config.def.h Zobrazit soubor

@@ -0,0 +1,113 @@
/* See LICENSE file for copyright and license details. */

/* appearance */
static const char *fonts[] = {
"monospace:size=10"
};
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 = 1; /* 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[] = { "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 */
{ "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[] = { "st", NULL };

static Key keys[] = {
/* modifier key function argument */
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
{ 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[2]} },
{ 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} },
};


+ 38
- 0
.pc/2002_inject_hardening_flags.patch/config.mk Zobrazit soubor

@@ -0,0 +1,38 @@
# dwm version
VERSION = 6.1

# Customize below to fit your system

# paths
PREFIX = /usr/local
MANPREFIX = ${PREFIX}/share/man

X11INC = /usr/X11R6/include
X11LIB = /usr/X11R6/lib

# Xinerama, comment if you don't want it
XINERAMALIBS = -lXinerama
XINERAMAFLAGS = -DXINERAMA

# freetype
FREETYPELIBS = -lfontconfig -lXft
FREETYPEINC = /usr/include/freetype2
# OpenBSD (uncomment)
#FREETYPEINC = ${X11INC}/freetype2

# includes and libs
INCS = -I${X11INC} -I${FREETYPEINC}
LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}

# flags
CPPFLAGS = -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
#CFLAGS = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
CFLAGS = -std=c99 -pedantic -Wall -Wno-deprecated-declarations -Os ${INCS} ${CPPFLAGS}
LDFLAGS = -s ${LIBS}

# Solaris
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
#LDFLAGS = ${LIBS}

# compiler and linker
CC = cc

+ 60
- 0
.pc/2003_transparent_makefile.patch/Makefile Zobrazit soubor

@@ -0,0 +1,60 @@
# dwm - dynamic window manager
# See LICENSE file for copyright and license details.

include config.mk

SRC = drw.c dwm.c util.c
OBJ = ${SRC:.c=.o}

all: options dwm

options:
@echo dwm build options:
@echo "CFLAGS = ${CFLAGS}"
@echo "LDFLAGS = ${LDFLAGS}"
@echo "CC = ${CC}"

.c.o:
@echo CC $<
@${CC} -c ${CFLAGS} $<

${OBJ}: config.h config.mk

config.h:
@echo creating $@ from config.def.h
@cp config.def.h $@

dwm: ${OBJ}
@echo CC -o $@
@${CC} -o $@ ${OBJ} ${LDFLAGS}

clean:
@echo cleaning
@rm -f dwm ${OBJ} dwm-${VERSION}.tar.gz

dist: clean
@echo creating dist tarball
@mkdir -p dwm-${VERSION}
@cp -R LICENSE TODO BUGS Makefile README config.def.h config.mk \
dwm.1 drw.h util.h ${SRC} dwm.png transient.c dwm-${VERSION}
@tar -cf dwm-${VERSION}.tar dwm-${VERSION}
@gzip dwm-${VERSION}.tar
@rm -rf dwm-${VERSION}

install: all
@echo installing executable file to ${DESTDIR}${PREFIX}/bin
@mkdir -p ${DESTDIR}${PREFIX}/bin
@cp -f dwm ${DESTDIR}${PREFIX}/bin
@chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
@echo installing manual page to ${DESTDIR}${MANPREFIX}/man1
@mkdir -p ${DESTDIR}${MANPREFIX}/man1
@sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
@chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1

uninstall:
@echo removing executable file from ${DESTDIR}${PREFIX}/bin
@rm -f ${DESTDIR}${PREFIX}/bin/dwm
@echo removing manual page from ${DESTDIR}${MANPREFIX}/man1
@rm -f ${DESTDIR}${MANPREFIX}/man1/dwm.1

.PHONY: all options clean dist install uninstall

+ 38
- 0
.pc/2004_use_system_searchpaths.patch/config.mk Zobrazit soubor

@@ -0,0 +1,38 @@
# dwm version
VERSION = 6.1

# Customize below to fit your system

# paths
PREFIX = /usr/local
MANPREFIX = ${PREFIX}/share/man

X11INC = /usr/X11R6/include
X11LIB = /usr/X11R6/lib

# Xinerama, comment if you don't want it
XINERAMALIBS = -lXinerama
XINERAMAFLAGS = -DXINERAMA

# freetype
FREETYPELIBS = -lfontconfig -lXft
FREETYPEINC = /usr/include/freetype2
# OpenBSD (uncomment)
#FREETYPEINC = ${X11INC}/freetype2

# includes and libs
INCS = -I${X11INC} -I${FREETYPEINC}
LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}

# flags
CPPFLAGS += -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
#CFLAGS = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
CFLAGS += -std=c99 -pedantic -Wall -Wno-deprecated-declarations ${INCS} ${CPPFLAGS}
LDFLAGS += -s ${LIBS}

# Solaris
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
#LDFLAGS = ${LIBS}

# compiler and linker
CC = cc

+ 4
- 0
.pc/applied-patches Zobrazit soubor

@@ -0,0 +1,4 @@
2001_replace_term_cmd.patch
2002_inject_hardening_flags.patch
2003_transparent_makefile.patch
2004_use_system_searchpaths.patch

binární
.transient.c.swp Zobrazit soubor


binární
.util.c.swp Zobrazit soubor


+ 44
- 0
BUGS Zobrazit soubor

@@ -0,0 +1,44 @@
---

18:17 < Biolunar> when i change my resolution in dwm (to a smaller one) and then back to the native, the top bar is not repainted. that's since 5.7.2, in 5.6 it worked fine
18:19 < Biolunar> is it just happening to me or a (known) bug?
18:24 < Biolunar> and in addition, mplayers fullscreen is limited to the small resolution after i changed it back to the native

reproducible with xrandr -s but not with --output and --mode, strange

---

yet another corner case:
open a terminal, focus another monitor, but without moving the mouse
pointer there
if there is no client on the other monitor to get the focus, then the
terminal will be unfocused but it will accept input

---

Donald Allen reported this:

starting emacs from dmenu in archlinux results in missing configure of emacs, but mod1-space or mod1-shift-space fix this problem. this problem is new and did not happen in 1.6 xorg servers

---

voltaic reports this:

When I use two monitors, one larger in resolution than the other, the
bar is drawn using the smaller x-dimension on both screens. I think
what's happening is that there are two bars drawn, but the short bar
is always on top of the long bar such that I can't see the information
under the short bar. If I switch to the small screen, hide the short
bar, and then switch to the large screen, the long bar is drawn
correctly.

A similar problem occurs when I have started dwm on a small resolution
monitor (laptop screen) and then I switch to a large external display.
When I do this, the bar itself is drawn for the original smaller
resolution, but the information to be printed on the bar is
right-aligned for a longer bar. So what I see is a bar that has the
right hand side of it cut-off. See attached screenshot.

I am using standard options for xrandr such as --output VGA1 --auto, etc.

---

+ 33
- 0
LICENSE Zobrazit soubor

@@ -0,0 +1,33 @@
MIT/X Consortium License

© 2006-2014 Anselm R Garbe <anselm@garbe.us>
© 2010-2014 Hiltjo Posthuma <hiltjo@codemadness.org>
© 2007-2011 Peter Hartlich <sgkkr at hartlich dot com>
© 2010-2011 Connor Lane Smith <cls@lubutu.com>
© 2006-2009 Jukka Salmi <jukka at salmi dot ch>
© 2007-2009 Premysl Hruby <dfenze at gmail dot com>
© 2007-2009 Szabolcs Nagy <nszabolcs at gmail dot com>
© 2007-2009 Christof Musik <christof at sendfax dot de>
© 2009 Mate Nagy <mnagy at port70 dot net>
© 2007-2008 Enno Gottox Boland <gottox at s01 dot de>
© 2008 Martin Hurton <martin dot hurton at gmail dot com>
© 2008 Neale Pickett <neale dot woozle dot org>
© 2006-2007 Sander van Dijk <a dot h dot vandijk at gmail dot com>

Permission is hereby granted, free of charge, to any person obtaining a
copy of this software and associated documentation files (the "Software"),
to deal in the Software without restriction, including without limitation
the rights to use, copy, modify, merge, publish, distribute, sublicense,
and/or sell copies of the Software, and to permit persons to whom the
Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
DEALINGS IN THE SOFTWARE.

+ 60
- 0
Makefile Zobrazit soubor

@@ -0,0 +1,60 @@
# dwm - dynamic window manager
# See LICENSE file for copyright and license details.

include config.mk

SRC = drw.c dwm.c util.c
OBJ = ${SRC:.c=.o}

all: options dwm

options:
@echo dwm build options:
@echo "CFLAGS = ${CFLAGS}"
@echo "LDFLAGS = ${LDFLAGS}"
@echo "CC = ${CC}"

.c.o:
@echo CC $<
${CC} -c ${CFLAGS} $<

${OBJ}: config.h config.mk

config.h:
@echo creating $@ from config.def.h
cp config.def.h $@

dwm: ${OBJ}
@echo CC -o $@
${CC} -o $@ ${OBJ} ${LDFLAGS}

clean:
@echo cleaning
rm -f dwm ${OBJ} dwm-${VERSION}.tar.gz

dist: clean
@echo creating dist tarball
mkdir -p dwm-${VERSION}
cp -R LICENSE TODO BUGS Makefile README config.def.h config.mk \
dwm.1 drw.h util.h ${SRC} dwm.png transient.c dwm-${VERSION}
tar -cf dwm-${VERSION}.tar dwm-${VERSION}
gzip dwm-${VERSION}.tar
rm -rf dwm-${VERSION}

install: all
@echo installing executable file to ${DESTDIR}${PREFIX}/bin
mkdir -p ${DESTDIR}${PREFIX}/bin
cp -f dwm ${DESTDIR}${PREFIX}/bin
chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
@echo installing manual page to ${DESTDIR}${MANPREFIX}/man1
mkdir -p ${DESTDIR}${MANPREFIX}/man1
sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1

uninstall:
@echo removing executable file from ${DESTDIR}${PREFIX}/bin
rm -f ${DESTDIR}${PREFIX}/bin/dwm
@echo removing manual page from ${DESTDIR}${MANPREFIX}/man1
rm -f ${DESTDIR}${MANPREFIX}/man1/dwm.1

.PHONY: all options clean dist install uninstall

+ 51
- 0
README Zobrazit soubor

@@ -0,0 +1,51 @@
dwm - dynamic window manager
============================
dwm is an extremely fast, small, and dynamic window manager for X.


Requirements
------------
In order to build dwm you need the Xlib header files.


Installation
------------
Edit config.mk to match your local setup (dwm is installed into
the /usr/local namespace by default).

Afterwards enter the following command to build and install dwm (if
necessary as root):

make clean install

If you are going to use the default bluegray color scheme it is highly
recommended to also install the bluegray files shipped in the dextra package.


Running dwm
-----------
Add the following line to your .xinitrc to start dwm using startx:

exec dwm

In order to connect dwm to a specific display, make sure that
the DISPLAY environment variable is set correctly, e.g.:

DISPLAY=foo.bar:1 exec dwm

(This will start dwm on display :1 of the host foo.bar.)

In order to display status info in the bar, you can do something
like this in your .xinitrc:

while xsetroot -name "`date` `uptime | sed 's/.*,//'`"
do
sleep 1
done &
exec dwm


Configuration
-------------
The configuration of dwm is done by creating a custom config.h
and (re)compiling the source code.

+ 4
- 0
TODO Zobrazit soubor

@@ -0,0 +1,4 @@
- add a flag to Key to execute the command on release (needed for commands
affecting the keyboard grab, see scrot -s for example)
- add updategeom() hook for external tools like dzen
- consider onscreenkeyboard hooks for tablet deployment

+ 112
- 0
config.def.h Zobrazit soubor

@@ -0,0 +1,112 @@
/* See LICENSE file for copyright and license details. */

/* appearance */
static const char *fonts[] = {
"monospace:size=10"
};
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 = 1; /* 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[] = { "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 */
{ "Gimp", NULL, NULL, 0, 1, -1 },
{ "Iceweasel", 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[] = { "x-terminal-emulator", NULL };

static Key keys[] = {
/* modifier key function argument */
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
{ 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[2]} },
{ 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} },
};

+ 35
- 0
config.mk Zobrazit soubor

@@ -0,0 +1,35 @@
# dwm version
VERSION = 6.1

# Customize below to fit your system

# paths
PREFIX = /usr/local
MANPREFIX = ${PREFIX}/share/man

# Xinerama, comment if you don't want it
XINERAMALIBS = -lXinerama
XINERAMAFLAGS = -DXINERAMA

# freetype
FREETYPELIBS = -lfontconfig -lXft
FREETYPEINC = /usr/include/freetype2
# OpenBSD (uncomment)
#FREETYPEINC = ${X11INC}/freetype2

# includes and libs
INCS = -I${FREETYPEINC}
LIBS = -lX11 ${XINERAMALIBS} ${FREETYPELIBS}

# flags
CPPFLAGS += -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
#CFLAGS = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
CFLAGS += -std=c99 -pedantic -Wall -Wno-deprecated-declarations ${INCS} ${CPPFLAGS}
LDFLAGS += -s ${LIBS}

# Solaris
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
#LDFLAGS = ${LIBS}

# compiler and linker
CC = cc

+ 863
- 0
debian/changelog Zobrazit soubor

@@ -0,0 +1,863 @@
dwm (6.1-5) unstable; urgency=medium

* debian/control:
- Bump Standards-Version to 4.1.5 (no changes needed).
- Update debhelper dependency to >= 11 instead of >= 10.
- Update Vcs-* fields (Salsa migration).
* debian/copyright:
- Update copyright years.
* Bump compat level to 11.
* Bump debian/watch version to 4 and use HTTPS protocol.
* Get rid of trailing whitespaces in debian/changelog.

-- Hugo Lefeuvre <hle@debian.org> Sat, 21 Jul 2018 10:16:54 -0400

dwm (6.1-4) unstable; urgency=medium

* debian/control:
- Bump Standards-Version to 4.0.0 (no changes needed).
- Update debhelper dependency to >= 10 instead of >= 9.
* debian/copyright:
- Update copyright years.
* Bump compat level to 10.
* Revert changes to config.web.h introduced in 6.1-1 (Closes: #857174).

-- Hugo Lefeuvre <hle@debian.org> Wed, 30 Aug 2017 12:12:50 +0200

dwm (6.1-3) unstable; urgency=low

* debian/control:
- Bump Standards-Version to 3.9.8 (no changes needed).
* debian/rules:
- Make dwm repoducible by sorting header files before processing them
(acknowledgements to Reiner Herrmann for the patch) (Closes: #825545).
* debian/patches/2004_use_system_searchpaths.patch:
- Use HTTPS protocol in the BTS link.
* debian/copyright:
- Update Format field to match DEP5 recommandations.
- Use 'Expat' instead of 'MIT'.

-- Hugo Lefeuvre <hle@debian.org> Sun, 19 Jun 2016 13:23:37 +0200

dwm (6.1-2) unstable; urgency=low

* Upload to unstable.
* debian/control:
- Fix broken Vcs-Git link.
* debian/copyright:
- Fix broken link in the Format field.

-- Hugo Lefeuvre <hle@debian.org> Mon, 28 Mar 2016 11:47:52 +0200

dwm (6.1-1) experimental; urgency=low

* New upstream release.
* debian/control:
- Bump Standards-Version to 3.9.7.
- Add a dependency on libxft-dev and libfreetype6-dev to match
new release requirements.
- Replace uxterm by stterm in the Recommends field to match new release
recommendations.
- Fix broken Vcs-Browser field.
- Update Vcs-Git field to use an encrypted transport protocol.
* debian/copyright:
- Update copyright years.
* debian/watch:
- Change link to point to the official git repository (releases
are more up-to-date there).
* debian/patches/*:
- Refresh patches for new upstream release.
* debian/local/*:
- Refresh config files for new upstream release.
* debian/rules:
- Enable all hardening options to compile as a PIE and add the bindnow
flag.

-- Hugo Lefeuvre <hle@debian.org> Sun, 27 Mar 2016 15:12:02 +0100

dwm (6.0-8) unstable; urgency=low

* New Maintainer (Closes: #793985).
* debian/control:
- Update the Maintainer field with the new maintainer name.
- Bump Standards-Version to 3.9.6 (no changes needed).
- Use https for the Vcs-Browser field.
* debian/copyright:
- Add a copyright entry to mention Hugo's work.
- Use https for the Format field.

-- Hugo Lefeuvre <hle@debian.org> Fri, 25 Sep 2015 16:14:43 +0200

dwm (6.0-7) unstable; urgency=medium

* Fix the override file, Thanks to intrigeri for hints.
* Bump Standards-Version to 3.9.5, no change required.
* Use cgit URL for Vcs-Browser field.

-- Vasudev Kamath <kamathvasudev@gmail.com> Thu, 02 Oct 2014 22:21:08 +0530

dwm (6.0-6) unstable; urgency=low

* Introduce a missing new line in patch which makes it unusable.
Closes: bug#722994. Thanks to Mats Erik Andersson.
* Renamed patches to follow patch tagging micro guidelines
debian/patches/README.
* Add debian/patches/README documenting patch numbering micro policy.
* Strip trailing space in 2001_replace_term_cmd.patch
* Add patch 2004 removing reference to custom library paths and include
paths, fixing FTBFS on mips*.
Closes: bug#722765. Thanks to YunQiang Su.
* Update 2001 patch to change rule to use Iceweasel instead of Firefox.
Closes: bug#710180. Thanks to Daniel Gazda.
* Changed maintainer specific configuration, to use xfce4-terminal in
rule specific to terminals instead of x-terminal-emulator.

-- Vasudev Kamath <kamathvasudev@gmail.com> Sun, 15 Sep 2013 20:34:14 +0530

dwm (6.0-5) unstable; urgency=low

* debian/control
+ Changed Homepage to http://dwm.suckless.org thanks to David Kalnischkies
for pointing out
+ Increased minimum debhelper required to 9
+ Removed DM-Upload-Allowed field as it will be deprecated soon.
+ Bumped Standards-Version to 3.9.4, this didn't require any change to the
package source.
+ Added dependency on xterm | x-terminal-emulator
* Set debian/compat to 9
* debian/rules
+ Removed hardening related lines. Since dwm package now uses compat level 9
hardening will be automagically done by debhelper
* debian/local/config.maintainer.h:
+ Changed tag 1 class to x-terminal-emulator so any terminal conforming to
this virtual package will be placed in tag 1

-- Vasudev Kamath <kamathvasudev@gmail.com> Sat, 11 May 2013 12:26:44 +0530

dwm (6.0-4) unstable; urgency=low

* debian/rules:
+ Fixed the way dpkg-buildflags were used in rules by removing conditional
check on buidlflags.mk
* debian/control:
+ Added dependency on dpkg-dev (>= 1.16.1.1) to remove conditional check for
existence of dpkg-buildflags in rules file
+ Bumped Standards-Version to 3.9.3. No changes required to package.
* debian/local/config.maintainer.h:
+ Added tag rules for few more applications

-- Vasudev Kamath <kamathvasudev@gmail.com> Thu, 14 Jun 2012 20:37:51 +0530

dwm (6.0-3) unstable; urgency=low

* debian/patches:
+ Renamed all patches to contain numbers in their name.
+ Modified 02-dpkg-buildflags.patch to remove -Os from config.mk
to allow DEB_BUILD_OPTIONS=noopt
+ Added 03-transparent-makefile.patch to make command execution in Makefile
visible.
* debian/clean:
+ Remove config.h generated during compiling of package

-- Vasudev Kamath <kamathvasudev@gmail.com> Sun, 19 Feb 2012 15:32:47 +0530

dwm (6.0-2) unstable; urgency=low

* New alternative dwm.winkey is added. This uses windows key as modifier
* New alternative dwm.maintainers is added. This is the configuration used
by the current dwm maintainer
* Reverted config.def.h and config.mk to upstream version

[Kartik Mistry]
* debian/control:
+ Added 'DM-Upload-Allowed: yes' field.

-- Vasudev Kamath <kamathvasudev@gmail.com> Thu, 02 Feb 2012 16:39:09 +0530

dwm (6.0-1) unstable; urgency=low

* Imported Upstream version 6.0
* debian/local/config.web.h
+ Added missing variable 'nmaster'

-- Vasudev Kamath <kamathvasudev@gmail.com> Wed, 21 Dec 2011 22:15:39 +0530

dwm (5.9-1) unstable; urgency=low

* New Maintainer (Closes: #647088)
* Watch file is added
* Imported Upstream version 5.9
* debian/control
+ Added myself as maintainer
+ Vcs-* fields now point to collab-maint git repository
+ Bumped Standards-Version to 3.9.2
* debian/copyright
+ Added dep5 header
+ Added myself to list of copyright holders for debian folder
+ Cosmetic changes
+ Removed extra license block
* debian/rules
+ Applied a patch provided by David Kalnischkies (Closes: #493819)

-- Vasudev Kamath <kamathvasudev@gmail.com> Sun, 20 Nov 2011 21:32:50 +0530

dwm (5.8.2-4) unstable; urgency=high

* Fix "dwm doesn't work, black screen" <fix build script to clean config.h>
(Closes: #618401)
* Fix "Package description describes old behaviour" <removed text> (Closes:
#615154)
* Fix "startx, dwm shows error messages on a non functional fullscreen
xterm" <same as #618401> (Closes: #606985)

-- Kai Hendry <hendry@iki.fi> Sun, 03 Apr 2011 17:04:21 +0000

dwm (5.8.2-3) unstable; urgency=low

* New maintainer

-- Kai Hendry <hendry@iki.fi> Sat, 04 Dec 2010 11:47:07 +0000

dwm (5.8.2-2) experimental; urgency=low

* Updating recommends on suckless-tools, formerly dwm-tools.
* Updating standards version to 3.9.0.
* Updating to standards version 3.9.1.
* Switching to source format 3.0 (quilt).
* Updating to debhelper version 8.

-- Daniel Baumann <daniel@debian.org> Mon, 29 Nov 2010 21:13:21 +0100

dwm (5.8.2-1) unstable; urgency=low

* Merging upstream version 5.8.2.

-- Daniel Baumann <daniel@debian.org> Fri, 04 Jun 2010 17:25:28 +0200

dwm (5.8.1-2) unstable; urgency=low

* Adding now apparently mandatory extension for xsession desktop files
(Closes: #574742).

-- Daniel Baumann <daniel@debian.org> Tue, 01 Jun 2010 07:32:34 +0200

dwm (5.8.1-1) unstable; urgency=low

* Merging upstream version 5.8.1.

-- Daniel Baumann <daniel@debian.org> Sat, 29 May 2010 20:01:34 +0200

dwm (5.8-1) unstable; urgency=low

* Merging upstream version 5.8.
* Updating year in copyright file.
* Removing strip.patch, not required anymore.
* Renumbering patches files.

-- Daniel Baumann <daniel@debian.org> Sat, 29 May 2010 14:45:04 +0200

dwm (5.7.2-2) unstable; urgency=low

* Adding explicit debian source version 1.0 until switch to 3.0.
* Updating year in copyright file.
* Updating to standards 3.8.4.
* Updating lintian overrides.
* Sorting dh call in rules to more common order.
* Updating README.source.

-- Daniel Baumann <daniel@debian.org> Wed, 07 Apr 2010 00:36:04 +0200

dwm (5.7.2-1) unstable; urgency=low

* Merging upstream version 5.7.2.
* Wrapping build-depends.

-- Daniel Baumann <daniel@debian.org> Sat, 03 Oct 2009 16:44:37 +0200

dwm (5.7.1-1) unstable; urgency=low

* Merging upstream version 5.7.1.
* Bumping versioned build-depends on debhelper.
* Bumping versioned build-depends on quilt.

-- Daniel Baumann <daniel@debian.org> Sat, 03 Oct 2009 16:42:13 +0200

dwm (5.7-1) unstable; urgency=low

* Adding maintainer homepage field to control.
* Marking maintainer homepage field to be also included in binary
packages and changelog.
* Adding README.source.
* Merging upstream version 5.7.
* Moving maintainer homepage from control to copyright.
* Updating README.source.

-- Daniel Baumann <daniel@debian.org> Sat, 03 Oct 2009 16:38:25 +0200

dwm (5.6.1-2) unstable; urgency=low

* Updating maintainer field.
* Updating vcs fields.
* Updating package to standards version 3.8.3.
* Sorting depends.
* Prefixing debhelper files with package name.
* Minimizing rules file.

-- Daniel Baumann <daniel@debian.org> Thu, 20 Aug 2009 17:57:52 +0200

dwm (5.6.1-1) unstable; urgency=low

* Merging upstream version 5.6.1.

-- Daniel Baumann <daniel@debian.org> Mon, 27 Jul 2009 13:54:25 +0200

dwm (5.6-2) unstable; urgency=low

[ Kai Hendry ]
* Updating Webconverger config.

-- Daniel Baumann <daniel@debian.org> Tue, 14 Jul 2009 23:06:29 +0200

dwm (5.6-1) unstable; urgency=low

[ Daniel Baumann ]
* Merging upstream version 5.6.
* Rediffing strip.dpatch.
* Removing font.dpatch, not required anymore.

[ Kai Hendry ]
* Updating Webconverger config.

[ Daniel Baumann ]
* Using quilt rather than dpatch.
* Updating year in copyright file.
* Updating package to standards version 3.8.2.
* Adding description in menu file.
* Updating rules to current state of the art.

-- Daniel Baumann <daniel@debian.org> Tue, 14 Jul 2009 22:21:42 +0200

dwm (5.5-1) unstable; urgency=low

* Adding x11-xserver-utils to recommends (Closes: #516640).
* Merging upstream version 5.5.
* Using correct rfc-2822 date formats in changelog.

-- Daniel Baumann <daniel@debian.org> Mon, 18 May 2009 12:00:58 +0200

dwm (5.4.1-1) unstable; urgency=low

* Merging upstream version 5.4.1.

-- Daniel Baumann <daniel@debian.org> Tue, 10 Feb 2009 15:57:00 +0100

dwm (5.4-1) unstable; urgency=low

* Merging upstream version 5.4.

-- Daniel Baumann <daniel@debian.org> Tue, 10 Feb 2009 15:52:00 +0100

dwm (5.3.1-2) unstable; urgency=low

* Setting selfgcolor in web config to black.
* Renaming tag to shortname 'web' instead of 'webconverger'. However,
this isn't visible anyway, but for cosemtics.

-- Daniel Baumann <daniel@debian.org> Mon, 22 Dec 2008 12:24:00 +0100

dwm (5.3.1-1) unstable; urgency=low

* Merging upstream version 5.3.1 (Closes: #508296).

-- Daniel Baumann <daniel@debian.org> Sun, 14 Dec 2008 21:39:00 +0100

dwm (5.3-1) unstable; urgency=low

[ Daniel Baumann ]
* Using patch-stamp rather than patch in rules file.
* Replacing obsolete dh_clean -k with dh_prep.
* Merging upstream version 5.3.

[ Kai Hendry ]
* Updating Webconverger config.

-- Daniel Baumann <daniel@debian.org> Sun, 14 Dec 2008 21:33:00 +0100

dwm (5.2-1) unstable; urgency=low

[ Daniel Baumann ]
* Updating vcs fields in control file.
* Merging upstream version 5.2 (Closes: #498738).

[ Kai Hendry ]
* Updating Webconverger config.

-- Daniel Baumann <daniel@debian.org> Wed, 17 Sep 2008 16:28:00 +0200

dwm (5.1-1) unstable; urgency=low

[ Daniel Baumann ]
* Adding build-depends to libxinerama-dev.
* Reordering rules file.
* Correcting icon entry in desktop file.
* Using lintian debhelper to install lintian overrides.
* Rediffing terminal patch.
* Rediffing font patch.
* Adding patch from Tiago Saboga <tiagosaboga@gmail.com> to respect nostrip
(Closes: #436781).
* Rewriting copyright file in machine-interpretable format.
* Adding vcs fields to control file.
* Upgrading package to standards 3.8.0.
* Upgrading package to debhelper 7.
* Merging upstream version 5.1.

[ Kai Hendry ]
* Updating Webconverger config.

-- Daniel Baumann <daniel@debian.org> Sun, 03 Aug 2008 17:05:00 +0200

dwm (4.7-3) unstable; urgency=low

[ Kay Hendry ]
* Updating web config.

-- Daniel Baumann <daniel@debian.org> Mon, 21 Jan 2008 21:22:00 +0100

dwm (4.7-2) unstable; urgency=low

* Bumping standards version.
* Using new homepage field in control.
* Don't hide make errors in clean target of rules.
* Updating menu file to new policy version.

-- Daniel Baumann <daniel@debian.org> Sun, 23 Dec 2007 13:41:00 +0100

dwm (4.7-1) unstable; urgency=low

* New upstream release.
* Setting default font to fixed.
* Fixing webc config again.

-- Daniel Baumann <daniel@debian.org> Fri, 23 Nov 2007 21:48:00 +0100

dwm (4.6-1) unstable; urgency=low

* New upstream release.
* Updated webc config.

-- Daniel Baumann <daniel@debian.org> Fri, 16 Nov 2007 12:01:00 +0100

dwm (4.5-2) unstable; urgency=medium

* Fixed clean target to respect the config.h changes from dwm 4.4 to dwm
4.5 wrt/ applying and deapplying patches.

-- Daniel Baumann <daniel@debian.org> Sun, 14 Oct 2007 13:24:00 +0200

dwm (4.5-1) unstable; urgency=low

* New upstream release:
- Upstream switched from multiple config.*.h to one single config.h.
This means, that user customized configs must be put into debian/config,
because additional config.*.h are not detected anymore.
A side effect of this is, that the previous 'problem' of changed
contents of the package after several builds with user configs goes
away (Closes: #441701).

-- Daniel Baumann <daniel@debian.org> Sat, 29 Sep 2007 16:11:00 +0200

dwm (4.4.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Sun, 26 Aug 2007 14:10:00 +0200

dwm (4.4-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 23 Aug 2007 21:06:00 +0200

dwm (4.3-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Sat, 14 Jul 2007 21:22:00 +0200

dwm (4.2-3) unstable; urgency=low

* Fixed typo in menu longtitle as found by Bill Allombert
<ballombe@debian.org> (Closes: #428520).

-- Daniel Baumann <daniel@debian.org> Tue, 12 Jun 2007 13:06:00 +0200

dwm (4.2-2) unstable; urgency=low

[ Kai Hendri ]
* Updated the web config to have no top bar.

-- Daniel Baumann <daniel@debian.org> Tue, 05 Jun 2007 18:13:00 +0200

dwm (4.2-1) unstable; urgency=low

* New upstrema release.

-- Daniel Baumann <daniel@debian.org> Fri, 01 Jun 2007 18:52:00 +0200

dwm (4.1-1) unstable; urgency=low

* New upstrema release.

-- Daniel Baumann <daniel@debian.org> Mon, 21 May 2007 15:35:00 +0200

dwm (4.0-2) unstable; urgency=low

* Rebuild against fixed debhelper, see #420158 (Closes: #420120, #420140).

-- Daniel Baumann <daniel@debian.org> Sat, 21 Apr 2007 07:30:00 +0200

dwm (4.0-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 19 Apr 2007 10:22:00 +0200

dwm (3.9-3) unstable; urgency=low

* Fixed typo in rules.

-- Daniel Baumann <daniel@debian.org> Thu, 05 Apr 2007 08:35:00 +0200

dwm (3.9-2) unstable; urgency=low

[ Daniel Baumann ]
* Adding debian/configs for local configuration files.

[ Kai Hendri ]
* Made a new web configuration for webconverger.

-- Daniel Baumann <daniel@debian.org> Mon, 02 Apr 2007 18:20:00 +0200

dwm (3.9-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 02 Apr 2007 14:15:00 +0200

dwm (3.8-4) unstable; urgency=low

* If a user puts his config in config.h or config.user.h, it's configuration
is not overwritten anymore, but included as dwm.user binary into the debian
package (Closes: #415587).

-- Daniel Baumann <daniel@debian.org> Mon, 26 Mar 2007 16:51:00 +0100

dwm (3.8-3) unstable; urgency=low

* Removed left-over from alternative config.

-- Daniel Baumann <daniel@debian.org> Mon, 19 Mar 2007 19:41:00 +0100

dwm (3.8-2) unstable; urgency=low

* Added alternative configuration provided by Kai Hendry <hendry@iki.fi>.

-- Daniel Baumann <daniel@debian.org> Mon, 05 Mar 2007 15:20:00 +0100

dwm (3.8-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 05 Mar 2007 15:20:00 +0100

dwm (3.7-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Sat, 24 Feb 2007 19:00:00 +0100

dwm (3.6.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 21 Feb 2007 13:11:00 +0100

dwm (3.5-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 13 Feb 2007 10:19:00 +0100

dwm (3.4-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 07 Feb 2007 13:31:00 +0100

dwm (3.3-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 01 Feb 2007 09:30:00 +0100

dwm (3.2.2-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 25 Jan 2007 11:51:00 +0100

dwm (3.2.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 24 Jan 2007 21:20:00 +0100

dwm (3.2-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 24 Jan 2007 13:05:00 +0100

dwm (3.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Tue, 16 Jan 2007 14:52:00 +0100

dwm (3.0-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Fri, 12 Jan 2007 21:49:00 +0100

dwm (2.9-1) unstable; urgency=low

* New upstream release:
- dropping 02-configuration.dpatch, dwm contains now 9 tags per default.

-- Daniel Baumann <daniel@debian.org> Mon, 08 Jan 2007 16:26:00 +0100

dwm (2.8-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Tue, 02 Jan 2007 15:46:00 +0100

dwm (2.7-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 14 Dec 2006 09:28:00 +0100

dwm (2.6-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 07 Dec 2006 16:03:00 +0100

dwm (2.5.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 04 Dec 2006 22:01:00 +0100

dwm (2.5-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 04 Dec 2006 16:19:00 +0100

dwm (2.4-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 30 Nov 2006 14:44:00 +0100

dwm (2.3-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 26 Nov 2006 15:15:00 +0100

dwm (2.2-2) unstable; urgency=medium

* Forgot to assign keystrokes for the additional desktops.

-- Daniel Baumann <daniel@debian.org> Thu, 23 Nov 2006 21:17:00 +0100

dwm (2.2-1) unstable; urgency=medium

* New upstream release:
- contains some code cleanups and a minor fixes.

-- Daniel Baumann <daniel@debian.org> Tue, 21 Nov 2006 10:09:00 +0100

dwm (2.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 02 Nov 2006 12:00:00 +0100

dwm (2.0-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Tue, 31 Oct 2006 12:11:00 +0100

dwm (1.9+fixed-4) unstable; urgency=medium

* Updated upstream URL, removed watch file.

-- Daniel Baumann <daniel@debian.org> Sun, 29 Oct 2006 15:29:00 +0100

dwm (1.9+fixed-3) unstable; urgency=medium

* Added recommends to dmenu.

-- Daniel Baumann <daniel@debian.org> Thu, 12 Oct 2006 15:13:00 +0200

dwm (1.9+fixed-2) unstable; urgency=medium

* Added recommends to dwm-tools.

-- Daniel Baumann <daniel@debian.org> Thu, 12 Oct 2006 15:12:00 +0200

dwm (1.9+fixed-1) unstable; urgency=low

* Upstream did change the released tarball again, reuploading the
fixed one. See
<http://www.10kloc.org/pipermail/dwm/2006-October/001004.html> for more
information.

-- Daniel Baumann <daniel@debian.org> Fri, 06 Oct 2006 14:19:00 +0200

dwm (1.9-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Fri, 06 Oct 2006 13:59:00 +0200

dwm (1.8-1) unstable; urgency=low

* New upstream release.
* Removing alternatives again, upstream of the patches cannot keep up with
the upstream of dwm.

-- Daniel Baumann <daniel@debian.org> Thu, 05 Oct 2006 20:37:00 +0200

dwm (1.7.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 02 Oct 2006 19:52:00 +0200

dwm (1.6-3) unstable; urgency=low

* Added sticky-layout patch from Julian Romero <julian.romero+dwm@gmail.com>.
* Now building alternative binaries:
- normal: /usr/bin/dwm.normal
- sticky-layout: /usr/bin/dwm.sticky-layout
- wide-layout: /usr/bin/dwm.wide-layout
- /usr/bin/dwm is handled through update-alternatives.
* Added lintian override.

-- Daniel Baumann <daniel@debian.org> Sat, 23 Sep 2006 19:09:00 +0200

dwm (1.6-2) unstable; urgency=low

* Adding wide-layout patch from Ross Mohn <rpmohn@waxandwane.org>.

-- Daniel Baumann <daniel@debian.org> Tue, 19 Sep 2006 23:56:00 +0200

dwm (1.6-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Sat, 16 Sep 2006 11:34:00 +0200

dwm (1.5-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Fri, 08 Sep 2006 14:33:00 +0200

dwm (1.4+fixed-1) unstable; urgency=low

* Upstream did upload the 1.4 tarball without a z-layer fix, therefore
re-uploading 1.4. See
<http://www.10kloc.org/pipermail/dwm/2006-September/000664.html> for more
information.

-- Daniel Baumann <daniel@debian.org> Wed, 06 Sep 2006 12:50:00 +0200

dwm (1.4-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 06 Sep 2006 11:59:00 +0200

dwm (1.3-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Tue, 05 Sep 2006 01:38:00 +0200

dwm (1.2-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 30 Aug 2006 20:01:00 +0200

dwm (1.1-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 28 Aug 2006 10:36:00 +0200

dwm (1.0-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Tue, 24 Aug 2006 14:10:00 +0200

dwm (0.9-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Tue, 15 Aug 2006 10:54:00 +0200

dwm (0.8-2) unstable; urgency=low

* Updated description.

-- Daniel Baumann <daniel@debian.org> Sun, 13 Aug 2006 19:35:00 +0200

dwm (0.8-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Thu, 10 Aug 2006 17:30:00 +0200

dwm (0.7-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Mon, 07 Aug 2006 14:42:00 +0200

dwm (0.6-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Wed, 02 Aug 2006 17:08:00 +0200

dwm (0.5-1) unstable; urgency=low

* New upstream release.

-- Daniel Baumann <daniel@debian.org> Fri, 21 Jul 2006 21:24:00 +0200

dwm (0.4-1) unstable; urgency=low

* Initial release.

-- Daniel Baumann <daniel@debian.org> Thu, 20 Jul 2006 12:52:00 +0200

+ 1
- 0
debian/clean Zobrazit soubor

@@ -0,0 +1 @@
config.h

+ 1
- 0
debian/compat Zobrazit soubor

@@ -0,0 +1 @@
11

+ 39
- 0
debian/control Zobrazit soubor

@@ -0,0 +1,39 @@
Source: dwm
Section: x11
Priority: optional
Maintainer: Hugo Lefeuvre <hle@debian.org>
Build-Depends: debhelper (>= 11),
libx11-dev,
libxinerama-dev,
libxft-dev,
libfreetype6-dev,
dpkg-dev (>= 1.16.1.1)
Standards-Version: 4.1.5
Homepage: http://dwm.suckless.org/
Vcs-Browser: https://salsa.debian.org/hle/dwm
Vcs-Git: https://salsa.debian.org/hle/dwm.git

Package: dwm
Architecture: any
Depends: ${misc:Depends},
${shlibs:Depends}
Recommends: suckless-tools, x11-xserver-utils, stterm | x-terminal-emulator
Provides: x-window-manager
Description: dynamic window manager
dwm is a minimalistic window manager. It manages windows in tiling and floating
modes. Either mode can be applied dynamically, depending on the application in
use and the task performed.
.
In tiling mode windows are managed in a master and stacking column. The master
column contains the window which needs most attention at a time, whereas the
stacking column contains all other windows in a stack. Dialog windows are
managed floating, however.
.
In floating mode windows can be resized and moved freely. Windows are grouped
by tags. All windows with a specific tag can be viewed at a time. But each
window may contain more than one tag, which makes it visible in several views.
.
Please notice that dwm is currently customized through editing its source code,
so you probably want to build your own dwm packages. This package is compiled
with the default configuration and should just give you an idea about what dwm
brings to your desktop.

+ 45
- 0
debian/copyright Zobrazit soubor

@@ -0,0 +1,45 @@
Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
Upstream-Name: dwm
Source: http://dwm.suckless.org

Files: *
Copyright: © 2006-2014 Anselm R Garbe <anselm@garbe.us>
© 2010-2014 Hiltjo Posthuma <hiltjo@codemadness.org>
© 2007-2011 Peter Hartlich <sgkkr at hartlich dot com>
© 2010-2011 Connor Lane Smith <cls@lubutu.com>
© 2006-2009 Jukka Salmi <jukka at salmi dot ch>
© 2007-2009 Premysl Hruby <dfenze at gmail dot com>
© 2007-2009 Szabolcs Nagy <nszabolcs at gmail dot com>
© 2007-2009 Christof Musik <christof at sendfax dot de>
© 2009 Mate Nagy <mnagy at port70 dot net>
© 2007-2008 Enno Gottox Boland <gottox at s01 dot de>
© 2008 Martin Hurton <martin dot hurton at gmail dot com>
© 2008 Neale Pickett <neale dot woozle dot org>
© 2006-2007 Sander van Dijk <a dot h dot vandijk at gmail dot com>
License: Expat

Files: debian/*
Copyright: (C) 2015-2018 Hugo Lefeuvre <hle@debian.org>
(C) 2011 Vasudev Kamath <kamathvasudev@gmail.com>
(C) 2010 Kai Hendry <hendry@iki.fi>
(C) 2006-2010 Daniel Baumann <daniel@debian.org>
License: Expat

License: Expat
Permission is hereby granted, free of charge, to any person obtaining a
copy of this software and associated documentation files (the "Software"),
to deal in the Software without restriction, including without limitation
the rights to use, copy, modify, merge, publish, distribute, sublicense,
and/or sell copies of the Software, and to permit persons to whom the
Software is furnished to do so, subject to the following conditions:
.
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
DEALINGS IN THE SOFTWARE.

+ 7
- 0
debian/desktop/dwm.desktop Zobrazit soubor

@@ -0,0 +1,7 @@
[Desktop Entry]
Encoding=UTF-8
Name=Dwm
Comment=Dynamic window manager
Exec=dwm
Icon=dwm
Type=XSession

+ 1
- 0
debian/dwm.docs Zobrazit soubor

@@ -0,0 +1 @@
README

+ 2
- 0
debian/dwm.install Zobrazit soubor

@@ -0,0 +1,2 @@
debian/desktop/* /usr/share/xsessions
debian/icons/* /usr/share/icons

+ 1
- 0
debian/dwm.lintian-overrides Zobrazit soubor

@@ -0,0 +1 @@
dwm: menu-command-not-in-package

+ 4
- 0
debian/dwm.menu Zobrazit soubor

@@ -0,0 +1,4 @@
?package(dwm):needs="wm" section="Window Managers"\
title="Dwm" longtitle="Dynamic window manager" \
description="Dwm is a minimalistic window manager."\
command="/usr/bin/dwm"

+ 29
- 0
debian/dwm.postinst.in Zobrazit soubor

@@ -0,0 +1,29 @@
#!/bin/sh

set -e

ALTERNATIVES="@ALTERNATIVES@"

case "${1}" in
configure)
update-alternatives --quiet --install /usr/bin/dwm dwm /usr/bin/dwm.default 100

for ALTERNATIVE in ${ALTERNATIVES}
do
update-alternatives --quiet --install /usr/bin/dwm dwm /usr/bin/dwm.${ALTERNATIVE} 50
done
;;

abort-upgrade|abort-remove|abort-deconfigure)

;;

*)
echo "postinst called with unknown argument \`${1}'" >&2
exit 1
;;
esac

#DEBHELPER#

exit 0

+ 29
- 0
debian/dwm.prerm.in Zobrazit soubor

@@ -0,0 +1,29 @@
#!/bin/sh

set -e

ALTERNATIVES="@ALTERNATIVES@"

case "${1}" in
remove|deconfigure)
update-alternatives --quiet --remove dwm /usr/bin/dwm.default

for ALTERNATIVE in ${ALTERNATIVES}
do
update-alternatives --quiet --remove dwm /usr/bin/dwm.${ALTERNATIVE}
done
;;

upgrade|failed-upgrade)

;;

*)
echo "prerm called with unknown argument \`${1}'" >&2
exit 1
;;
esac

#DEBHELPER#

exit 0

+ 1
- 0
debian/dwm.wm Zobrazit soubor

@@ -0,0 +1 @@
/usr/bin/dwm

binární
debian/icons/dwm.png Zobrazit soubor

Před Za
Šířka: 32  |  Výška: 13  |  Velikost: 288 B

+ 120
- 0
debian/local/config.maintainer.h Zobrazit soubor

@@ -0,0 +1,120 @@
/* See LICENSE file for copyright and license details. */

/* appearance */
static const char *fonts[] = {
"-*-lucidabright-medium-r-*-*-*-100-*-*-*-*-*-*"
};
static const char dmenufont[] = "-*-lucidabright-medium-r-*-*-*-100-*-*-*-*-*-*";
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 = 1; /* 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[] = { "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 */
{ "xfce4-terminal", NULL, NULL, 0, 0, -1 },
{ "Iceweasel", NULL, NULL, 1 << 1, 0, -1 },
{ "Firefox-bin", NULL, NULL, 1 << 1, 0, -1 },
{ "Pidgin", NULL, NULL, 1 << 2, 1, 1 },
{ "Skype", NULL, NULL, 1 << 2, 1, 1 },
{ "Vlc", NULL, NULL, 1 << 5, 0, -1 },
{ "Emacs", NULL, NULL, 1 << 3, 0, -1 },
{ "Evince", NULL, NULL, 1 << 4, 0, -1 },
{ "Gimp", NULL, NULL, 1 << 6, 1, -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 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} },

/* 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[] = { "x-terminal-emulator", NULL };

static Key keys[] = {
/* modifier key function argument */
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
{ 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[2]} },
{ 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} },
};


+ 52
- 0
debian/local/config.web.h Zobrazit soubor

@@ -0,0 +1,52 @@
/* See LICENSE file for copyright and license details. */

/* appearance */
static const char *fonts[] = { "fixed" };
static const char dmenufont[] = "fixed";
static const char normbordercolor[] = "#cccccc";
static const char normbgcolor[] = "#cccccc";
static const char normfgcolor[] = "#000000";
static const char selbordercolor[] = "#0066ff";
static const char selbgcolor[] = "#0066ff";
static const char selfgcolor[] = "#000000";
static unsigned int borderpx = 0;
static unsigned int snap = 32;
static const int showbar = 0; /* 0 means no bar */
static const int topbar = 0; /* 0 means bottom bar */

/* tagging */
static const char *tags[] = { "web" };

static const Rule rules[] = {
{0}
};

/* 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 = 0; /* 1 means respect size hints in tiled resizals */

static const Layout layouts[] = {
/* symbol arrange function */
{ "[M]", monocle },
};

/* key definitions */
#define MODKEY Mod1Mask

/* 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 Key keys[] = {
/* modifier key function argument */ \
{ MODKEY|ShiftMask, XK_c, killclient, {0} },
{ MODKEY, XK_q, killclient, {0} }, \
{ MODKEY, XK_F4, killclient, {0} }, \
};

/* button definitions */
/* click can be ClkLtSymbol, ClkStatusText, ClkWinTitle, ClkClientWin, or ClkRootWin */
static Button buttons[] = {
{ 0 }
};

+ 113
- 0
debian/local/config.winkey.h Zobrazit soubor

@@ -0,0 +1,113 @@
/* See LICENSE file for copyright and license details. */

/* appearance */
static const char *fonts[] = {
"monospace:size=10"
};
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 = 1; /* 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[] = { "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 */
{ "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 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} },

/* 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[] = { "x-terminal-emulator", NULL };

static Key keys[] = {
/* modifier key function argument */
{ MODKEY, XK_p, spawn, {.v = dmenucmd } },
{ MODKEY|ShiftMask, XK_Return, spawn, {.v = termcmd } },
{ 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[2]} },
{ 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} },
};


+ 35
- 0
debian/patches/2001_replace_term_cmd.patch Zobrazit soubor

@@ -0,0 +1,35 @@
Description: Modified command and rules to use Debian specific tools
By default dwm uses uxterm as terminal emulator
this is modified now to use x-terminal-emulator
command instead.
.
Also patch modifies class rules to use Iceweasel instead of Firefox
as that is the replacement for Firefox on Debian system.
Author: Vasudev Kamath <kamathvasudev@gmail.com>
Forwarded: not-needed
Last-Update: 2016-03-25
--- a/config.def.h 2016-03-26 22:54:02.066831758 +0100
+++ b/config.def.h 2016-03-26 22:54:20.974134262 +0100
@@ -26,7 +26,7 @@
*/
/* class instance title tags mask isfloating monitor */
{ "Gimp", NULL, NULL, 0, 1, -1 },
- { "Firefox", NULL, NULL, 1 << 8, 0, -1 },
+ { "Iceweasel", NULL, NULL, 1 << 8, 0, -1 },
};
/* layout(s) */
@@ -55,7 +55,7 @@
/* 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[] = { "st", NULL };
+static const char *termcmd[] = { "x-terminal-emulator", NULL };
static Key keys[] = {
/* modifier key function argument */
@@ -110,4 +110,3 @@
{ ClkTagBar, MODKEY, Button1, tag, {0} },
{ ClkTagBar, MODKEY, Button3, toggletag, {0} },
};
-

+ 23
- 0
debian/patches/2002_inject_hardening_flags.patch Zobrazit soubor

@@ -0,0 +1,23 @@
Description: Modification to allow dpkg-buildflags
This modification allows the dpkg-buildflags to inject compilation
flags in addition to vendor specific patches. Also this patch removes
-Os from upstream allowing use DEB_BUILD_OPTIONS=noopt
Author: Vasudev Kamath <kamathvasudev@gmail.com>
Forwarded: not-needed
Last-Update: 2016-03-26
--- a/config.mk 2016-03-26 15:58:16.677180328 +0100
+++ b/config.mk 2016-03-26 16:17:29.594570899 +0100
@@ -25,10 +25,10 @@
LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}
# flags
-CPPFLAGS = -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
+CPPFLAGS += -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}
#CFLAGS = -g -std=c99 -pedantic -Wall -O0 ${INCS} ${CPPFLAGS}
-CFLAGS = -std=c99 -pedantic -Wall -Wno-deprecated-declarations -Os ${INCS} ${CPPFLAGS}
-LDFLAGS = -s ${LIBS}
+CFLAGS += -std=c99 -pedantic -Wall -Wno-deprecated-declarations ${INCS} ${CPPFLAGS}
+LDFLAGS += -s ${LIBS}
# Solaris
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"

+ 71
- 0
debian/patches/2003_transparent_makefile.patch Zobrazit soubor

@@ -0,0 +1,71 @@
Description: Commands in Makefile should be visible while execution
This patch removes @ from the Makefile so that command execution is
visible to every one when DH_VERBOSE=1
Author: Vasudev Kamath <kamathvasudev@gmail.com>
Last-Update: 2016-03-26
Forwarded: not-needed
--- a/Makefile 2016-03-26 17:46:10.988905902 +0100
+++ b/Makefile 2016-03-26 18:03:02.847233725 +0100
@@ -16,45 +16,45 @@
.c.o:
@echo CC $<
- @${CC} -c ${CFLAGS} $<
+ ${CC} -c ${CFLAGS} $<
${OBJ}: config.h config.mk
config.h:
@echo creating $@ from config.def.h
- @cp config.def.h $@
+ cp config.def.h $@
dwm: ${OBJ}
@echo CC -o $@
- @${CC} -o $@ ${OBJ} ${LDFLAGS}
+ ${CC} -o $@ ${OBJ} ${LDFLAGS}
clean:
@echo cleaning
- @rm -f dwm ${OBJ} dwm-${VERSION}.tar.gz
+ rm -f dwm ${OBJ} dwm-${VERSION}.tar.gz
dist: clean
@echo creating dist tarball
- @mkdir -p dwm-${VERSION}
- @cp -R LICENSE TODO BUGS Makefile README config.def.h config.mk \
+ mkdir -p dwm-${VERSION}
+ cp -R LICENSE TODO BUGS Makefile README config.def.h config.mk \
dwm.1 drw.h util.h ${SRC} dwm.png transient.c dwm-${VERSION}
- @tar -cf dwm-${VERSION}.tar dwm-${VERSION}
- @gzip dwm-${VERSION}.tar
- @rm -rf dwm-${VERSION}
+ tar -cf dwm-${VERSION}.tar dwm-${VERSION}
+ gzip dwm-${VERSION}.tar
+ rm -rf dwm-${VERSION}
install: all
@echo installing executable file to ${DESTDIR}${PREFIX}/bin
- @mkdir -p ${DESTDIR}${PREFIX}/bin
- @cp -f dwm ${DESTDIR}${PREFIX}/bin
- @chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
+ mkdir -p ${DESTDIR}${PREFIX}/bin
+ cp -f dwm ${DESTDIR}${PREFIX}/bin
+ chmod 755 ${DESTDIR}${PREFIX}/bin/dwm
@echo installing manual page to ${DESTDIR}${MANPREFIX}/man1
- @mkdir -p ${DESTDIR}${MANPREFIX}/man1
- @sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
- @chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1
+ mkdir -p ${DESTDIR}${MANPREFIX}/man1
+ sed "s/VERSION/${VERSION}/g" < dwm.1 > ${DESTDIR}${MANPREFIX}/man1/dwm.1
+ chmod 644 ${DESTDIR}${MANPREFIX}/man1/dwm.1
uninstall:
@echo removing executable file from ${DESTDIR}${PREFIX}/bin
- @rm -f ${DESTDIR}${PREFIX}/bin/dwm
+ rm -f ${DESTDIR}${PREFIX}/bin/dwm
@echo removing manual page from ${DESTDIR}${MANPREFIX}/man1
- @rm -f ${DESTDIR}${MANPREFIX}/man1/dwm.1
+ rm -f ${DESTDIR}${MANPREFIX}/man1/dwm.1
.PHONY: all options clean dist install uninstall

+ 33
- 0
debian/patches/2004_use_system_searchpaths.patch Zobrazit soubor

@@ -0,0 +1,33 @@
Description: Fix FTBFS on mipsel* due to custom library search paths.
This patch removes library search -L/usr/lib and include paths
defined by upstream. Since all the libraries and headers needed are
available in default path these flags are redundant also since
/usr/lib may have different purpose on various architecture like
mips* it causes FTBFS. Thanks to YunQiang Su for bringing this up.
Author: Vasudev Kamath <kamathvasudev@gmail.com>
Last-Updated: 2016-03-26
Bug-Debian: https://bugs.debian.org/722765

--- a/config.mk 2016-03-26 23:36:45.914814792 +0100
+++ b/config.mk 2016-03-26 23:37:20.275092945 +0100
@@ -7,9 +7,6 @@
PREFIX = /usr/local
MANPREFIX = ${PREFIX}/share/man
-X11INC = /usr/X11R6/include
-X11LIB = /usr/X11R6/lib
-
# Xinerama, comment if you don't want it
XINERAMALIBS = -lXinerama
XINERAMAFLAGS = -DXINERAMA
@@ -21,8 +18,8 @@
#FREETYPEINC = ${X11INC}/freetype2
# includes and libs
-INCS = -I${X11INC} -I${FREETYPEINC}
-LIBS = -L${X11LIB} -lX11 ${XINERAMALIBS} ${FREETYPELIBS}
+INCS = -I${FREETYPEINC}
+LIBS = -lX11 ${XINERAMALIBS} ${FREETYPELIBS}
# flags
CPPFLAGS += -D_BSD_SOURCE -D_POSIX_C_SOURCE=2 -DVERSION=\"${VERSION}\" ${XINERAMAFLAGS}

+ 3
- 0
debian/patches/README Zobrazit soubor

@@ -0,0 +1,3 @@
0xxx: Grabbed from upstream development.
1xxx: Possibly relevant for upstream adoption.
2xxx: Only relevant for official Debian release.

+ 4
- 0
debian/patches/series Zobrazit soubor

@@ -0,0 +1,4 @@
2001_replace_term_cmd.patch
2002_inject_hardening_flags.patch
2003_transparent_makefile.patch
2004_use_system_searchpaths.patch

+ 32
- 0
debian/rules Zobrazit soubor

@@ -0,0 +1,32 @@
#!/usr/bin/make -f

export DEB_BUILD_MAINT_OPTIONS = hardening=+all

SHELL := sh -e

%:
dh ${@}

override_dh_auto_clean:
rm -f config.h
$(MAKE) clean

override_dh_auto_install:
$(MAKE) install DESTDIR=$(CURDIR)/debian/dwm PREFIX=/usr

mv debian/dwm/usr/bin/dwm debian/dwm/usr/bin/dwm.default
ln -s dwm.1.gz debian/dwm/usr/share/man/man1/dwm.default.1.gz

# Building alternatives
for ALTERNATIVE in debian/local/config.*.h; \
do \
$(MAKE) clean; \
cp $${ALTERNATIVE} config.h; \
CFLAGS="$(CFLAGS)" $(MAKE) PREFIX=/usr; \
install -m 0755 dwm debian/dwm/usr/bin/dwm.`basename $${ALTERNATIVE} | cut -d'.' -f 2`; \
ln -s dwm.1.gz debian/dwm/usr/share/man/man1/dwm.`basename $${ALTERNATIVE} | cut -d'.' -f 2`.1.gz; \
done

# Configuring maintainer scripts
sed -e "s|@ALTERNATIVES@|$(shell find debian/local/ -name 'config.*.h' | LC_ALL=C sort | cut -d'.' -f 2 | tr '\n' ' ')|" debian/dwm.postinst.in > debian/dwm.postinst
sed -e "s|@ALTERNATIVES@|$(shell find debian/local/ -name 'config.*.h' | LC_ALL=C sort | cut -d'.' -f 2 | tr '\n' ' ')|" debian/dwm.prerm.in > debian/dwm.prerm

+ 1
- 0
debian/source/format Zobrazit soubor

@@ -0,0 +1 @@
3.0 (quilt)

+ 1
- 0
debian/source/include-binaries Zobrazit soubor

@@ -0,0 +1 @@
debian/icons/dwm.png

+ 2
- 0
debian/source/options Zobrazit soubor

@@ -0,0 +1,2 @@
compression = gzip
compression-level = 9

+ 2
- 0
debian/watch Zobrazit soubor

@@ -0,0 +1,2 @@
version=4
https://git.suckless.org/dwm/refs /dwm/snapshot/dwm-(.*)\.tar\.gz

+ 398
- 0
drw.c Zobrazit soubor

@@ -0,0 +1,398 @@
/* See LICENSE file for copyright and license details. */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <X11/Xlib.h>
#include <X11/Xft/Xft.h>

#include "drw.h"
#include "util.h"

#define UTF_INVALID 0xFFFD
#define UTF_SIZ 4

static const unsigned char utfbyte[UTF_SIZ + 1] = {0x80, 0, 0xC0, 0xE0, 0xF0};
static const unsigned char utfmask[UTF_SIZ + 1] = {0xC0, 0x80, 0xE0, 0xF0, 0xF8};
static const long utfmin[UTF_SIZ + 1] = { 0, 0, 0x80, 0x800, 0x10000};
static const long utfmax[UTF_SIZ + 1] = {0x10FFFF, 0x7F, 0x7FF, 0xFFFF, 0x10FFFF};

static long
utf8decodebyte(const char c, size_t *i)
{
for (*i = 0; *i < (UTF_SIZ + 1); ++(*i))
if (((unsigned char)c & utfmask[*i]) == utfbyte[*i])
return (unsigned char)c & ~utfmask[*i];
return 0;
}

static size_t
utf8validate(long *u, size_t i)
{
if (!BETWEEN(*u, utfmin[i], utfmax[i]) || BETWEEN(*u, 0xD800, 0xDFFF))
*u = UTF_INVALID;
for (i = 1; *u > utfmax[i]; ++i)
;
return i;
}

static size_t
utf8decode(const char *c, long *u, size_t clen)
{
size_t i, j, len, type;
long udecoded;

*u = UTF_INVALID;
if (!clen)
return 0;
udecoded = utf8decodebyte(c[0], &len);
if (!BETWEEN(len, 1, UTF_SIZ))
return 1;
for (i = 1, j = 1; i < clen && j < len; ++i, ++j) {
udecoded = (udecoded << 6) | utf8decodebyte(c[i], &type);
if (type)
return j;
}
if (j < len)
return 0;
*u = udecoded;
utf8validate(u, len);

return len;
}

Drw *
drw_create(Display *dpy, int screen, Window root, unsigned int w, unsigned int h)
{
Drw *drw;

drw = ecalloc(1, sizeof(Drw));
drw->dpy = dpy;
drw->screen = screen;
drw->root = root;
drw->w = w;
drw->h = h;
drw->drawable = XCreatePixmap(dpy, root, w, h, DefaultDepth(dpy, screen));
drw->gc = XCreateGC(dpy, root, 0, NULL);
drw->fontcount = 0;
XSetLineAttributes(dpy, drw->gc, 1, LineSolid, CapButt, JoinMiter);

return drw;
}

void
drw_resize(Drw *drw, unsigned int w, unsigned int h)
{
drw->w = w;
drw->h = h;
if (drw->drawable)
XFreePixmap(drw->dpy, drw->drawable);
drw->drawable = XCreatePixmap(drw->dpy, drw->root, w, h, DefaultDepth(drw->dpy, drw->screen));
}

void
drw_free(Drw *drw)
{
size_t i;

for (i = 0; i < drw->fontcount; i++)
drw_font_free(drw->fonts[i]);
XFreePixmap(drw->dpy, drw->drawable);
XFreeGC(drw->dpy, drw->gc);
free(drw);
}

/* This function is an implementation detail. Library users should use
* drw_font_create instead.
*/
static Fnt *
drw_font_xcreate(Drw *drw, const char *fontname, FcPattern *fontpattern)
{
Fnt *font;
XftFont *xfont = NULL;
FcPattern *pattern = NULL;

if (fontname) {
/* Using the pattern found at font->xfont->pattern does not yield same
* the same substitution results as using the pattern returned by
* FcNameParse; using the latter results in the desired fallback
* behaviour whereas the former just results in
* missing-character-rectangles being drawn, at least with some fonts.
*/
if (!(xfont = XftFontOpenName(drw->dpy, drw->screen, fontname))) {
fprintf(stderr, "error, cannot load font: '%s'\n", fontname);
return NULL;
}
if (!(pattern = FcNameParse((FcChar8 *) fontname))) {
fprintf(stderr, "error, cannot load font: '%s'\n", fontname);
XftFontClose(drw->dpy, xfont);
return NULL;
}
} else if (fontpattern) {
if (!(xfont = XftFontOpenPattern(drw->dpy, fontpattern))) {
fprintf(stderr, "error, cannot load font pattern.\n");
return NULL;
}
} else {
die("no font specified.\n");
}

font = ecalloc(1, sizeof(Fnt));
font->xfont = xfont;
font->pattern = pattern;
font->ascent = xfont->ascent;
font->descent = xfont->descent;
font->h = font->ascent + font->descent;
font->dpy = drw->dpy;

return font;
}

Fnt*
drw_font_create(Drw *drw, const char *fontname)
{
return drw_font_xcreate(drw, fontname, NULL);
}

void
drw_load_fonts(Drw* drw, const char *fonts[], size_t fontcount)
{
size_t i;
Fnt *font;

for (i = 0; i < fontcount; i++) {
if (drw->fontcount >= DRW_FONT_CACHE_SIZE) {
die("font cache exhausted.\n");
} else if ((font = drw_font_xcreate(drw, fonts[i], NULL))) {
drw->fonts[drw->fontcount++] = font;
}
}
}

void
drw_font_free(Fnt *font)
{
if (!font)
return;
if (font->pattern)
FcPatternDestroy(font->pattern);
XftFontClose(font->dpy, font->xfont);
free(font);
}

Clr *
drw_clr_create(Drw *drw, const char *clrname)
{
Clr *clr;

clr = ecalloc(1, sizeof(Clr));
if (!XftColorAllocName(drw->dpy, DefaultVisual(drw->dpy, drw->screen),
DefaultColormap(drw->dpy, drw->screen),
clrname, &clr->rgb))
die("error, cannot allocate color '%s'\n", clrname);
clr->pix = clr->rgb.pixel;

return clr;
}

void
drw_clr_free(Clr *clr)
{
free(clr);
}

void
drw_setscheme(Drw *drw, ClrScheme *scheme)
{
drw->scheme = scheme;
}

void
drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h, int filled, int empty, int invert)
{
if (!drw->scheme)
return;
XSetForeground(drw->dpy, drw->gc, invert ? drw->scheme->bg->pix : drw->scheme->fg->pix);
if (filled)
XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w + 1, h + 1);
else if (empty)
XDrawRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
}

int
drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, const char *text, int invert)
{
char buf[1024];
int tx, ty, th;
Extnts tex;
XftDraw *d = NULL;
Fnt *curfont, *nextfont;
size_t i, len;
int utf8strlen, utf8charlen, render;
long utf8codepoint = 0;
const char *utf8str;
FcCharSet *fccharset;
FcPattern *fcpattern;
FcPattern *match;
XftResult result;
int charexists = 0;

if (!drw->scheme || !drw->fontcount)
return 0;

if (!(render = x || y || w || h)) {
w = ~w;
} else {
XSetForeground(drw->dpy, drw->gc, invert ?
drw->scheme->fg->pix : drw->scheme->bg->pix);
XFillRectangle(drw->dpy, drw->drawable, drw->gc, x, y, w, h);
d = XftDrawCreate(drw->dpy, drw->drawable,
DefaultVisual(drw->dpy, drw->screen),
DefaultColormap(drw->dpy, drw->screen));
}

curfont = drw->fonts[0];
while (1) {
utf8strlen = 0;
utf8str = text;
nextfont = NULL;
while (*text) {
utf8charlen = utf8decode(text, &utf8codepoint, UTF_SIZ);
for (i = 0; i < drw->fontcount; i++) {
charexists = charexists || XftCharExists(drw->dpy, drw->fonts[i]->xfont, utf8codepoint);
if (charexists) {
if (drw->fonts[i] == curfont) {
utf8strlen += utf8charlen;
text += utf8charlen;
} else {
nextfont = drw->fonts[i];
}
break;
}
}

if (!charexists || (nextfont && nextfont != curfont))
break;
else
charexists = 0;
}

if (utf8strlen) {
drw_font_getexts(curfont, utf8str, utf8strlen, &tex);
/* shorten text if necessary */
for (len = MIN(utf8strlen, (sizeof buf) - 1); len && (tex.w > w - drw->fonts[0]->h || w < drw->fonts[0]->h); len--)
drw_font_getexts(curfont, utf8str, len, &tex);

if (len) {
memcpy(buf, utf8str, len);
buf[len] = '\0';
if (len < utf8strlen)
for (i = len; i && i > len - 3; buf[--i] = '.');

if (render) {
th = curfont->ascent + curfont->descent;
ty = y + (h / 2) - (th / 2) + curfont->ascent;
tx = x + (h / 2);
XftDrawStringUtf8(d, invert ? &drw->scheme->bg->rgb : &drw->scheme->fg->rgb, curfont->xfont, tx, ty, (XftChar8 *)buf, len);
}
x += tex.w;
w -= tex.w;
}
}

if (!*text) {
break;
} else if (nextfont) {
charexists = 0;
curfont = nextfont;
} else {
/* Regardless of whether or not a fallback font is found, the
* character must be drawn.
*/
charexists = 1;

if (drw->fontcount >= DRW_FONT_CACHE_SIZE)
continue;

fccharset = FcCharSetCreate();
FcCharSetAddChar(fccharset, utf8codepoint);

if (!drw->fonts[0]->pattern) {
/* Refer to the comment in drw_font_xcreate for more
* information. */
die("the first font in the cache must be loaded from a font string.\n");
}

fcpattern = FcPatternDuplicate(drw->fonts[0]->pattern);
FcPatternAddCharSet(fcpattern, FC_CHARSET, fccharset);
FcPatternAddBool(fcpattern, FC_SCALABLE, FcTrue);

FcConfigSubstitute(NULL, fcpattern, FcMatchPattern);
FcDefaultSubstitute(fcpattern);
match = XftFontMatch(drw->dpy, drw->screen, fcpattern, &result);

FcCharSetDestroy(fccharset);
FcPatternDestroy(fcpattern);

if (match) {
curfont = drw_font_xcreate(drw, NULL, match);
if (curfont && XftCharExists(drw->dpy, curfont->xfont, utf8codepoint)) {
drw->fonts[drw->fontcount++] = curfont;
} else {
drw_font_free(curfont);
curfont = drw->fonts[0];
}
}
}
}
if (d)
XftDrawDestroy(d);

return x;
}

void
drw_map(Drw *drw, Window win, int x, int y, unsigned int w, unsigned int h)
{
XCopyArea(drw->dpy, drw->drawable, win, drw->gc, x, y, w, h, x, y);
XSync(drw->dpy, False);
}

void
drw_font_getexts(Fnt *font, const char *text, unsigned int len, Extnts *tex)
{
XGlyphInfo ext;

XftTextExtentsUtf8(font->dpy, font->xfont, (XftChar8 *)text, len, &ext);
tex->h = font->h;
tex->w = ext.xOff;
}

unsigned int
drw_font_getexts_width(Fnt *font, const char *text, unsigned int len)
{
Extnts tex;

drw_font_getexts(font, text, len, &tex);

return tex.w;
}

Cur *
drw_cur_create(Drw *drw, int shape)
{
Cur *cur;

cur = ecalloc(1, sizeof(Cur));
cur->cursor = XCreateFontCursor(drw->dpy, shape);

return cur;
}

void
drw_cur_free(Drw *drw, Cur *cursor)
{
if (!cursor)
return;
XFreeCursor(drw->dpy, cursor->cursor);
free(cursor);
}

+ 74
- 0
drw.h Zobrazit soubor

@@ -0,0 +1,74 @@
/* See LICENSE file for copyright and license details. */
#define DRW_FONT_CACHE_SIZE 32

typedef struct {
unsigned long pix;
XftColor rgb;
} Clr;

typedef struct {
Cursor cursor;
} Cur;

typedef struct {
Display *dpy;
int ascent;
int descent;
unsigned int h;
XftFont *xfont;
FcPattern *pattern;
} Fnt;

typedef struct {
Clr *fg;
Clr *bg;
Clr *border;
} ClrScheme;

typedef struct {
unsigned int w, h;
Display *dpy;
int screen;
Window root;
Drawable drawable;
GC gc;
ClrScheme *scheme;
size_t fontcount;
Fnt *fonts[DRW_FONT_CACHE_SIZE];
} Drw;

typedef struct {
unsigned int w;
unsigned int h;
} Extnts;

/* Drawable abstraction */
Drw *drw_create(Display *, int, Window, unsigned int, unsigned int);
void drw_resize(Drw *, unsigned int, unsigned int);
void drw_free(Drw *);

/* Fnt abstraction */
Fnt *drw_font_create(Drw *, const char *);
void drw_load_fonts(Drw *, const char *[], size_t);
void drw_font_free(Fnt *);
void drw_font_getexts(Fnt *, const char *, unsigned int, Extnts *);
unsigned int drw_font_getexts_width(Fnt *, const char *, unsigned int);

/* Colour abstraction */
Clr *drw_clr_create(Drw *, const char *);
void drw_clr_free(Clr *);

/* Cursor abstraction */
Cur *drw_cur_create(Drw *, int);
void drw_cur_free(Drw *, Cur *);

/* Drawing context manipulation */
void drw_setfont(Drw *, Fnt *);
void drw_setscheme(Drw *, ClrScheme *);

/* Drawing functions */
void drw_rect(Drw *, int, int, unsigned int, unsigned int, int, int, int);
int drw_text(Drw *, int, int, unsigned int, unsigned int, const char *, int);

/* Map functions */
void drw_map(Drw *, Window, int, int, unsigned int, unsigned int);

+ 176
- 0
dwm.1 Zobrazit soubor

@@ -0,0 +1,176 @@
.TH DWM 1 dwm\-VERSION
.SH NAME
dwm \- dynamic window manager
.SH SYNOPSIS
.B dwm
.RB [ \-v ]
.SH DESCRIPTION
dwm is a dynamic window manager for X. It manages windows in tiled, monocle
and floating layouts. Either layout can be applied dynamically, optimising the
environment for the application in use and the task performed.
.P
In tiled layouts windows are managed in a master and stacking area. The master
area contains the window which currently needs most attention, whereas the
stacking area contains all other windows. In monocle layout all windows are
maximised to the screen size. In floating layout windows can be resized and
moved freely. Dialog windows are always managed floating, regardless of the
layout applied.
.P
Windows are grouped by tags. Each window can be tagged with one or multiple
tags. Selecting certain tags displays all windows with these tags.
.P
Each screen contains a small status bar which displays all available tags, the
layout, the title of the focused window, and the text read from the root window
name property, if the screen is focused. A floating window is indicated with an
empty square and a maximised floating window is indicated with a filled square
before the windows title. The selected tags are indicated with a different
color. The tags of the focused window are indicated with a filled square in the
top left corner. The tags which are applied to one or more windows are
indicated with an empty square in the top left corner.
.P
dwm draws a small border around windows to indicate the focus state.
.SH OPTIONS
.TP
.B \-v
prints version information to standard output, then exits.
.SH USAGE
.SS Status bar
.TP
.B X root window name
is read and displayed in the status text area. It can be set with the
.BR xsetroot (1)
command.
.TP
.B Button1
click on a tag label to display all windows with that tag, click on the layout
label toggles between tiled and floating layout.
.TP
.B Button3
click on a tag label adds/removes all windows with that tag to/from the view.
.TP
.B Mod1\-Button1
click on a tag label applies that tag to the focused window.
.TP
.B Mod1\-Button3
click on a tag label adds/removes that tag to/from the focused window.
.SS Keyboard commands
.TP
.B Mod1\-Shift\-Return
Start
.BR st(1).
.TP
.B Mod1\-,
Focus previous screen, if any.
.TP
.B Mod1\-.
Focus next screen, if any.
.TP
.B Mod1\-Shift\-,
Send focused window to previous screen, if any.
.TP
.B Mod1\-Shift\-.
Send focused window to next screen, if any.
.TP
.B Mod1\-b
Toggles bar on and off.
.TP
.B Mod1\-t
Sets tiled layout.
.TP
.B Mod1\-f
Sets floating layout.
.TP
.B Mod1\-m
Sets monocle layout.
.TP
.B Mod1\-space
Toggles between current and previous layout.
.TP
.B Mod1\-j
Focus next window.
.TP
.B Mod1\-k
Focus previous window.
.TP
.B Mod1\-i
Increase clients in master area.
.TP
.B Mod1\-d
Decrease clients in master area.
.TP
.B Mod1\-l
Increase master area size.
.TP
.B Mod1\-h
Decrease master area size.
.TP
.B Mod1\-Return
Zooms/cycles focused window to/from master area (tiled layouts only).
.TP
.B Mod1\-Shift\-c
Close focused window.
.TP
.B Mod1\-Shift\-space
Toggle focused window between tiled and floating state.
.TP
.B Mod1\-Tab
Toggles to the previously selected tags.
.TP
.B Mod1\-Shift\-[1..n]
Apply nth tag to focused window.
.TP
.B Mod1\-Shift\-0
Apply all tags to focused window.
.TP
.B Mod1\-Control\-Shift\-[1..n]
Add/remove nth tag to/from focused window.
.TP
.B Mod1\-[1..n]
View all windows with nth tag.
.TP
.B Mod1\-0
View all windows with any tag.
.TP
.B Mod1\-Control\-[1..n]
Add/remove all windows with nth tag to/from the view.
.TP
.B Mod1\-Shift\-q
Quit dwm.
.SS Mouse commands
.TP
.B Mod1\-Button1
Move focused window while dragging. Tiled windows will be toggled to the floating state.
.TP
.B Mod1\-Button2
Toggles focused window between floating and tiled state.
.TP
.B Mod1\-Button3
Resize focused window while dragging. Tiled windows will be toggled to the floating state.
.SH CUSTOMIZATION
dwm is customized by creating a custom config.h and (re)compiling the source
code. This keeps it fast, secure and simple.
.SH SEE ALSO
.BR dmenu (1),
.BR st (1)
.SH BUGS
Java applications which use the XToolkit/XAWT backend may draw grey windows
only. The XToolkit/XAWT backend breaks ICCCM-compliance in recent JDK 1.5 and early
JDK 1.6 versions, because it assumes a reparenting window manager. Possible workarounds
are using JDK 1.4 (which doesn't contain the XToolkit/XAWT backend) or setting the
environment variable
.BR AWT_TOOLKIT=MToolkit
(to use the older Motif backend instead) or running
.B xprop -root -f _NET_WM_NAME 32a -set _NET_WM_NAME LG3D
or
.B wmname LG3D
(to pretend that a non-reparenting window manager is running that the
XToolkit/XAWT backend can recognize) or when using OpenJDK setting the environment variable
.BR _JAVA_AWT_WM_NONREPARENTING=1 .
.P
GTK 2.10.9+ versions contain a broken
.BR Save\-As
file dialog implementation,
which requests to reconfigure its window size in an endless loop. However, its
window is still respondable during this state, so you can simply ignore the flicker
until a new GTK version appears, which will fix this bug, approximately
GTK 2.10.12+ versions.

+ 2141
- 0
dwm.c
Diff nebyl zobrazen, protože je příliš veliký
Zobrazit soubor


binární
dwm.png Zobrazit soubor

Před Za
Šířka: 192  |  Výška: 80  |  Velikost: 373 B

+ 42
- 0
transient.c Zobrazit soubor

@@ -0,0 +1,42 @@
/* cc transient.c -o transient -lX11 */

#include <stdlib.h>
#include <unistd.h>
#include <X11/Xlib.h>
#include <X11/Xutil.h>

int main(void) {
Display *d;
Window r, f, t = None;
XSizeHints h;
XEvent e;

d = XOpenDisplay(NULL);
if (!d)
exit(1);
r = DefaultRootWindow(d);

f = XCreateSimpleWindow(d, r, 100, 100, 400, 400, 0, 0, 0);
h.min_width = h.max_width = h.min_height = h.max_height = 400;
h.flags = PMinSize | PMaxSize;
XSetWMNormalHints(d, f, &h);
XStoreName(d, f, "floating");
XMapWindow(d, f);

XSelectInput(d, f, ExposureMask);
while (1) {
XNextEvent(d, &e);

if (t == None) {
sleep(5);
t = XCreateSimpleWindow(d, r, 50, 50, 100, 100, 0, 0, 0);
XSetTransientForHint(d, t, f);
XStoreName(d, t, "transient");
XMapWindow(d, t);
XSelectInput(d, t, ExposureMask);
}
}

XCloseDisplay(d);
exit(0);
}

+ 33
- 0
util.c Zobrazit soubor

@@ -0,0 +1,33 @@
/* See LICENSE file for copyright and license details. */
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "util.h"

void *
ecalloc(size_t nmemb, size_t size)
{
void *p;

if (!(p = calloc(nmemb, size)))
perror(NULL);
return p;
}

void
die(const char *fmt, ...) {
va_list ap;

va_start(ap, fmt);
vfprintf(stderr, fmt, ap);
va_end(ap);

if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
fputc(' ', stderr);
perror(NULL);
}

exit(1);
}

+ 8
- 0
util.h Zobrazit soubor

@@ -0,0 +1,8 @@
/* See LICENSE file for copyright and license details. */

#define MAX(A, B) ((A) > (B) ? (A) : (B))
#define MIN(A, B) ((A) < (B) ? (A) : (B))
#define BETWEEN(X, A, B) ((A) <= (X) && (X) <= (B))

void die(const char *errstr, ...);
void *ecalloc(size_t, size_t);

Načítá se…
Zrušit
Uložit