diff options
author | Pavel Labath <pavelo@centrum.sk> | 2011-07-10 14:10:39 (GMT) |
---|---|---|
committer | Pavel Labath <pavelo@centrum.sk> | 2013-02-17 09:49:38 (GMT) |
commit | 3ec18bbdc84aa17c2cbbbcfcaa599a8e021b60de (patch) | |
tree | 6a8d3b8ed435e541dfcb07d34c0405982c0e46ab /src/Keys.cc | |
parent | 6a701da32042b61a23fdd95c7bdfa84c2fb20e3e (diff) | |
download | fluxbox_pavel-3ec18bbdc84aa17c2cbbbcfcaa599a8e021b60de.zip fluxbox_pavel-3ec18bbdc84aa17c2cbbbcfcaa599a8e021b60de.tar.bz2 |
Attach a modifiedSig handler to the session.keyFile resource
Diffstat (limited to 'src/Keys.cc')
-rw-r--r-- | src/Keys.cc | 21 |
1 files changed, 8 insertions, 13 deletions
diff --git a/src/Keys.cc b/src/Keys.cc index c4ad5ea..717a8fc 100644 --- a/src/Keys.cc +++ b/src/Keys.cc | |||
@@ -188,7 +188,11 @@ Keys::Keys(): | |||
188 | m_reloader(new FbTk::AutoReloadHelper()), | 188 | m_reloader(new FbTk::AutoReloadHelper()), |
189 | m_keylist(0), | 189 | m_keylist(0), |
190 | next_key(0), saved_keymode(0) { | 190 | next_key(0), saved_keymode(0) { |
191 | |||
191 | m_reloader->setReloadCmd(FbTk::RefCount<FbTk::Command<void> >(new FbTk::SimpleCommand<Keys>(*this, &Keys::reload))); | 192 | m_reloader->setReloadCmd(FbTk::RefCount<FbTk::Command<void> >(new FbTk::SimpleCommand<Keys>(*this, &Keys::reload))); |
193 | m_reloader->setMainFile(*Fluxbox::instance()->getKeysResource()); | ||
194 | join(Fluxbox::instance()->getKeysResource().modifiedSig(), | ||
195 | MemFun(*m_reloader, &FbTk::AutoReloadHelper::setMainFile)); | ||
192 | } | 196 | } |
193 | 197 | ||
194 | Keys::~Keys() { | 198 | Keys::~Keys() { |
@@ -282,8 +286,9 @@ void Keys::grabWindow(Window win) { | |||
282 | void Keys::reload() { | 286 | void Keys::reload() { |
283 | // an intentionally empty file will still have one root mapping | 287 | // an intentionally empty file will still have one root mapping |
284 | bool firstload = m_map.empty(); | 288 | bool firstload = m_map.empty(); |
289 | const std::string filename = FbTk::StringUtil::expandFilename(*Fluxbox::instance()->getKeysResource()); | ||
285 | 290 | ||
286 | if (m_filename.empty()) { | 291 | if (filename.empty()) { |
287 | if (firstload) | 292 | if (firstload) |
288 | loadDefaults(); | 293 | loadDefaults(); |
289 | return; | 294 | return; |
@@ -291,12 +296,12 @@ void Keys::reload() { | |||
291 | 296 | ||
292 | FbTk::App::instance()->sync(false); | 297 | FbTk::App::instance()->sync(false); |
293 | 298 | ||
294 | if (! FbTk::FileUtil::isRegularFile(m_filename.c_str())) { | 299 | if (! FbTk::FileUtil::isRegularFile(filename.c_str())) { |
295 | return; | 300 | return; |
296 | } | 301 | } |
297 | 302 | ||
298 | // open the file | 303 | // open the file |
299 | ifstream infile(m_filename.c_str()); | 304 | ifstream infile(filename.c_str()); |
300 | if (!infile) { | 305 | if (!infile) { |
301 | if (firstload) | 306 | if (firstload) |
302 | loadDefaults(); | 307 | loadDefaults(); |
@@ -609,16 +614,6 @@ void Keys::unregisterWindow(Window win) { | |||
609 | m_window_map.erase(win); | 614 | m_window_map.erase(win); |
610 | } | 615 | } |
611 | 616 | ||
612 | /** | ||
613 | deletes the tree and load configuration | ||
614 | returns true on success else false | ||
615 | */ | ||
616 | void Keys::reconfigure() { | ||
617 | m_filename = FbTk::StringUtil::expandFilename(Fluxbox::instance()->getKeysFilename()); | ||
618 | m_reloader->setMainFile(m_filename); | ||
619 | m_reloader->checkReload(); | ||
620 | } | ||
621 | |||
622 | void Keys::regrab() { | 617 | void Keys::regrab() { |
623 | setKeyMode(m_keylist); | 618 | setKeyMode(m_keylist); |
624 | } | 619 | } |