aboutsummaryrefslogtreecommitdiff
path: root/sway
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2017-11-19 17:04:28 -0500
committerDrew DeVault <sir@cmpwn.com>2017-11-19 17:04:28 -0500
commitdb4fb1c85c132e001fb1ae18f03f7585def1ae19 (patch)
tree91da84c9476e6ec34c65f3f8923961fd893fa721 /sway
parent733993a651c71f7e2198d505960d6bbd31e0e107 (diff)
downloadsway-db4fb1c85c132e001fb1ae18f03f7585def1ae19.tar.xz
Add outputs to the tree
Diffstat (limited to 'sway')
-rw-r--r--sway/CMakeLists.txt3
-rw-r--r--sway/desktop/output.c4
-rw-r--r--sway/main.c5
-rw-r--r--sway/tree/container.c45
-rw-r--r--sway/tree/layout.c35
5 files changed, 88 insertions, 4 deletions
diff --git a/sway/CMakeLists.txt b/sway/CMakeLists.txt
index 73531a84..9a92466c 100644
--- a/sway/CMakeLists.txt
+++ b/sway/CMakeLists.txt
@@ -14,6 +14,9 @@ add_executable(sway
desktop/output.c
desktop/xdg_shell_v6.c
+ tree/layout.c
+ tree/container.c
+
base64.c
main.c
server.c
diff --git a/sway/desktop/output.c b/sway/desktop/output.c
index 6ddcac3b..27579c1b 100644
--- a/sway/desktop/output.c
+++ b/sway/desktop/output.c
@@ -5,6 +5,7 @@
#include <wlr/types/wlr_output.h>
#include <wlr/render.h>
#include "log.h"
+#include "sway/container.h"
#include "sway/output.h"
#include "sway/server.h"
@@ -34,11 +35,10 @@ void output_add_notify(struct wl_listener *listener, void *data) {
struct sway_output *output = calloc(1, sizeof(struct sway_output));
output->wlr_output = wlr_output;
output->server = server;
+ output->swayc = new_output(output);
output->frame.notify = output_frame_notify;
wl_signal_add(&wlr_output->events.frame, &output->frame);
-
- // TODO: Add to tree
}
void output_remove_notify(struct wl_listener *listener, void *data) {
diff --git a/sway/main.c b/sway/main.c
index 5710a099..42262b05 100644
--- a/sway/main.c
+++ b/sway/main.c
@@ -16,10 +16,11 @@
#include <sys/prctl.h>
#endif
#include "sway/server.h"
+#include "sway/layout.h"
#include "ipc-client.h"
+#include "log.h"
#include "readline.h"
#include "stringop.h"
-#include "log.h"
#include "util.h"
static bool terminate_request = false;
@@ -436,7 +437,7 @@ int main(int argc, char **argv) {
return 1;
}
- //init_layout();
+ init_layout();
//ipc_init();
//if (validate) {
diff --git a/sway/tree/container.c b/sway/tree/container.c
new file mode 100644
index 00000000..54bcf478
--- /dev/null
+++ b/sway/tree/container.c
@@ -0,0 +1,45 @@
+#define _POSIX_C_SOURCE 200809L
+#include <stdint.h>
+#include <stdlib.h>
+#include <string.h>
+#include "sway/container.h"
+#include "sway/layout.h"
+#include "sway/output.h"
+
+static swayc_t *new_swayc(enum swayc_types type) {
+ // next id starts at 1 because 0 is assigned to root_container in layout.c
+ static size_t next_id = 1;
+ swayc_t *c = calloc(1, sizeof(swayc_t));
+ if (!c) {
+ return NULL;
+ }
+ c->id = next_id++;
+ c->layout = L_NONE;
+ c->workspace_layout = L_NONE;
+ c->type = type;
+ c->nb_master = 1;
+ c->nb_slave_groups = 1;
+ if (type != C_VIEW) {
+ c->children = create_list();
+ }
+ return c;
+}
+
+swayc_t *new_output(struct sway_output *sway_output) {
+ struct wlr_box size;
+ wlr_output_effective_resolution(sway_output->wlr_output,
+ &size.width, &size.height);
+ const char *name = sway_output->wlr_output->name;
+
+ swayc_t *output = new_swayc(C_OUTPUT);
+ output->sway_output = sway_output;
+ output->name = name ? strdup(name) : NULL;
+ output->width = size.width;
+ output->height = size.width;
+
+ add_child(&root_container, output);
+
+ // TODO: Create workspace
+
+ return output;
+}
diff --git a/sway/tree/layout.c b/sway/tree/layout.c
new file mode 100644
index 00000000..06200bbf
--- /dev/null
+++ b/sway/tree/layout.c
@@ -0,0 +1,35 @@
+#define _POSIX_C_SOURCE 200809L
+#include <stdbool.h>
+#include <string.h>
+#include <wlr/types/wlr_output_layout.h>
+#include "sway/container.h"
+#include "list.h"
+#include "log.h"
+
+swayc_t root_container;
+
+void init_layout(void) {
+ root_container.id = 0; // normally assigned in new_swayc()
+ root_container.type = C_ROOT;
+ root_container.layout = L_NONE;
+ root_container.name = strdup("root");
+ root_container.children = create_list();
+ root_container.output_layout = wlr_output_layout_create();
+}
+
+void add_child(swayc_t *parent, swayc_t *child) {
+ sway_log(L_DEBUG, "Adding %p (%d, %fx%f) to %p (%d, %fx%f)",
+ child, child->type, child->width, child->height,
+ parent, parent->type, parent->width, parent->height);
+ list_add(parent->children, child);
+ child->parent = parent;
+ // set focus for this container
+ if (!parent->focused) {
+ parent->focused = child;
+ }
+ /* TODO WLR
+ if (parent->type == C_WORKSPACE && child->type == C_VIEW && (parent->workspace_layout == L_TABBED || parent->workspace_layout == L_STACKED)) {
+ child = new_container(child, parent->workspace_layout);
+ }
+ */
+}