aboutsummaryrefslogtreecommitdiffstats
path: root/sway/config
diff options
context:
space:
mode:
authorLibravatar Tony Crisci <tony@dubstepdish.com>2017-12-16 11:25:59 -0500
committerLibravatar Tony Crisci <tony@dubstepdish.com>2017-12-16 11:25:59 -0500
commitf4a5a0ead4c8b155985c242db1fa5de5fa4807a0 (patch)
treea5f7f787aa04d68f800de9bb91b0813fb57fbc25 /sway/config
parentfix header includes (diff)
downloadsway-f4a5a0ead4c8b155985c242db1fa5de5fa4807a0.tar.gz
sway-f4a5a0ead4c8b155985c242db1fa5de5fa4807a0.tar.zst
sway-f4a5a0ead4c8b155985c242db1fa5de5fa4807a0.zip
put seat and input config in their own files
Diffstat (limited to 'sway/config')
-rw-r--r--sway/config/input.c105
-rw-r--r--sway/config/seat.c127
2 files changed, 232 insertions, 0 deletions
diff --git a/sway/config/input.c b/sway/config/input.c
new file mode 100644
index 00000000..6f8d31f7
--- /dev/null
+++ b/sway/config/input.c
@@ -0,0 +1,105 @@
1#define _XOPEN_SOURCE 700
2#include <stdlib.h>
3#include <limits.h>
4#include <float.h>
5#include "sway/config.h"
6#include "log.h"
7
8struct input_config *new_input_config(const char* identifier) {
9 struct input_config *input = calloc(1, sizeof(struct input_config));
10 if (!input) {
11 sway_log(L_DEBUG, "Unable to allocate input config");
12 return NULL;
13 }
14 sway_log(L_DEBUG, "new_input_config(%s)", identifier);
15 if (!(input->identifier = strdup(identifier))) {
16 free(input);
17 sway_log(L_DEBUG, "Unable to allocate input config");
18 return NULL;
19 }
20
21 input->tap = INT_MIN;
22 input->drag_lock = INT_MIN;
23 input->dwt = INT_MIN;
24 input->send_events = INT_MIN;
25 input->click_method = INT_MIN;
26 input->middle_emulation = INT_MIN;
27 input->natural_scroll = INT_MIN;
28 input->accel_profile = INT_MIN;
29 input->pointer_accel = FLT_MIN;
30 input->scroll_method = INT_MIN;
31 input->left_handed = INT_MIN;
32
33 return input;
34}
35
36void merge_input_config(struct input_config *dst, struct input_config *src) {
37 if (src->identifier) {
38 free(dst->identifier);
39 dst->identifier = strdup(src->identifier);
40 }
41 if (src->accel_profile != INT_MIN) {
42 dst->accel_profile = src->accel_profile;
43 }
44 if (src->click_method != INT_MIN) {
45 dst->click_method = src->click_method;
46 }
47 if (src->drag_lock != INT_MIN) {
48 dst->drag_lock = src->drag_lock;
49 }
50 if (src->dwt != INT_MIN) {
51 dst->dwt = src->dwt;
52 }
53 if (src->middle_emulation != INT_MIN) {
54 dst->middle_emulation = src->middle_emulation;
55 }
56 if (src->natural_scroll != INT_MIN) {
57 dst->natural_scroll = src->natural_scroll;
58 }
59 if (src->pointer_accel != FLT_MIN) {
60 dst->pointer_accel = src->pointer_accel;
61 }
62 if (src->scroll_method != INT_MIN) {
63 dst->scroll_method = src->scroll_method;
64 }
65 if (src->send_events != INT_MIN) {
66 dst->send_events = src->send_events;
67 }
68 if (src->tap != INT_MIN) {
69 dst->tap = src->tap;
70 }
71 if (src->xkb_layout) {
72 free(dst->xkb_layout);
73 dst->xkb_layout = strdup(src->xkb_layout);
74 }
75 if (src->xkb_model) {
76 free(dst->xkb_model);
77 dst->xkb_model = strdup(src->xkb_model);
78 }
79 if (src->xkb_options) {
80 free(dst->xkb_options);
81 dst->xkb_options = strdup(src->xkb_options);
82 }
83 if (src->xkb_rules) {
84 free(dst->xkb_rules);
85 dst->xkb_rules = strdup(src->xkb_rules);
86 }
87 if (src->xkb_variant) {
88 free(dst->xkb_variant);
89 dst->xkb_variant = strdup(src->xkb_variant);
90 }
91}
92
93void free_input_config(struct input_config *ic) {
94 if (!ic) {
95 return;
96 }
97 free(ic->identifier);
98 free(ic);
99}
100
101int input_identifier_cmp(const void *item, const void *data) {
102 const struct input_config *ic = item;
103 const char *identifier = data;
104 return strcmp(ic->identifier, identifier);
105}
diff --git a/sway/config/seat.c b/sway/config/seat.c
new file mode 100644
index 00000000..3a2fdaa6
--- /dev/null
+++ b/sway/config/seat.c
@@ -0,0 +1,127 @@
1#define _XOPEN_SOURCE 700
2#include <stdlib.h>
3#include <string.h>
4#include "sway/config.h"
5#include "log.h"
6
7struct seat_config *new_seat_config(const char* name) {
8 struct seat_config *seat = calloc(1, sizeof(struct seat_config));
9 if (!seat) {
10 sway_log(L_DEBUG, "Unable to allocate seat config");
11 return NULL;
12 }
13
14 sway_log(L_DEBUG, "new_seat_config(%s)", name);
15 seat->name = strdup(name);
16 if (!sway_assert(seat->name, "could not allocate name for seat")) {
17 return NULL;
18 }
19
20 seat->attachments = create_list();
21 if (!sway_assert(seat->attachments,
22 "could not allocate seat attachments list")) {
23 return NULL;
24 }
25
26 return seat;
27}
28
29struct seat_attachment_config *seat_attachment_config_new() {
30 struct seat_attachment_config *attachment =
31 calloc(1, sizeof(struct seat_attachment_config));
32 if (!attachment) {
33 sway_log(L_DEBUG, "cannot allocate attachment config");
34 return NULL;
35 }
36 return attachment;
37}
38
39static void seat_attachment_config_free(
40 struct seat_attachment_config *attachment) {
41 free(attachment->identifier);
42 free(attachment);
43 return;
44}
45
46static struct seat_attachment_config *seat_attachment_config_copy(
47 struct seat_attachment_config *attachment) {
48 struct seat_attachment_config *copy = seat_attachment_config_new();
49 if (!copy) {
50 return NULL;
51 }
52
53 copy->identifier = strdup(attachment->identifier);
54
55 return copy;
56}
57
58static void merge_seat_attachment_config(struct seat_attachment_config *dest,
59 struct seat_attachment_config *source) {
60 // nothing to merge yet, but there will be some day
61}
62
63void merge_seat_config(struct seat_config *dest, struct seat_config *source) {
64 if (source->name) {
65 free(dest->name);
66 dest->name = strdup(source->name);
67 }
68
69 for (int i = 0; i < source->attachments->length; ++i) {
70 struct seat_attachment_config *source_attachment =
71 source->attachments->items[i];
72 bool found = false;
73 for (int j = 0; j < dest->attachments->length; ++j) {
74 struct seat_attachment_config *dest_attachment =
75 dest->attachments->items[j];
76 if (strcmp(source_attachment->identifier,
77 dest_attachment->identifier) == 0) {
78 merge_seat_attachment_config(dest_attachment,
79 source_attachment);
80 found = true;
81 }
82 }
83
84 if (!found) {
85 struct seat_attachment_config *copy =
86 seat_attachment_config_copy(source_attachment);
87 if (copy) {
88 list_add(dest->attachments, copy);
89 }
90 }
91 }
92}
93
94void free_seat_config(struct seat_config *seat) {
95 if (!seat) {
96 return;
97 }
98
99 free(seat->name);
100 for (int i = 0; i < seat->attachments->length; ++i) {
101 struct seat_attachment_config *attachment =
102 seat->attachments->items[i];
103 seat_attachment_config_free(attachment);
104 }
105
106 list_free(seat->attachments);
107 free(seat);
108}
109
110int seat_name_cmp(const void *item, const void *data) {
111 const struct seat_config *sc = item;
112 const char *name = data;
113 return strcmp(sc->name, name);
114}
115
116struct seat_attachment_config *seat_config_get_attachment(
117 struct seat_config *seat_config, char *identifier) {
118 for (int i = 0; i < seat_config->attachments->length; ++i) {
119 struct seat_attachment_config *attachment =
120 seat_config->attachments->items[i];
121 if (strcmp(attachment->identifier, identifier) == 0) {
122 return attachment;
123 }
124 }
125
126 return NULL;
127}