Configuration of dwm for Mac Computers
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

150 lines
6.3 KiB

18 years ago
18 years ago
18 years ago
18 years ago
18 years ago
18 years ago
18 years ago
  1. /* (C)opyright MMVI-MMVII Anselm R. Garbe <garbeam at gmail dot com>
  2. * See LICENSE file for license details.
  3. *
  4. * dynamic window manager is designed like any other X client as well. It is
  5. * driven through handling X events. In contrast to other X clients, a window
  6. * manager selects for SubstructureRedirectMask on the root window, to receive
  7. * events about window (dis-)appearance. Only one X connection at a time is
  8. * allowed to select for this event mask.
  9. *
  10. * Calls to fetch an X event from the event queue are blocking. Due reading
  11. * status text from standard input, a select()-driven main loop has been
  12. * implemented which selects for reads on the X connection and STDIN_FILENO to
  13. * handle all data smoothly. The event handlers of dwm are organized in an
  14. * array which is accessed whenever a new event has been fetched. This allows
  15. * event dispatching in O(1) time.
  16. *
  17. * Each child of the root window is called a client, except windows which have
  18. * set the override_redirect flag. Clients are organized in a global
  19. * doubly-linked client list, the focus history is remembered through a global
  20. * stack list. Each client contains an array of Bools of the same size as the
  21. * global tags array to indicate the tags of a client. For each client dwm
  22. * creates a small title window, which is resized whenever the (_NET_)WM_NAME
  23. * properties are updated or the client is moved/resized.
  24. *
  25. * Keys and tagging rules are organized as arrays and defined in the config.h
  26. * file. These arrays are kept static in event.o and tag.o respectively,
  27. * because no other part of dwm needs access to them. The current layout is
  28. * represented by the lt pointer.
  29. *
  30. * To understand everything else, start reading main.c:main().
  31. */
  32. #include "config.h"
  33. #include <X11/Xlib.h>
  34. /* mask shorthands, used in event.c and client.c */
  35. #define BUTTONMASK (ButtonPressMask | ButtonReleaseMask)
  36. enum { NetSupported, NetWMName, NetLast }; /* EWMH atoms */
  37. enum { WMProtocols, WMDelete, WMState, WMLast }; /* default atoms */
  38. enum { CurNormal, CurResize, CurMove, CurLast }; /* cursor */
  39. enum { ColBorder, ColFG, ColBG, ColLast }; /* color */
  40. typedef union {
  41. const char *cmd;
  42. int i;
  43. } Arg; /* argument type */
  44. typedef struct {
  45. int ascent;
  46. int descent;
  47. int height;
  48. XFontSet set;
  49. XFontStruct *xfont;
  50. } Fnt;
  51. typedef struct {
  52. int x, y, w, h;
  53. unsigned long norm[ColLast];
  54. unsigned long sel[ColLast];
  55. Drawable drawable;
  56. Fnt font;
  57. GC gc;
  58. } DC; /* draw context */
  59. typedef struct Client Client;
  60. struct Client {
  61. char name[256];
  62. int x, y, w, h;
  63. int rx, ry, rw, rh; /* revert geometry */
  64. int basew, baseh, incw, inch, maxw, maxh, minw, minh;
  65. int minax, minay, maxax, maxay;
  66. long flags;
  67. unsigned int border;
  68. Bool isbanned, isfixed, ismax, isversatile;
  69. Bool *tags;
  70. Client *next;
  71. Client *prev;
  72. Client *snext;
  73. Window win;
  74. };
  75. typedef struct {
  76. const char *symbol;
  77. void (*arrange)(void);
  78. } Layout;
  79. extern const char *tags[]; /* all tags */
  80. extern char stext[256]; /* status text */
  81. extern int screen, sx, sy, sw, sh; /* screen geometry */
  82. extern int wax, way, wah, waw; /* windowarea geometry */
  83. extern unsigned int bh, blw; /* bar height, bar layout label width */
  84. extern unsigned int master, nmaster; /* master percent, number of master clients */
  85. extern unsigned int ntags, numlockmask; /* number of tags, dynamic lock mask */
  86. extern void (*handler[LASTEvent])(XEvent *); /* event handler */
  87. extern Atom wmatom[WMLast], netatom[NetLast];
  88. extern Bool running, selscreen, *seltag; /* seltag is array of Bool */
  89. extern Client *clients, *sel, *stack; /* global client list and stack */
  90. extern Cursor cursor[CurLast];
  91. extern DC dc; /* global draw context */
  92. extern Display *dpy;
  93. extern Layout *lt;
  94. extern Window root, barwin;
  95. /* client.c */
  96. extern void configure(Client *c); /* send synthetic configure event */
  97. extern void focus(Client *c); /* focus c, c may be NULL */
  98. extern void focusnext(Arg *arg); /* focuses next visible client, arg is ignored */
  99. extern void focusprev(Arg *arg); /* focuses previous visible client, arg is ignored */
  100. extern void killclient(Arg *arg); /* kill c nicely */
  101. extern void manage(Window w, XWindowAttributes *wa); /* manage new client */
  102. extern Client *nexttiled(Client *c); /* returns tiled successor of c */
  103. extern void resize(Client *c, int x, int y,
  104. int w, int h, Bool sizehints); /* resize with given coordinates c*/
  105. extern void updatesizehints(Client *c); /* update the size hint variables of c */
  106. extern void updatetitle(Client *c); /* update the name of c */
  107. extern void unmanage(Client *c); /* destroy c */
  108. extern void zoom(Arg *arg); /* zooms the focused client to master area, arg is ignored */
  109. /* event.c */
  110. extern void grabkeys(void); /* grab all keys defined in config.h */
  111. /* main.c */
  112. extern void drawstatus(void); /* draw the bar */
  113. extern unsigned int textw(const char *text); /* return the width of text in px*/
  114. extern void quit(Arg *arg); /* quit dwm nicely */
  115. extern void sendevent(Window w, Atom a, long value); /* send synthetic event to w */
  116. extern int xerror(Display *dsply, XErrorEvent *ee); /* dwm's X error handler */
  117. /* screen.c */
  118. extern void compileregs(void); /* initialize regexps of rules defined in config.h */
  119. extern void incnmaster(Arg *arg); /* increments nmaster with arg's index value */
  120. extern void initlayouts(void); /* initialize layout array */
  121. extern Bool isvisible(Client *c); /* returns True if client is visible */
  122. extern void resizemaster(Arg *arg); /* resizes the master percent with arg's index value */
  123. extern void restack(void); /* restores z layers of all clients */
  124. extern void settags(Client *c, Client *trans); /* sets tags of c */
  125. extern void tag(Arg *arg); /* tags c with arg's index */
  126. extern void toggleversatile(Arg *arg); /* toggles focusesd client between versatile/and non-versatile state */
  127. extern void togglelayout(Arg *arg); /* toggles layout */
  128. extern void toggletag(Arg *arg); /* toggles c tags with arg's index */
  129. extern void toggleview(Arg *arg); /* toggles the tag with arg's index (in)visible */
  130. extern void versatile(void); /* arranges all windows versatile */
  131. extern void view(Arg *arg); /* views the tag with arg's index */
  132. /* util.c */
  133. extern void *emallocz(unsigned int size); /* allocates zero-initialized memory, exits on error */
  134. extern void eprint(const char *errstr, ...); /* prints errstr and exits with 1 */
  135. extern void spawn(Arg *arg); /* forks a new subprocess with to arg's cmd */