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>
|
2015-09-18 13:16:20 +02:00
|
|
|
#include <sys/types.h>
|
2015-10-18 19:53:56 +02:00
|
|
|
#include <sys/un.h>
|
2015-08-13 09:44:56 +02:00
|
|
|
#include <signal.h>
|
2015-08-20 14:37:09 +02:00
|
|
|
#include <getopt.h>
|
2015-11-19 04:01:22 +01:00
|
|
|
#include "extensions.h"
|
2015-08-06 14:40:16 +02:00
|
|
|
#include "layout.h"
|
2015-09-18 13:27:35 +02:00
|
|
|
#include "stringop.h"
|
2015-08-05 03:30:40 +02:00
|
|
|
#include "config.h"
|
2015-08-08 23:01:22 +02:00
|
|
|
#include "log.h"
|
2015-09-02 17:46:21 +02:00
|
|
|
#include "readline.h"
|
2015-08-06 14:24:14 +02:00
|
|
|
#include "handlers.h"
|
2015-11-27 15:50:04 +01:00
|
|
|
#include "ipc-server.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-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-09-02 17:46:21 +02:00
|
|
|
void detect_nvidia() {
|
|
|
|
FILE *f = fopen("/proc/modules", "r");
|
|
|
|
if (!f) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
while (!feof(f)) {
|
|
|
|
char *line = read_line(f);
|
|
|
|
if (strstr(line, "nvidia")) {
|
|
|
|
fprintf(stderr, "\x1B[1;31mWarning: Proprietary nvidia drivers do NOT support Wayland. Use nouveau.\x1B[0m\n");
|
|
|
|
free(line);
|
2015-09-02 17:47:15 +02:00
|
|
|
break;
|
2015-09-02 17:46:21 +02:00
|
|
|
}
|
|
|
|
free(line);
|
|
|
|
}
|
2015-09-02 17:47:15 +02:00
|
|
|
fclose(f);
|
2015-09-02 17:46:21 +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
|
|
|
};
|
|
|
|
|
|
|
|
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-27 04:13:53 +02:00
|
|
|
#if defined SWAY_GIT_VERSION && defined SWAY_GIT_BRANCH && defined SWAY_VERSION_DATE
|
|
|
|
fprintf(stdout, "sway version %s (%s, branch \"%s\")\n", SWAY_GIT_VERSION, SWAY_VERSION_DATE, SWAY_GIT_BRANCH);
|
2015-08-26 05:04:57 +02:00
|
|
|
#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;
|
2015-10-18 19:53:56 +02:00
|
|
|
case 'p': ; // --get-socketpath
|
2015-11-13 17:53:46 +01:00
|
|
|
if (getenv("SWAYSOCK")) {
|
|
|
|
fprintf(stdout, "%s\n", getenv("SWAYSOCK"));
|
|
|
|
exit(0);
|
|
|
|
} else {
|
|
|
|
fprintf(stderr, "sway socket not detected.\n");
|
|
|
|
exit(1);
|
|
|
|
}
|
2015-08-20 14:37:09 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-28 19:52:28 +01:00
|
|
|
setenv("WLC_DIM", "0", 0);
|
|
|
|
wlc_log_set_handler(wlc_log_handler);
|
|
|
|
detect_nvidia();
|
|
|
|
|
|
|
|
/* Changing code earlier than this point requires detailed review */
|
|
|
|
/* (That code runs as root on systems without logind, and wlc_init drops to
|
|
|
|
* another user.) */
|
|
|
|
if (!wlc_init(&interface, argc, argv)) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
register_extensions();
|
|
|
|
|
2015-08-20 14:37:09 +02:00
|
|
|
if (debug) {
|
|
|
|
init_log(L_DEBUG);
|
|
|
|
} else if (verbose || validate) {
|
|
|
|
init_log(L_INFO);
|
|
|
|
} else {
|
|
|
|
init_log(L_ERROR);
|
|
|
|
}
|
|
|
|
|
2015-09-02 15:42:27 +02:00
|
|
|
#if defined SWAY_GIT_VERSION && defined SWAY_GIT_BRANCH && defined SWAY_VERSION_DATE
|
|
|
|
sway_log(L_INFO, "Starting sway version %s (%s, branch \"%s\")\n", SWAY_GIT_VERSION, SWAY_VERSION_DATE, SWAY_GIT_BRANCH);
|
|
|
|
#endif
|
|
|
|
|
2015-08-20 14:37:09 +02:00
|
|
|
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-10-08 12:24:35 +02:00
|
|
|
|