aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <ddevault@linode.com>2015-08-10 11:50:32 -0400
committerDrew DeVault <ddevault@linode.com>2015-08-10 11:50:32 -0400
commit06bca18a09d102aeed07284a4155909f6b75d896 (patch)
tree5a51f970e34acddea33d110dd4397b548a57e11f
parent8525548a3464d0060db2fe6746643abd13545715 (diff)
Fix issue with untitled windows
-rw-r--r--sway/layout.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/sway/layout.c b/sway/layout.c
index e9fa2a7a..d7806ee5 100644
--- a/sway/layout.c
+++ b/sway/layout.c
@@ -163,13 +163,14 @@ swayc_t *get_focused_container(swayc_t *parent) {
void add_view(wlc_handle view_handle) {
const uint32_t type = wlc_view_get_type(view_handle);
const char *title = wlc_view_get_title(view_handle);
- if ((type & WLC_BIT_UNMANAGED) || (type & WLC_BIT_POPUP) || (type & WLC_BIT_MODAL) || (type & WLC_BIT_SPLASH)) {
+ if ((type & WLC_BIT_OVERRIDE_REDIRECT) || (type & WLC_BIT_UNMANAGED) || (type &
+ WLC_BIT_POPUP) || (type & WLC_BIT_MODAL) || (type & WLC_BIT_SPLASH)) {
sway_log(L_DEBUG, "Leaving view %d:%s alone (unmanaged)", view_handle, title);
return;
}
swayc_t *parent = get_focused_container(&root_container);
- sway_log(L_DEBUG, "Adding new view %d:%s under container %p %d", view_handle, title, parent, parent->type);
+ sway_log(L_DEBUG, "Adding new view %d:%s:%d under container %p %d", view_handle, title, type, parent, parent->type);
while (parent->type == C_VIEW) {
parent = parent->parent;
@@ -181,8 +182,10 @@ void add_view(wlc_handle view_handle) {
view->handle = view_handle;
view->parent = parent;
view->type = C_VIEW;
- view->name = malloc(strlen(title) + 1);
- strcpy(view->name, title);
+ if (title) {
+ view->name = malloc(strlen(title) + 1);
+ strcpy(view->name, title);
+ }
add_child(parent, view);
unfocus_all(&root_container);