2015-08-05 03:02:46 +02:00
|
|
|
#include <stdio.h>
|
2015-08-05 03:30:40 +02:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <wlc/wlc.h>
|
2015-08-13 09:44:56 +02:00
|
|
|
#include <sys/wait.h>
|
|
|
|
#include <signal.h>
|
2015-08-20 14:37:09 +02:00
|
|
|
#include <getopt.h>
|
2015-08-06 14:40:16 +02:00
|
|
|
#include "layout.h"
|
2015-08-05 03:30:40 +02:00
|
|
|
#include "config.h"
|
2015-08-08 23:01:22 +02:00
|
|
|
#include "log.h"
|
2015-08-06 14:24:14 +02:00
|
|
|
#include "handlers.h"
|
2015-08-16 20:24:18 +02:00
|
|
|
#include "ipc.h"
|
2015-08-20 15:12:34 +02:00
|
|
|
#include "sway.h"
|
|
|
|
|
|
|
|
static bool terminate_request = false;
|
|
|
|
|
|
|
|
void sway_terminate(void) {
|
|
|
|
terminate_request = true;
|
|
|
|
wlc_terminate();
|
|
|
|
}
|
2015-08-05 03:02:46 +02:00
|
|
|
|
2015-08-13 09:44:56 +02:00
|
|
|
static void sigchld_handle(int signal);
|
2015-08-05 03:30:40 +02:00
|
|
|
|
2015-08-23 19:08:04 +02:00
|
|
|
static void wlc_log_handler(enum wlc_log_type type, const char *str) {
|
|
|
|
if (type == WLC_LOG_ERROR) {
|
2015-08-23 19:31:16 +02:00
|
|
|
sway_log(L_ERROR, "[wlc] %s", str);
|
2015-08-23 19:08:04 +02:00
|
|
|
} else if (type == WLC_LOG_WARN) {
|
2015-08-23 19:31:16 +02:00
|
|
|
sway_log(L_INFO, "[wlc] %s", str);
|
2015-08-23 19:08:04 +02:00
|
|
|
} else {
|
2015-08-23 19:31:16 +02:00
|
|
|
sway_log(L_DEBUG, "[wlc] %s", str);
|
2015-08-23 19:08:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-05 03:30:40 +02:00
|
|
|
int main(int argc, char **argv) {
|
2015-08-20 14:37:09 +02:00
|
|
|
static int verbose = 0, debug = 0, validate = 0;
|
|
|
|
|
|
|
|
static struct option long_options[] = {
|
|
|
|
{"config", required_argument, NULL, 'c'},
|
|
|
|
{"validate", no_argument, &validate, 1},
|
|
|
|
{"debug", no_argument, &debug, 1},
|
|
|
|
{"version", no_argument, NULL, 'v'},
|
|
|
|
{"verbose", no_argument, &verbose, 1},
|
|
|
|
{"get-socketpath", no_argument, NULL, 'p'},
|
2015-08-26 20:01:26 +02:00
|
|
|
{0, 0, 0, 0}
|
2015-08-20 14:37:09 +02:00
|
|
|
};
|
|
|
|
|
2015-08-13 09:44:56 +02:00
|
|
|
/* Signal handling */
|
|
|
|
signal(SIGCHLD, sigchld_handle);
|
|
|
|
|
2015-08-10 14:29:57 +02:00
|
|
|
setenv("WLC_DIM", "0", 0);
|
2015-08-20 14:37:09 +02:00
|
|
|
|
2015-08-23 19:08:04 +02:00
|
|
|
wlc_log_set_handler(wlc_log_handler);
|
|
|
|
|
2015-08-18 00:20:56 +02:00
|
|
|
/* Changing code earlier than this point requires detailed review */
|
2015-08-05 03:30:40 +02:00
|
|
|
if (!wlc_init(&interface, argc, argv)) {
|
|
|
|
return 1;
|
|
|
|
}
|
2015-08-18 00:20:56 +02:00
|
|
|
|
2015-08-20 14:37:09 +02:00
|
|
|
char *config_path = NULL;
|
|
|
|
|
|
|
|
int c;
|
|
|
|
while (1) {
|
|
|
|
int option_index = 0;
|
|
|
|
c = getopt_long(argc, argv, "CdvVpc:", long_options, &option_index);
|
|
|
|
if (c == -1) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
switch (c) {
|
|
|
|
case 0: // Flag
|
|
|
|
break;
|
|
|
|
case 'c': // config
|
|
|
|
config_path = strdup(optarg);
|
|
|
|
break;
|
|
|
|
case 'C': // validate
|
|
|
|
validate = 1;
|
|
|
|
break;
|
|
|
|
case 'd': // debug
|
|
|
|
debug = 1;
|
|
|
|
break;
|
|
|
|
case 'v': // version
|
2015-08-26 05:04:57 +02:00
|
|
|
#ifdef SWAY_GIT_VERSION
|
|
|
|
fprintf(stdout, "sway build %s\n", SWAY_GIT_VERSION);
|
|
|
|
#else
|
|
|
|
fprintf(stdout, "version not detected\n");
|
|
|
|
#endif
|
2015-08-20 14:37:09 +02:00
|
|
|
exit(0);
|
|
|
|
break;
|
|
|
|
case 'V': // verbose
|
|
|
|
verbose = 1;
|
|
|
|
break;
|
|
|
|
case 'p': // --get-socketpath
|
|
|
|
// TODO
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (debug) {
|
|
|
|
init_log(L_DEBUG);
|
|
|
|
} else if (verbose || validate) {
|
|
|
|
init_log(L_INFO);
|
|
|
|
} else {
|
|
|
|
init_log(L_ERROR);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (validate) {
|
|
|
|
bool valid = load_config(config_path);
|
|
|
|
return valid ? 0 : 1;
|
|
|
|
}
|
|
|
|
|
2015-08-18 00:20:56 +02:00
|
|
|
init_layout();
|
2015-08-11 02:50:22 +02:00
|
|
|
|
2015-08-20 14:37:09 +02:00
|
|
|
if (!load_config(config_path)) {
|
2015-08-18 00:15:05 +02:00
|
|
|
sway_log(L_ERROR, "Error(s) loading config!");
|
|
|
|
}
|
2015-08-20 14:37:09 +02:00
|
|
|
if (config_path) {
|
|
|
|
free(config_path);
|
|
|
|
}
|
2015-08-18 00:15:05 +02:00
|
|
|
|
2015-08-19 01:52:46 +02:00
|
|
|
ipc_init();
|
2015-08-16 20:24:18 +02:00
|
|
|
|
2015-08-20 15:12:34 +02:00
|
|
|
if (!terminate_request) {
|
|
|
|
wlc_run();
|
|
|
|
}
|
|
|
|
|
|
|
|
ipc_terminate();
|
2015-08-19 01:52:46 +02:00
|
|
|
|
2015-08-05 03:02:46 +02:00
|
|
|
return 0;
|
|
|
|
}
|
2015-08-13 09:44:56 +02:00
|
|
|
|
2015-08-26 20:01:26 +02:00
|
|
|
void sigchld_handle(int signal) {
|
2015-08-13 09:44:56 +02:00
|
|
|
(void) signal;
|
|
|
|
while (waitpid((pid_t)-1, 0, WNOHANG) > 0);
|
|
|
|
}
|