sway-patched-tray-menu-github/sway/main.c

155 lines
3.2 KiB
C
Raw Normal View History

2015-08-04 21:02:46 -04:00
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <wlc/wlc.h>
2015-08-13 00:44:56 -07:00
#include <sys/wait.h>
#include <sys/types.h>
#include <sys/un.h>
2015-08-13 00:44:56 -07:00
#include <signal.h>
2015-08-20 08:37:09 -04:00
#include <getopt.h>
2015-08-06 08:40:16 -04:00
#include "layout.h"
#include "stringop.h"
#include "config.h"
#include "log.h"
#include "readline.h"
#include "handlers.h"
#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-04 21:02:46 -04:00
2015-08-23 13:08:04 -04:00
static void wlc_log_handler(enum wlc_log_type type, const char *str) {
if (type == WLC_LOG_ERROR) {
2015-08-23 13:31:16 -04:00
sway_log(L_ERROR, "[wlc] %s", str);
2015-08-23 13:08:04 -04:00
} else if (type == WLC_LOG_WARN) {
2015-08-23 13:31:16 -04:00
sway_log(L_INFO, "[wlc] %s", str);
2015-08-23 13:08:04 -04:00
} else {
2015-08-23 13:31:16 -04:00
sway_log(L_DEBUG, "[wlc] %s", str);
2015-08-23 13:08:04 -04: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);
break;
}
free(line);
}
fclose(f);
}
int main(int argc, char **argv) {
2015-08-20 08:37:09 -04: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 11:01:26 -07:00
{0, 0, 0, 0}
2015-08-20 08:37:09 -04:00
};
2015-08-10 08:29:57 -04:00
setenv("WLC_DIM", "0", 0);
2015-08-20 08:37:09 -04:00
2015-08-23 13:08:04 -04:00
wlc_log_set_handler(wlc_log_handler);
detect_nvidia();
2015-08-17 18:20:56 -04:00
/* Changing code earlier than this point requires detailed review */
if (!wlc_init(&interface, argc, argv)) {
return 1;
}
2015-08-17 18:20:56 -04:00
2015-08-20 08:37:09 -04: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 21:13:53 -05: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);
#else
fprintf(stdout, "version not detected\n");
#endif
2015-08-20 08:37:09 -04:00
exit(0);
break;
case 'V': // verbose
verbose = 1;
break;
case 'p': ; // --get-socketpath
struct sockaddr_un *ipc_sockaddr = ipc_user_sockaddr();
fprintf(stdout, "%s\n", ipc_sockaddr->sun_path);
free(ipc_sockaddr);
exit(0);
2015-08-20 08:37:09 -04:00
break;
}
}
if (debug) {
init_log(L_DEBUG);
} else if (verbose || validate) {
init_log(L_INFO);
} else {
init_log(L_ERROR);
}
2015-09-02 09:42:27 -04: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 08:37:09 -04:00
if (validate) {
bool valid = load_config(config_path);
return valid ? 0 : 1;
}
2015-08-17 18:20:56 -04:00
init_layout();
2015-08-20 08:37:09 -04:00
if (!load_config(config_path)) {
sway_log(L_ERROR, "Error(s) loading config!");
}
2015-08-20 08:37:09 -04:00
if (config_path) {
free(config_path);
}
ipc_init();
2015-08-20 15:12:34 +02:00
if (!terminate_request) {
wlc_run();
}
ipc_terminate();
2015-08-04 21:02:46 -04:00
return 0;
}
2015-10-08 06:24:35 -04:00