aboutsummaryrefslogtreecommitdiffstats
path: root/sway
diff options
context:
space:
mode:
authorLibravatar Drew DeVault <sir@cmpwn.com>2017-11-19 17:04:28 -0500
committerLibravatar Drew DeVault <sir@cmpwn.com>2017-11-19 17:04:28 -0500
commitdb4fb1c85c132e001fb1ae18f03f7585def1ae19 (patch)
tree91da84c9476e6ec34c65f3f8923961fd893fa721 /sway
parentMove everything to sway/old/ (diff)
downloadsway-db4fb1c85c132e001fb1ae18f03f7585def1ae19.tar.gz
sway-db4fb1c85c132e001fb1ae18f03f7585def1ae19.tar.zst
sway-db4fb1c85c132e001fb1ae18f03f7585def1ae19.zip
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
14 desktop/output.c 14 desktop/output.c
15 desktop/xdg_shell_v6.c 15 desktop/xdg_shell_v6.c
16 16
17 tree/layout.c
18 tree/container.c
19
17 base64.c 20 base64.c
18 main.c 21 main.c
19 server.c 22 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 @@
5#include <wlr/types/wlr_output.h> 5#include <wlr/types/wlr_output.h>
6#include <wlr/render.h> 6#include <wlr/render.h>
7#include "log.h" 7#include "log.h"
8#include "sway/container.h"
8#include "sway/output.h" 9#include "sway/output.h"
9#include "sway/server.h" 10#include "sway/server.h"
10 11
@@ -34,11 +35,10 @@ void output_add_notify(struct wl_listener *listener, void *data) {
34 struct sway_output *output = calloc(1, sizeof(struct sway_output)); 35 struct sway_output *output = calloc(1, sizeof(struct sway_output));
35 output->wlr_output = wlr_output; 36 output->wlr_output = wlr_output;
36 output->server = server; 37 output->server = server;
38 output->swayc = new_output(output);
37 39
38 output->frame.notify = output_frame_notify; 40 output->frame.notify = output_frame_notify;
39 wl_signal_add(&wlr_output->events.frame, &output->frame); 41 wl_signal_add(&wlr_output->events.frame, &output->frame);
40
41 // TODO: Add to tree
42} 42}
43 43
44void output_remove_notify(struct wl_listener *listener, void *data) { 44void 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 @@
16#include <sys/prctl.h> 16#include <sys/prctl.h>
17#endif 17#endif
18#include "sway/server.h" 18#include "sway/server.h"
19#include "sway/layout.h"
19#include "ipc-client.h" 20#include "ipc-client.h"
21#include "log.h"
20#include "readline.h" 22#include "readline.h"
21#include "stringop.h" 23#include "stringop.h"
22#include "log.h"
23#include "util.h" 24#include "util.h"
24 25
25static bool terminate_request = false; 26static bool terminate_request = false;
@@ -436,7 +437,7 @@ int main(int argc, char **argv) {
436 return 1; 437 return 1;
437 } 438 }
438 439
439 //init_layout(); 440 init_layout();
440 //ipc_init(); 441 //ipc_init();
441 442
442 //if (validate) { 443 //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 @@
1#define _POSIX_C_SOURCE 200809L
2#include <stdint.h>
3#include <stdlib.h>
4#include <string.h>
5#include "sway/container.h"
6#include "sway/layout.h"
7#include "sway/output.h"
8
9static swayc_t *new_swayc(enum swayc_types type) {
10 // next id starts at 1 because 0 is assigned to root_container in layout.c
11 static size_t next_id = 1;
12 swayc_t *c = calloc(1, sizeof(swayc_t));
13 if (!c) {
14 return NULL;
15 }
16 c->id = next_id++;
17 c->layout = L_NONE;
18 c->workspace_layout = L_NONE;
19 c->type = type;
20 c->nb_master = 1;
21 c->nb_slave_groups = 1;
22 if (type != C_VIEW) {
23 c->children = create_list();
24 }
25 return c;
26}
27
28swayc_t *new_output(struct sway_output *sway_output) {
29 struct wlr_box size;
30 wlr_output_effective_resolution(sway_output->wlr_output,
31 &size.width, &size.height);
32 const char *name = sway_output->wlr_output->name;
33
34 swayc_t *output = new_swayc(C_OUTPUT);
35 output->sway_output = sway_output;
36 output->name = name ? strdup(name) : NULL;
37 output->width = size.width;
38 output->height = size.width;
39
40 add_child(&root_container, output);
41
42 // TODO: Create workspace
43
44 return output;
45}
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 @@
1#define _POSIX_C_SOURCE 200809L
2#include <stdbool.h>
3#include <string.h>
4#include <wlr/types/wlr_output_layout.h>
5#include "sway/container.h"
6#include "list.h"
7#include "log.h"
8
9swayc_t root_container;
10
11void init_layout(void) {
12 root_container.id = 0; // normally assigned in new_swayc()
13 root_container.type = C_ROOT;
14 root_container.layout = L_NONE;
15 root_container.name = strdup("root");
16 root_container.children = create_list();
17 root_container.output_layout = wlr_output_layout_create();
18}
19
20void add_child(swayc_t *parent, swayc_t *child) {
21 sway_log(L_DEBUG, "Adding %p (%d, %fx%f) to %p (%d, %fx%f)",
22 child, child->type, child->width, child->height,
23 parent, parent->type, parent->width, parent->height);
24 list_add(parent->children, child);
25 child->parent = parent;
26 // set focus for this container
27 if (!parent->focused) {
28 parent->focused = child;
29 }
30 /* TODO WLR
31 if (parent->type == C_WORKSPACE && child->type == C_VIEW && (parent->workspace_layout == L_TABBED || parent->workspace_layout == L_STACKED)) {
32 child = new_container(child, parent->workspace_layout);
33 }
34 */
35}