#include "focus.h"
#include "moveresize.h"
#include "frame.h"
+#include "keyboard.h"
+#include "mouse.h"
#include "extensions.h"
#include "grab.h"
#include "plugin.h"
static void signal_handler(const ObEvent *e, void *data);
static void parse_args(int argc, char **argv);
-static void exit_with_error(gchar *msg);
-
int main(int argc, char **argv)
{
struct sigaction action;
ob_display = XOpenDisplay(NULL);
if (ob_display == NULL)
- exit_with_error("Failed to open the display.");
+ ob_exit_with_error("Failed to open the display.");
if (fcntl(ConnectionNumber(ob_display), F_SETFD, 1) == -1)
- exit_with_error("Failed to set display as close-on-exec.");
+ ob_exit_with_error("Failed to set display as close-on-exec.");
- session_load(sm_save_file);
+ if (sm_save_file)
+ session_load(sm_save_file);
session_startup(argc, argv);
#ifdef USE_LIBSN
ob_rr_inst = RrInstanceNew(ob_display, ob_screen);
if (ob_rr_inst == NULL)
- exit_with_error("Failed to initialize the render library.");
+ ob_exit_with_error("Failed to initialize the render library.");
/* XXX fork self onto other screens */
/* load the theme specified in the rc file */
ob_rr_theme = RrThemeNew(ob_rr_inst, config_theme);
if (ob_rr_theme == NULL)
- exit_with_error("Unable to load a theme.");
+ ob_exit_with_error("Unable to load a theme.");
moveresize_startup();
screen_startup();
group_startup();
client_startup();
dock_startup();
+ keyboard_startup();
+ mouse_startup();
/* call startup for all the plugins */
plugin_startall();
client_unmanage_all();
plugin_shutdown(); /* calls all the plugins' shutdown functions */
+ mouse_shutdown();
+ keyboard_shutdown();
dock_shutdown();
client_shutdown();
group_shutdown();
}
}
-static void exit_with_error(gchar *msg)
+void ob_exit_with_error(gchar *msg)
{
g_critical(msg);
session_shutdown();