X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fconfig.cc;h=5c6ddfe9107f651cfdaf57bb524332269bc97067;hb=fdabd3daf9c631f53408d82c9168705dc6a2832a;hp=e5ec74d49df7e2adeead2341db9f42cfabf6525d;hpb=0b466d7136f0dbfbd3cf82323aaf21a4b947f67a;p=chaz%2Fopenbox diff --git a/src/config.cc b/src/config.cc index e5ec74d4..5c6ddfe9 100644 --- a/src/config.cc +++ b/src/config.cc @@ -2,94 +2,60 @@ #include "config.h" -#include "config.hh" +/* + python_get_stringlist("DESKTOP_NAMES", &desktop_names); -extern "C" { -#include -} - -#include - -namespace ob { - -static PyObject *obdict = NULL; - -bool python_get_long(const char *name, long *value) -{ - PyObject *val = PyDict_GetItemString(obdict, const_cast(name)); - if (!(val && PyInt_Check(val))) return false; - - *value = PyInt_AsLong(val); - return true; -} - -bool python_get_string(const char *name, otk::ustring *value) -{ - PyObject *val = PyDict_GetItemString(obdict, const_cast(name)); - if (!(val && PyString_Check(val))) return false; + python_get_string("THEME", &theme); + // initialize the screen's style + otk::RenderStyle::setStyle(_screen, theme); + // draw the root window + otk::bexec("obsetroot " + otk::RenderStyle::style(_screen)->rootArgs(), + info->displayString()); - std::string temp(PyString_AsString(val), PyString_Size(val)); - *value = temp; - return true; -} -bool python_get_stringlist(const char *name, std::vector *value) -{ - PyObject *val = PyDict_GetItemString(obdict, const_cast(name)); - if (!(val && PyList_Check(val))) return false; + if (!python_get_string("TITLEBAR_LAYOUT", &titlebar_layout)) { + fprintf(stderr, _("Unable to load config.%s\n"), "TITLEBAR_LAYOUT"); + ::exit(1); + } - value->clear(); - - for (int i = 0, end = PyList_Size(val); i < end; ++i) { - PyObject *str = PyList_GetItem(val, i); - if (PyString_Check(str)) - value->push_back(PyString_AsString(str)); + if (!python_get_long("DOUBLE_CLICK_DELAY", &double_click_delay)) { + fprintf(stderr, _("Unable to load config.%s\n"), "DOUBLE_CLICK_DELAY"); + ::exit(1); + } + if (!python_get_long("DRAG_THRESHOLD", &drag_threshold)) { + fprintf(stderr, _("Unable to load config.%s\n"), "DRAG_THRESHOLD"); + ::exit(1); + } + if (!python_get_long("NUMBER_OF_DESKTOPS", (long*)&num_desktops)) { + fprintf(stderr, _("Unable to load config.%s\n"), "NUMBER_OF_DESKTOPS"); + ::exit(1); } - return true; + + // Set the net_desktop_names property + otk::Property::set(root, + otk::Property::atoms.net_desktop_names, + otk::Property::utf8, desktop_names); + // the above set() will cause screen::updateDesktopNames to fire right away + // so we have a list of desktop names + + XEvent ce; + ce.xclient.type = ClientMessage; + ce.xclient.message_type = otk::Property::atoms.net_number_of_desktops; + ce.xclient.display = **otk::display; + ce.xclient.window = root; + ce.xclient.format = 32; + ce.xclient.data.l[0] = num_desktops; + XSendEvent(**otk::display, root, False, + SubstructureNotifyMask | SubstructureRedirectMask, &ce); } -Config::Config() +Config::Config(int screen) + : _screen(screen) { - PyRun_SimpleString("import config;"); - // set up access to the python global variables - PyObject *obmodule = PyImport_AddModule("config"); - obdict = PyModule_GetDict(obmodule); - - std::vector names; - python_get_stringlist("DESKTOP_NAMES", &names); - - python_get_string("THEME", &theme); - - if (!python_get_string("TITLEBAR_LAYOUT", &titlebar_layout)) - titlebar_layout = "NTIMC"; - - if (!python_get_long("DOUBLE_CLICK_DELAY", &double_click_delay)) - double_click_delay = 300; - if (!python_get_long("DRAG_THRESHOLD", &drag_threshold)) - drag_threshold = 3; - if (!python_get_long("NUMBER_OF_DESKTOPS", (long*)&num_desktops)) - num_desktops = 1; - - otk::ustring s; - long w, h; - if (python_get_string("DEFAULT_ICON", &s) && s.bytes() > 2 && - python_get_long("DEFAULT_ICON_WIDTH", &w) && - python_get_long("DEFAULT_ICON_HEIGHT", &h) && - (unsigned)(w * h) == s.bytes() / sizeof(unsigned long)) { - default_icon = new unsigned long[s.bytes() / sizeof(unsigned long) + 2]; - default_icon[0] = w; - default_icon[1] = h; - memcpy(default_icon + 2, s.data(), s.bytes()); - } else { - default_icon = 0; - } - - icon_length = s.bytes(); } Config::~Config() { - if (default_icon) delete [] default_icon; } -} +*/