aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2020-03-06 12:29:20 +0100
committerDrew DeVault <sir@cmpwn.com>2020-03-06 21:34:44 +0100
commit68a69ee0798694c54e434f425b4d56690b65b939 (patch)
tree906faad4a312c438cf8fb351b155df8f9b548169
parent52c67284e25c6a31a260b4918132f7842e18532d (diff)
xwayland: use explicit indexes when initializing atom_map
It's very easy to break the mapping between the atom_name enum and the atom_map array. Use explicit indexes to prevent issues.
-rw-r--r--include/xwayland/xwm.h2
-rw-r--r--xwayland/xwm.c124
2 files changed, 63 insertions, 63 deletions
diff --git a/include/xwayland/xwm.h b/include/xwayland/xwm.h
index 00f2f3d5..d7659ea0 100644
--- a/include/xwayland/xwm.h
+++ b/include/xwayland/xwm.h
@@ -81,7 +81,7 @@ enum atom_name {
DND_ACTION_ASK,
DND_ACTION_PRIVATE,
_NET_CLIENT_LIST,
- ATOM_LAST,
+ ATOM_LAST // keep last
};
extern const char *atom_map[ATOM_LAST];
diff --git a/xwayland/xwm.c b/xwayland/xwm.c
index 1658e25d..1cbc5921 100644
--- a/xwayland/xwm.c
+++ b/xwayland/xwm.c
@@ -17,68 +17,68 @@
#include "xwayland/xwm.h"
const char *atom_map[ATOM_LAST] = {
- "WL_SURFACE_ID",
- "WM_DELETE_WINDOW",
- "WM_PROTOCOLS",
- "WM_HINTS",
- "WM_NORMAL_HINTS",
- "WM_SIZE_HINTS",
- "WM_WINDOW_ROLE",
- "_MOTIF_WM_HINTS",
- "UTF8_STRING",
- "WM_S0",
- "_NET_SUPPORTED",
- "_NET_WM_CM_S0",
- "_NET_WM_PID",
- "_NET_WM_NAME",
- "_NET_WM_STATE",
- "_NET_WM_WINDOW_TYPE",
- "WM_TAKE_FOCUS",
- "WINDOW",
- "_NET_ACTIVE_WINDOW",
- "_NET_WM_MOVERESIZE",
- "_NET_WM_NAME",
- "_NET_SUPPORTING_WM_CHECK",
- "_NET_WM_STATE_MODAL",
- "_NET_WM_STATE_FULLSCREEN",
- "_NET_WM_STATE_MAXIMIZED_VERT",
- "_NET_WM_STATE_MAXIMIZED_HORZ",
- "_NET_WM_PING",
- "WM_STATE",
- "CLIPBOARD",
- "PRIMARY",
- "_WL_SELECTION",
- "TARGETS",
- "CLIPBOARD_MANAGER",
- "INCR",
- "TEXT",
- "TIMESTAMP",
- "DELETE",
- "_NET_WM_WINDOW_TYPE_NORMAL",
- "_NET_WM_WINDOW_TYPE_UTILITY",
- "_NET_WM_WINDOW_TYPE_TOOLTIP",
- "_NET_WM_WINDOW_TYPE_DND",
- "_NET_WM_WINDOW_TYPE_DROPDOWN_MENU",
- "_NET_WM_WINDOW_TYPE_POPUP_MENU",
- "_NET_WM_WINDOW_TYPE_COMBO",
- "_NET_WM_WINDOW_TYPE_MENU",
- "_NET_WM_WINDOW_TYPE_NOTIFICATION",
- "_NET_WM_WINDOW_TYPE_SPLASH",
- "XdndSelection",
- "XdndAware",
- "XdndStatus",
- "XdndPosition",
- "XdndEnter",
- "XdndLeave",
- "XdndDrop",
- "XdndFinished",
- "XdndProxy",
- "XdndTypeList",
- "XdndActionMove",
- "XdndActionCopy",
- "XdndActionAsk",
- "XdndActionPrivate",
- "_NET_CLIENT_LIST",
+ [WL_SURFACE_ID] = "WL_SURFACE_ID",
+ [WM_DELETE_WINDOW] = "WM_DELETE_WINDOW",
+ [WM_PROTOCOLS] = "WM_PROTOCOLS",
+ [WM_HINTS] = "WM_HINTS",
+ [WM_NORMAL_HINTS] = "WM_NORMAL_HINTS",
+ [WM_SIZE_HINTS] = "WM_SIZE_HINTS",
+ [WM_WINDOW_ROLE] = "WM_WINDOW_ROLE",
+ [MOTIF_WM_HINTS] = "_MOTIF_WM_HINTS",
+ [UTF8_STRING] = "UTF8_STRING",
+ [WM_S0] = "WM_S0",
+ [NET_SUPPORTED] = "_NET_SUPPORTED",
+ [NET_WM_CM_S0] = "_NET_WM_CM_S0",
+ [NET_WM_PID] = "_NET_WM_PID",
+ [NET_WM_NAME] = "_NET_WM_NAME",
+ [NET_WM_STATE] = "_NET_WM_STATE",
+ [NET_WM_WINDOW_TYPE] = "_NET_WM_WINDOW_TYPE",
+ [WM_TAKE_FOCUS] = "WM_TAKE_FOCUS",
+ [WINDOW] = "WINDOW",
+ [_NET_ACTIVE_WINDOW] = "_NET_ACTIVE_WINDOW",
+ [_NET_WM_MOVERESIZE] = "_NET_WM_MOVERESIZE",
+ [_NET_WM_NAME] = "_NET_WM_NAME",
+ [_NET_SUPPORTING_WM_CHECK] = "_NET_SUPPORTING_WM_CHECK",
+ [_NET_WM_STATE_MODAL] = "_NET_WM_STATE_MODAL",
+ [_NET_WM_STATE_FULLSCREEN] = "_NET_WM_STATE_FULLSCREEN",
+ [_NET_WM_STATE_MAXIMIZED_VERT] = "_NET_WM_STATE_MAXIMIZED_VERT",
+ [_NET_WM_STATE_MAXIMIZED_HORZ] = "_NET_WM_STATE_MAXIMIZED_HORZ",
+ [_NET_WM_PING] = "_NET_WM_PING",
+ [WM_STATE] = "WM_STATE",
+ [CLIPBOARD] = "CLIPBOARD",
+ [PRIMARY] = "PRIMARY",
+ [WL_SELECTION] = "_WL_SELECTION",
+ [TARGETS] = "TARGETS",
+ [CLIPBOARD_MANAGER] = "CLIPBOARD_MANAGER",
+ [INCR] = "INCR",
+ [TEXT] = "TEXT",
+ [TIMESTAMP] = "TIMESTAMP",
+ [DELETE] = "DELETE",
+ [NET_WM_WINDOW_TYPE_NORMAL] = "_NET_WM_WINDOW_TYPE_NORMAL",
+ [NET_WM_WINDOW_TYPE_UTILITY] = "_NET_WM_WINDOW_TYPE_UTILITY",
+ [NET_WM_WINDOW_TYPE_TOOLTIP] = "_NET_WM_WINDOW_TYPE_TOOLTIP",
+ [NET_WM_WINDOW_TYPE_DND] = "_NET_WM_WINDOW_TYPE_DND",
+ [NET_WM_WINDOW_TYPE_DROPDOWN_MENU] = "_NET_WM_WINDOW_TYPE_DROPDOWN_MENU",
+ [NET_WM_WINDOW_TYPE_POPUP_MENU] = "_NET_WM_WINDOW_TYPE_POPUP_MENU",
+ [NET_WM_WINDOW_TYPE_COMBO] = "_NET_WM_WINDOW_TYPE_COMBO",
+ [NET_WM_WINDOW_TYPE_MENU] = "_NET_WM_WINDOW_TYPE_MENU",
+ [NET_WM_WINDOW_TYPE_NOTIFICATION] = "_NET_WM_WINDOW_TYPE_NOTIFICATION",
+ [NET_WM_WINDOW_TYPE_SPLASH] = "_NET_WM_WINDOW_TYPE_SPLASH",
+ [DND_SELECTION] = "XdndSelection",
+ [DND_AWARE] = "XdndAware",
+ [DND_STATUS] = "XdndStatus",
+ [DND_POSITION] = "XdndPosition",
+ [DND_ENTER] = "XdndEnter",
+ [DND_LEAVE] = "XdndLeave",
+ [DND_DROP] = "XdndDrop",
+ [DND_FINISHED] = "XdndFinished",
+ [DND_PROXY] = "XdndProxy",
+ [DND_TYPE_LIST] = "XdndTypeList",
+ [DND_ACTION_MOVE] = "XdndActionMove",
+ [DND_ACTION_COPY] = "XdndActionCopy",
+ [DND_ACTION_ASK] = "XdndActionAsk",
+ [DND_ACTION_PRIVATE] = "XdndActionPrivate",
+ [_NET_CLIENT_LIST] = "_NET_CLIENT_LIST",
};
static const struct wlr_surface_role xwayland_surface_role;