diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-04-09 21:24:58 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-04-09 21:24:58 +0000 |
| commit | 51e27c03cfc53b8070f2d020c033fdce383116af (patch) | |
| tree | 2e6833ef1f66fa16d71fb3afa9da935054ae40e9 /cwmcc/atom.c | |
| parent | 787cbcf656890fae77fd3e6bef8e2d0cfc669ee8 (diff) | |
set up the atoms in cwmcc
Diffstat (limited to 'cwmcc/atom.c')
| -rw-r--r-- | cwmcc/atom.c | 114 |
1 files changed, 114 insertions, 0 deletions
diff --git a/cwmcc/atom.c b/cwmcc/atom.c new file mode 100644 index 00000000..32b33df0 --- /dev/null +++ b/cwmcc/atom.c @@ -0,0 +1,114 @@ +#include "cwmcc_internal.h" +#include "atom.h" +#include <glib.h> + +struct TypeAtoms cwmcc_atom_type; +struct ClientAtoms cwmcc_atom_client; +struct RootAtoms cwmcc_atom_root; +struct DataAtoms cwmcc_atom_data; + +#define CREATE(type, var, name) (cwmcc_atom_##type.var = \ + XInternAtom(cwmcc_display, name, FALSE)) +#define SETVALUE(type, var, value) (cwmcc_atom_##type.var = value) + +void atom_startup() +{ + CREATE(type, cardinal, "CARDINAL"); + CREATE(type, window, "WINDOW"); + CREATE(type, pixmap, "PIXMAP"); + CREATE(type, atom, "ATOM"); + CREATE(type, string, "STRING"); + CREATE(type, utf8, "UTF8_STRING"); + + CREATE(client, wm_protocols, "WM_PROTOCOLS"); + CREATE(client, wm_state, "WM_STATE"); + CREATE(client, wm_name, "WM_NAME"); + CREATE(client, wm_icon_name, "WM_ICON_NAME"); + CREATE(client, wm_class, "WM_CLASS"); + CREATE(client, wm_window_role, "WM_WINDOW_ROLE"); + CREATE(client, motif_wm_hints, "_MOTIF_WM_HINTS"); + CREATE(client, net_wm_name, "_NET_WM_NAME"); + CREATE(client, net_wm_visible_name, "_NET_WM_VISIBLE_NAME"); + CREATE(client, net_wm_icon_name, "_NET_WM_ICON_NAME"); + CREATE(client, net_wm_visible_icon_name, "_NET_WM_VISIBLE_ICON_NAME"); + CREATE(client, net_wm_desktop, "_NET_WM_DESKTOP"); + CREATE(client, net_wm_window_type, "_NET_WM_WINDOW_TYPE"); + CREATE(client, net_wm_state, "_NET_WM_STATE"); + CREATE(client, net_wm_strut, "_NET_WM_STRUT"); + CREATE(client, net_wm_icon, "_NET_WM_ICON"); + CREATE(client, net_wm_allowed_actions, "_NET_WM_ALLOWED_ACTIONS"); + CREATE(client, kwm_win_icon, "KWM_WIN_ICON"); + CREATE(client, openbox_premax, "_OPENBOX_PREMAX"); + + CREATE(root, net_supported, "_NET_SUPPORTED"); + CREATE(root, net_client_list, "_NET_CLIENT_LIST"); + CREATE(root, net_client_list_stacking, "_NET_CLIENT_LIST_STACKING"); + CREATE(root, net_number_of_desktops, "_NET_NUMBER_OF_DESKTOPS"); + CREATE(root, net_desktop_geometry, "_NET_DESKTOP_GEOMETRY"); + CREATE(root, net_desktop_viewport, "_NET_DESKTOP_VIEWPORT"); + CREATE(root, net_current_desktop, "_NET_CURRENT_DESKTOP"); + CREATE(root, net_desktop_names, "_NET_DESKTOP_NAMES"); + CREATE(root, net_active_window, "_NET_ACTIVE_WINDOW"); + CREATE(root, net_workarea, "_NET_WORKAREA"); + CREATE(root, net_supporting_wm_check, "_NET_SUPPORTING_WM_CHECK"); + CREATE(root, net_desktop_layout, "_NET_DESKTOP_LAYOUT"); + CREATE(root, net_showing_desktop, "_NET_SHOWING_DESKTOP"); + CREATE(root, openbox_pid, "_OPENBOX_PID"); + + CREATE(data, wm_delete_window, "WM_DELETE_WINDOW"); + CREATE(data, wm_take_focus, "WM_TAKE_FOCUS"); + CREATE(data, wm_change_state, "WM_CHANGE_STATE"); + CREATE(data, net_close_window, "_NET_CLOSE_WINDOW"); + CREATE(data, net_wm_moveresize, "_NET_WM_MOVERESIZE"); + + CREATE(data, net_wm_window_type_desktop, "_NET_WM_WINDOW_TYPE_DESKTOP"); + CREATE(data, net_wm_window_type_dock, "_NET_WM_WINDOW_TYPE_DOCK"); + CREATE(data, net_wm_window_type_toolbar, "_NET_WM_WINDOW_TYPE_TOOLBAR"); + CREATE(data, net_wm_window_type_menu, "_NET_WM_WINDOW_TYPE_MENU"); + CREATE(data, net_wm_window_type_utility, "_NET_WM_WINDOW_TYPE_UTILITY"); + CREATE(data, net_wm_window_type_splash, "_NET_WM_WINDOW_TYPE_SPLASH"); + CREATE(data, net_wm_window_type_dialog, "_NET_WM_WINDOW_TYPE_DIALOG"); + CREATE(data, net_wm_window_type_normal, "_NET_WM_WINDOW_TYPE_NORMAL"); + CREATE(data, kde_net_wm_window_type_override, + "_KDE_NET_WM_WINDOW_TYPE_OVERRIDE"); + + SETVALUE(data, net_wm_moveresize_size_topleft, 0); + SETVALUE(data, net_wm_moveresize_size_topright, 2); + SETVALUE(data, net_wm_moveresize_size_bottomright, 4); + SETVALUE(data, net_wm_moveresize_size_bottomleft, 6); + SETVALUE(data, net_wm_moveresize_move, 8); + + CREATE(data, net_wm_action_move, "_NET_WM_ACTION_MOVE"); + CREATE(data, net_wm_action_resize, "_NET_WM_ACTION_RESIZE"); + CREATE(data, net_wm_action_minimize, "_NET_WM_ACTION_MINIMIZE"); + CREATE(data, net_wm_action_shade, "_NET_WM_ACTION_SHADE"); + CREATE(data, net_wm_action_stick, "_NET_WM_ACTION_STICK"); + CREATE(data, net_wm_action_maximize_horz, "_NET_WM_ACTION_MAXIMIZE_HORZ"); + CREATE(data, net_wm_action_maximize_vert, "_NET_WM_ACTION_MAXIMIZE_VERT"); + CREATE(data, net_wm_action_fullscreen, "_NET_WM_ACTION_FULLSCREEN"); + CREATE(data, net_wm_action_change_desktop,"_NET_WM_ACTION_CHANGE_DESKTOP"); + CREATE(data, net_wm_action_close, "_NET_WM_ACTION_CLOSE"); + + CREATE(data, net_wm_state_modal, "_NET_WM_STATE_MODAL"); + CREATE(data, net_wm_state_sticky, "_NET_WM_STATE_STICKY"); + CREATE(data, net_wm_state_maximized_vert, "_NET_WM_STATE_MAXIMIZED_VERT"); + CREATE(data, net_wm_state_maximized_horz, "_NET_WM_STATE_MAXIMIZED_HORZ"); + CREATE(data, net_wm_state_shaded, "_NET_WM_STATE_SHADED"); + CREATE(data, net_wm_state_skip_taskbar, "_NET_WM_STATE_SKIP_TASKBAR"); + CREATE(data, net_wm_state_skip_pager, "_NET_WM_STATE_SKIP_PAGER"); + CREATE(data, net_wm_state_hidden, "_NET_WM_STATE_HIDDEN"); + CREATE(data, net_wm_state_fullscreen, "_NET_WM_STATE_FULLSCREEN"); + CREATE(data, net_wm_state_above, "_NET_WM_STATE_ABOVE"); + CREATE(data, net_wm_state_below, "_NET_WM_STATE_BELOW"); + + SETVALUE(data, net_wm_state_remove, 0); + SETVALUE(data, net_wm_state_add, 1); + SETVALUE(data, net_wm_state_toggle, 2); + + SETVALUE(data, net_wm_orientation_horz, 0); + SETVALUE(data, net_wm_orientation_vert, 1); + SETVALUE(data, net_wm_topleft, 0); + SETVALUE(data, net_wm_topright, 1); + SETVALUE(data, net_wm_bottomright, 2); + SETVALUE(data, net_wm_bottomleft, 3); +} |
