123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- #define _GNU_SOURCE
- #include "config.h"
- #include "daemonize.h"
- #include "dbus_messaging.h"
- #include "gamemode.h"
- #include "gamemode_client.h"
- #include "logging.h"
- #include <signal.h>
- #include <stdlib.h>
- #include <string.h>
- #include <systemd/sd-daemon.h>
- #include <unistd.h>
- #define USAGE_TEXT \
- "Usage: %s [-d] [-l] [-r] [-t] [-h] [-v]\n\n" \
- " -d daemonize self after launch\n" \
- " -l log to syslog\n" \
- " -r request gamemode and pause\n" \
- " -t run tests\n" \
- " -h print this help\n" \
- " -v print version\n" \
- "\n" \
- "See man page for more information.\n"
- #define VERSION_TEXT "gamemode version: v" GAMEMODE_VERSION "\n"
- static void sigint_handler(__attribute__((unused)) int signo)
- {
- LOG_MSG("Quitting by request...\n");
- sd_notify(0, "STATUS=GameMode is quitting by request...\n");
-
- game_mode_context_destroy(game_mode_context_instance());
- _Exit(EXIT_SUCCESS);
- }
- static void sigint_handler_noexit(__attribute__((unused)) int signo)
- {
- LOG_MSG("Quitting by request...\n");
- }
- int main(int argc, char *argv[])
- {
- GameModeContext *context = NULL;
-
- bool daemon = false;
- bool use_syslog = false;
- int opt = 0;
- int status;
- while ((opt = getopt(argc, argv, "dlsrtvh")) != -1) {
- switch (opt) {
- case 'd':
- daemon = true;
- break;
- case 'l':
- use_syslog = true;
- break;
- case 's': {
- if ((status = gamemode_query_status()) < 0) {
- LOG_ERROR("gamemode status request failed: %s\n", gamemode_error_string());
- exit(EXIT_FAILURE);
- } else if (status > 0) {
- LOG_MSG("gamemode is active\n");
- } else {
- LOG_MSG("gamemode is inactive\n");
- }
- exit(EXIT_SUCCESS);
- break;
- }
- case 'r':
- if (gamemode_request_start() < 0) {
- LOG_ERROR("gamemode request failed: %s\n", gamemode_error_string());
- exit(EXIT_FAILURE);
- }
- if ((status = gamemode_query_status()) == 2) {
- LOG_MSG("gamemode request succeeded and is active\n");
- } else if (status == 1) {
- LOG_ERROR("gamemode request succeeded and is active but registration failed\n");
- exit(EXIT_FAILURE);
- } else {
- LOG_ERROR("gamemode request succeeded but is not active\n");
- exit(EXIT_FAILURE);
- }
-
- if (signal(SIGINT, sigint_handler_noexit) == SIG_ERR) {
- FATAL_ERRORNO("Could not catch SIGINT");
- }
- pause();
-
- if (gamemode_request_end() < 0) {
- LOG_ERROR("gamemode request failed: %s\n", gamemode_error_string());
- exit(EXIT_FAILURE);
- }
- exit(EXIT_SUCCESS);
- break;
- case 't':
- status = game_mode_run_client_tests();
- exit(status);
- break;
- case 'v':
- LOG_MSG(VERSION_TEXT);
- exit(EXIT_SUCCESS);
- break;
- case 'h':
- LOG_MSG(USAGE_TEXT, argv[0]);
- exit(EXIT_SUCCESS);
- break;
- default:
- fprintf(stderr, USAGE_TEXT, argv[0]);
- exit(EXIT_FAILURE);
- break;
- }
- }
-
- if (use_syslog) {
- set_use_syslog(argv[0]);
- }
-
- if (daemon) {
- daemonize(argv[0]);
- }
-
- LOG_MSG("v%s\n", GAMEMODE_VERSION);
-
- context = game_mode_context_instance();
- game_mode_context_init(context);
-
- if (signal(SIGINT, sigint_handler) == SIG_ERR) {
- FATAL_ERRORNO("Could not catch SIGINT");
- }
- if (signal(SIGTERM, sigint_handler) == SIG_ERR) {
- FATAL_ERRORNO("Could not catch SIGTERM");
- }
-
- game_mode_context_loop(context);
- game_mode_context_destroy(context);
-
- LOG_MSG("Quitting naturally...\n");
- sd_notify(0, "STATUS=GameMode is quitting naturally...\n");
- }
|