-// -*- mode: C++; indent-tabs-mode: nil; -*-
+// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
#ifdef HAVE_CONFIG_H
# include "../config.h"
#include "../version.h"
#include "openbox.hh"
+#include "client.hh"
#include "screen.hh"
+#include "actions.hh"
#include "otk/property.hh"
#include "otk/display.hh"
#include "otk/assassin.hh"
# include <sys/select.h>
#endif // HAVE_SYS_SELECT_H
+//#include <guile/gh.h>
+
+#include <Python.h>
+
+// The initializer in openbox_wrap.cc
+extern void init_openbox(void);
+
#include "gettext.h"
#define _(str) gettext(str)
}
namespace ob {
-Openbox *Openbox::instance = (Openbox *) 0;
+Openbox *Openbox::instance = (Openbox *) 0;
void Openbox::signalHandler(int signal)
_property = new otk::OBProperty();
- // set this class as the fallback event handler (for map events)
- setFallbackHandler(this);
+ _actions = new OBActions();
+
+ setMasterHandler(_actions); // set as the master event handler
// create the mouse cursors we'll use
_cursors.session = XCreateFontCursor(otk::OBDisplay::display, XC_left_ptr);
printf(_("No screens were found without a window manager. Exiting.\n"));
::exit(1);
}
+
+ /*
+ // make our guile interfaces exist
+ SWIG_init();
+ // run the guile of d3th
+ FILE *rcpyfd = fopen("/home/natas/.openbox/user.scm", "r");
+ if (!rcpyfd) {
+ printf("failed to load guile script /home/natas/.openbox/user.scm\n");
+ } else {
+ fclose(rcpyfd);
+ gh_load("/home/natas/.openbox/user.scm");
+ }
+ */
+
+ Py_SetProgramName(argv[0]);
+ Py_Initialize();
+ //initopenbox(); // initialize the static 'openbox' module
+ init_openbox();
+ FILE *rcpyfd = fopen("/home/natas/.openbox/user.py", "r");
+ if (!rcpyfd) {
+ printf("failed to load python file /home/natas/.openbox/user.py\n");
+ } else {
+ PyRun_SimpleFile(rcpyfd, "/home/natas/.openbox/user.py");
+ fclose(rcpyfd);
+ }
+
+
_state = State_Normal; // done starting
}
void Openbox::removeClient(Window window)
{
- ClientMap::iterator it = _clients.find(window);
- if (it != _clients.end())
- _clients.erase(it);
+ _clients.erase(window);
}
return (OBClient*) 0;
}
-
-void Openbox::mapRequestHandler(const XMapRequestEvent &e)
-{
-#ifdef DEBUG
- printf("MapRequest for 0x%lx\n", e.window);
-#endif // DEBUG
-
- otk::OtkEventHandler::mapRequestHandler(e);
-
- OBClient *client = findClient(e.window);
-
- if (client) {
- // XXX: uniconify and/or unshade the window
- } else {
- int screen = INT_MAX;
-
- for (int i = 0; i < ScreenCount(otk::OBDisplay::display); ++i)
- if (otk::OBDisplay::screenInfo(i)->getRootWindow() == e.parent) {
- screen = i;
- break;
- }
-
- if (screen >= ScreenCount(otk::OBDisplay::display)) {
- /*
- we got a map request for a window who's parent isn't root. this
- can happen in only one circumstance:
-
- a client window unmapped a managed window, and then remapped it
- somewhere between unmapping the client window and reparenting it
- to root.
-
- regardless of how it happens, we need to find the screen that
- the window is on
- */
- XWindowAttributes wattrib;
- if (! XGetWindowAttributes(otk::OBDisplay::display, e.window,
- &wattrib)) {
- // failed to get the window attributes, perhaps the window has
- // now been destroyed?
- return;
- }
-
- for (int i = 0; i < ScreenCount(otk::OBDisplay::display); ++i)
- if (otk::OBDisplay::screenInfo(i)->getRootWindow() == wattrib.root) {
- screen = i;
- break;
- }
- }
-
- assert(screen < static_cast<int>(_screens.size()));
- _screens[screen]->manageWindow(e.window);
- }
-}
-
}