257 lines
8.5 KiB
C
257 lines
8.5 KiB
C
|
/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*-
|
||
|
|
||
|
obt/prop.h for the Openbox window manager
|
||
|
Copyright (c) 2006 Mikael Magnusson
|
||
|
Copyright (c) 2003-2007 Dana Jansens
|
||
|
|
||
|
This program is free software; you can redistribute it and/or modify
|
||
|
it under the terms of the GNU General Public License as published by
|
||
|
the Free Software Foundation; either version 2 of the License, or
|
||
|
(at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
See the COPYING file for a copy of the GNU General Public License.
|
||
|
*/
|
||
|
|
||
|
#ifndef __obt_prop_h
|
||
|
#define __obt_prop_h
|
||
|
|
||
|
#include <X11/Xlib.h>
|
||
|
#include <glib.h>
|
||
|
|
||
|
G_BEGIN_DECLS
|
||
|
|
||
|
typedef enum {
|
||
|
/* types */
|
||
|
OBT_PROP_CARDINAL, /*!< The atom which represents the Cardinal data type */
|
||
|
OBT_PROP_WINDOW, /*!< The atom which represents window ids */
|
||
|
OBT_PROP_PIXMAP, /*!< The atom which represents pixmap ids */
|
||
|
OBT_PROP_ATOM, /*!< The atom which represents atom values */
|
||
|
OBT_PROP_STRING, /*!< The atom which represents ascii strings */
|
||
|
OBT_PROP_UTF8, /*!< The atom which represents utf8-encoded strings */
|
||
|
|
||
|
/* selection stuff */
|
||
|
OBT_PROP_MANAGER,
|
||
|
|
||
|
/* window hints */
|
||
|
OBT_PROP_WM_COLORMAP_WINDOWS,
|
||
|
OBT_PROP_WM_PROTOCOLS,
|
||
|
OBT_PROP_WM_STATE,
|
||
|
OBT_PROP_WM_DELETE_WINDOW,
|
||
|
OBT_PROP_WM_TAKE_FOCUS,
|
||
|
OBT_PROP_WM_CHANGE_STATE,
|
||
|
OBT_PROP_WM_NAME,
|
||
|
OBT_PROP_WM_ICON_NAME,
|
||
|
OBT_PROP_WM_CLASS,
|
||
|
OBT_PROP_WM_WINDOW_ROLE,
|
||
|
OBT_PROP_WM_CLIENT_MACHINE,
|
||
|
OBT_PROP_WM_COMMAND,
|
||
|
OBT_PROP_WM_CLIENT_LEADER,
|
||
|
OBT_PROP_MOTIF_WM_HINTS,
|
||
|
|
||
|
/* SM atoms */
|
||
|
OBT_PROP_SM_CLIENT_ID,
|
||
|
|
||
|
/* NETWM atoms */
|
||
|
|
||
|
/* Atoms that are used inside messages - these don't go in net_supported */
|
||
|
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_TOPLEFT,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_TOP,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_TOPRIGHT,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_RIGHT,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_BOTTOMRIGHT,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_BOTTOM,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_BOTTOMLEFT,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_LEFT,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_MOVE,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_SIZE_KEYBOARD,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_MOVE_KEYBOARD,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE_CANCEL,
|
||
|
|
||
|
OBT_PROP_NET_WM_STATE_ADD,
|
||
|
OBT_PROP_NET_WM_STATE_REMOVE,
|
||
|
OBT_PROP_NET_WM_STATE_TOGGLE,
|
||
|
|
||
|
OBT_PROP_NET_WM_ORIENTATION_HORZ,
|
||
|
OBT_PROP_NET_WM_ORIENTATION_VERT,
|
||
|
OBT_PROP_NET_WM_TOPLEFT,
|
||
|
OBT_PROP_NET_WM_TOPRIGHT,
|
||
|
OBT_PROP_NET_WM_BOTTOMRIGHT,
|
||
|
OBT_PROP_NET_WM_BOTTOMLEFT,
|
||
|
|
||
|
/* Everything below here must go in net_supported on the root window */
|
||
|
|
||
|
/* root window properties */
|
||
|
OBT_PROP_NET_SUPPORTED,
|
||
|
OBT_PROP_NET_CLIENT_LIST,
|
||
|
OBT_PROP_NET_CLIENT_LIST_STACKING,
|
||
|
OBT_PROP_NET_NUMBER_OF_DESKTOPS,
|
||
|
OBT_PROP_NET_DESKTOP_GEOMETRY,
|
||
|
OBT_PROP_NET_DESKTOP_VIEWPORT,
|
||
|
OBT_PROP_NET_CURRENT_DESKTOP,
|
||
|
OBT_PROP_NET_DESKTOP_NAMES,
|
||
|
OBT_PROP_NET_ACTIVE_WINDOW,
|
||
|
/* Atom net_restack_window;*/
|
||
|
OBT_PROP_NET_WORKAREA,
|
||
|
OBT_PROP_NET_SUPPORTING_WM_CHECK,
|
||
|
OBT_PROP_NET_DESKTOP_LAYOUT,
|
||
|
OBT_PROP_NET_SHOWING_DESKTOP,
|
||
|
|
||
|
/* root window messages */
|
||
|
OBT_PROP_NET_CLOSE_WINDOW,
|
||
|
OBT_PROP_NET_WM_MOVERESIZE,
|
||
|
OBT_PROP_NET_MOVERESIZE_WINDOW,
|
||
|
OBT_PROP_NET_REQUEST_FRAME_EXTENTS,
|
||
|
OBT_PROP_NET_RESTACK_WINDOW,
|
||
|
|
||
|
/* helpful hints to apps that aren't used for anything */
|
||
|
OBT_PROP_NET_WM_FULL_PLACEMENT,
|
||
|
|
||
|
/* startup-notification extension */
|
||
|
OBT_PROP_NET_STARTUP_ID,
|
||
|
|
||
|
/* application window properties */
|
||
|
OBT_PROP_NET_WM_NAME,
|
||
|
OBT_PROP_NET_WM_VISIBLE_NAME,
|
||
|
OBT_PROP_NET_WM_ICON_NAME,
|
||
|
OBT_PROP_NET_WM_VISIBLE_ICON_NAME,
|
||
|
OBT_PROP_NET_WM_DESKTOP,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE,
|
||
|
OBT_PROP_NET_WM_STATE,
|
||
|
OBT_PROP_NET_WM_STRUT,
|
||
|
OBT_PROP_NET_WM_STRUT_PARTIAL,
|
||
|
OBT_PROP_NET_WM_ICON,
|
||
|
OBT_PROP_NET_WM_ICON_GEOMETRY,
|
||
|
/* OBT_PROP_NET_WM_PID, */
|
||
|
OBT_PROP_NET_WM_ALLOWED_ACTIONS,
|
||
|
OBT_PROP_NET_WM_USER_TIME,
|
||
|
OBT_PROP_NET_WM_USER_TIME_WINDOW,
|
||
|
OBT_PROP_NET_FRAME_EXTENTS,
|
||
|
|
||
|
/* application protocols */
|
||
|
/* OBT_PROP_NET_WM_PING, */
|
||
|
#ifdef SYNC
|
||
|
OBT_PROP_NET_WM_SYNC_REQUEST,
|
||
|
OBT_PROP_NET_WM_SYNC_REQUEST_COUNTER,
|
||
|
#endif
|
||
|
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_DESKTOP,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_DOCK,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_TOOLBAR,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_MENU,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_UTILITY,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_SPLASH,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_DIALOG,
|
||
|
OBT_PROP_NET_WM_WINDOW_TYPE_NORMAL,
|
||
|
|
||
|
OBT_PROP_NET_WM_ACTION_MOVE,
|
||
|
OBT_PROP_NET_WM_ACTION_RESIZE,
|
||
|
OBT_PROP_NET_WM_ACTION_MINIMIZE,
|
||
|
OBT_PROP_NET_WM_ACTION_SHADE,
|
||
|
/* OBT_PROP_NET_WM_ACTION_STICK,*/
|
||
|
OBT_PROP_NET_WM_ACTION_MAXIMIZE_HORZ,
|
||
|
OBT_PROP_NET_WM_ACTION_MAXIMIZE_VERT,
|
||
|
OBT_PROP_NET_WM_ACTION_FULLSCREEN,
|
||
|
OBT_PROP_NET_WM_ACTION_CHANGE_DESKTOP,
|
||
|
OBT_PROP_NET_WM_ACTION_CLOSE,
|
||
|
OBT_PROP_NET_WM_ACTION_ABOVE,
|
||
|
OBT_PROP_NET_WM_ACTION_BELOW,
|
||
|
|
||
|
OBT_PROP_NET_WM_STATE_MODAL,
|
||
|
/* OBT_PROP_NET_WM_STATE_STICKY,*/
|
||
|
OBT_PROP_NET_WM_STATE_MAXIMIZED_VERT,
|
||
|
OBT_PROP_NET_WM_STATE_MAXIMIZED_HORZ,
|
||
|
OBT_PROP_NET_WM_STATE_SHADED,
|
||
|
OBT_PROP_NET_WM_STATE_SKIP_TASKBAR,
|
||
|
OBT_PROP_NET_WM_STATE_SKIP_PAGER,
|
||
|
OBT_PROP_NET_WM_STATE_HIDDEN,
|
||
|
OBT_PROP_NET_WM_STATE_FULLSCREEN,
|
||
|
OBT_PROP_NET_WM_STATE_ABOVE,
|
||
|
OBT_PROP_NET_WM_STATE_BELOW,
|
||
|
OBT_PROP_NET_WM_STATE_DEMANDS_ATTENTION,
|
||
|
|
||
|
/* KDE atoms */
|
||
|
|
||
|
OBT_PROP_KDE_WM_CHANGE_STATE,
|
||
|
OBT_PROP_KDE_NET_WM_FRAME_STRUT,
|
||
|
OBT_PROP_KDE_NET_WM_WINDOW_TYPE_OVERRIDE,
|
||
|
|
||
|
/*
|
||
|
OBT_PROP_ROOTPMAPID,
|
||
|
OBT_PROP_ESETROOTID,
|
||
|
*/
|
||
|
|
||
|
/* Openbox specific atoms */
|
||
|
|
||
|
OBT_PROP_OB_WM_ACTION_UNDECORATE,
|
||
|
OBT_PROP_OB_WM_STATE_UNDECORATED,
|
||
|
OBT_PROP_OPENBOX_PID, /* this is depreecated in favour of ob_control */
|
||
|
OBT_PROP_OB_THEME,
|
||
|
OBT_PROP_OB_CONTROL,
|
||
|
|
||
|
OBT_PROP_NUM_ATOMS
|
||
|
} ObtPropAtom;
|
||
|
|
||
|
#define OB_PROP_NUM_PUBLIC_ATOMS (OB_PROP_NUM_ATOMS - OB_PROP_NET_SUPPORTED)
|
||
|
|
||
|
void obt_prop_startup();
|
||
|
|
||
|
Atom obt_prop_atom(ObtPropAtom a);
|
||
|
|
||
|
gboolean obt_prop_get32(Window win, Atom prop, Atom type, guint32 *ret);
|
||
|
gboolean obt_prop_get_array32(Window win, Atom prop, Atom type, guint32 **ret,
|
||
|
guint *nret);
|
||
|
gboolean obt_prop_get_string_locale(Window win, Atom prop, gchar **ret);
|
||
|
gboolean obt_prop_get_string_utf8(Window win, Atom prop, gchar **ret);
|
||
|
gboolean obt_prop_get_strings_locale(Window win, Atom prop, gchar ***ret);
|
||
|
gboolean obt_prop_get_strings_utf8(Window win, Atom prop, gchar ***ret);
|
||
|
|
||
|
void obt_prop_set32(Window win, Atom prop, Atom type, gulong val);
|
||
|
void obt_prop_set_array32(Window win, Atom prop, Atom type, gulong *val,
|
||
|
guint num);
|
||
|
void obt_prop_set_string_utf8(Window win, Atom prop, const gchar *val);
|
||
|
void obt_prop_set_strings_utf8(Window win, Atom prop, gchar **strs);
|
||
|
|
||
|
void obt_prop_erase(Window win, Atom prop);
|
||
|
|
||
|
void obt_prop_message(gint screen, Window about, Atom messagetype,
|
||
|
glong data0, glong data1, glong data2, glong data3,
|
||
|
glong data4, glong mask);
|
||
|
|
||
|
#define PROP_GET32(win, prop, type, ret) \
|
||
|
(prop_get32(win, obt_prop_atom(OB_PROP_##prop), prop_atoms.type, ret))
|
||
|
#define PROP_GETA32(win, prop, type, ret, nret) \
|
||
|
(prop_get_array32(win, obt_prop_atom(OB_PROP_##prop), prop_atoms.type, \
|
||
|
ret, nret))
|
||
|
#define PROP_GETS(win, prop, type, ret) \
|
||
|
(prop_get_string_##type(win, obt_prop_atom(OB_PROP_##prop), ret))
|
||
|
#define PROP_GETSS(win, prop, type, ret) \
|
||
|
(prop_get_strings_##type(win, obt_prop_atom(OB_PROP_##prop), ret))
|
||
|
|
||
|
#define PROP_SET32(win, prop, type, val) \
|
||
|
prop_set32(win, obt_prop_atom(OB_PROP_##prop), \
|
||
|
obt_prop_atom(OB_PROP_##type), val)
|
||
|
#define PROP_SETA32(win, prop, type, val, num) \
|
||
|
prop_set_array32(win, obt_prop_atom(OB_PROP_##prop), \
|
||
|
obt_prop_atom(OB_PROP_##type), val, num)
|
||
|
#define PROP_SETS(win, prop, val) \
|
||
|
prop_set_string_utf8(win, obt_prop_atom(OB_PROP_##prop), val)
|
||
|
#define PROP_SETSS(win, prop, strs) \
|
||
|
prop_set_strings_utf8(win, obt_prop_atom(OB_PROP_##prop), strs)
|
||
|
|
||
|
#define PROP_ERASE(win, prop) prop_erase(win, obt_prop_atom(OB_PROP_##prop))
|
||
|
|
||
|
#define PROP_MSG(screen, about, msgtype, data0, data1, data2, data3, data4) \
|
||
|
(prop_message(screen, about, obt_prop_atom(OB_PROP_##msgtype), \
|
||
|
data0, data1, data2, data3, data4, \
|
||
|
SubstructureNotifyMask | SubstructureRedirectMask))
|
||
|
|
||
|
G_END_DECLS
|
||
|
|
||
|
#endif /* __obt_prop_h */
|