aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/FbCommands.cc68
-rw-r--r--src/FbCommands.hh23
-rw-r--r--src/MenuCreator.cc2
3 files changed, 92 insertions, 1 deletions
diff --git a/src/FbCommands.cc b/src/FbCommands.cc
index a3a0c27..9f3acdc 100644
--- a/src/FbCommands.cc
+++ b/src/FbCommands.cc
@@ -31,6 +31,7 @@
31#include "MenuCreator.hh" 31#include "MenuCreator.hh"
32 32
33#include "FbTk/I18n.hh" 33#include "FbTk/I18n.hh"
34#include "FbTk/Luamm.hh"
34#include "FbTk/Theme.hh" 35#include "FbTk/Theme.hh"
35#include "FbTk/Menu.hh" 36#include "FbTk/Menu.hh"
36#include "FbTk/CommandParser.hh" 37#include "FbTk/CommandParser.hh"
@@ -622,4 +623,71 @@ void ClientPatternTestCmd::execute() {
622} 623}
623 624
624 625
626REGISTER_UNTRUSTED_COMMAND_WITH_ARGS(lua, LuaCmd, void);
627
628namespace {
629 const char LuaCmds[] = "FbCommands::LuaCmd";
630}
631
632LuaCmd::LuaCmd(const std::string &chunk) {
633 lua::state &l = Fluxbox::instance()->lua();
634 l.checkstack(1);
635 l.loadstring(chunk);
636 init(l);
637}
638
639LuaCmd::LuaCmd(lua::state &l) {
640 lua::stack_sentry s(l, -1);
641 if(l.isstring(-1)) {
642 const std::string &str = l.tostring(-1);
643 l.pop();
644 l.loadstring(str);
645 }
646 init(l);
647}
648
649void LuaCmd::init(lua::state &l) {
650 lua::stack_sentry s(l, -1);
651 l.checkstack(2);
652
653 l.rawgetfield(lua::REGISTRYINDEX, LuaCmds); {
654 if(l.isnil(-1)) {
655 l.pop();
656 l.newtable();
657
658 l.pushvalue(-1);
659 l.rawsetfield(lua::REGISTRYINDEX, LuaCmds);
660 }
661
662 l.pushvalue(-2);
663 m_ref = l.ref(-2);
664 } l.pop();
665
666 l.pop();
667}
668
669LuaCmd::~LuaCmd() {
670 lua::state &l = Fluxbox::instance()->lua();
671 l.checkstack(1);
672 lua::stack_sentry s(l);
673
674 l.rawgetfield(lua::REGISTRYINDEX, LuaCmds); {
675 l.unref(-1, m_ref);
676 } l.pop();
677}
678
679void LuaCmd::execute() {
680 lua::state &l = Fluxbox::instance()->lua();
681 l.checkstack(1);
682 lua::stack_sentry s(l);
683
684 l.rawgetfield(lua::REGISTRYINDEX, LuaCmds); {
685 assert(l.istable(-1));
686
687 l.rawgeti(-1, m_ref); {
688 assert(! l.isnil(-1));
689 } l.call(0, 0);
690 } l.pop();
691}
692
625} // end namespace FbCommands 693} // end namespace FbCommands
diff --git a/src/FbCommands.hh b/src/FbCommands.hh
index d9639ad..bd377f5 100644
--- a/src/FbCommands.hh
+++ b/src/FbCommands.hh
@@ -32,6 +32,10 @@
32#include "ClientPattern.hh" 32#include "ClientPattern.hh"
33#include "FocusableList.hh" 33#include "FocusableList.hh"
34 34
35namespace lua {
36class state;
37}
38
35namespace FbCommands { 39namespace FbCommands {
36 40
37/// executes a system command 41/// executes a system command
@@ -218,7 +222,6 @@ private:
218 Destination m_dest; 222 Destination m_dest;
219}; 223};
220 224
221
222/// test client pattern 225/// test client pattern
223class ClientPatternTestCmd: public FbTk::Command<void> { 226class ClientPatternTestCmd: public FbTk::Command<void> {
224public: 227public:
@@ -228,6 +231,24 @@ private:
228 std::string m_args; 231 std::string m_args;
229}; 232};
230 233
234/// Command that runs a lua function
235class LuaCmd: public FbTk::Command<void> {
236public:
237 /// parses the string as a lua chunk
238 LuaCmd(const std::string &chunk);
239
240 /// expect the function to be on the lua stack (as a function or a string)
241 LuaCmd(lua::state &l);
242
243 ~LuaCmd();
244
245 void execute();
246private:
247 int m_ref;
248
249 void init(lua::state &l);
250};
251
231} // end namespace FbCommands 252} // end namespace FbCommands
232 253
233#endif // FBCOMMANDS_HH 254#endif // FBCOMMANDS_HH
diff --git a/src/MenuCreator.cc b/src/MenuCreator.cc
index 46f233d..3b7667a 100644
--- a/src/MenuCreator.cc
+++ b/src/MenuCreator.cc
@@ -236,6 +236,7 @@ createMenu_(FbTk::Menu &inject_into, lua::state &l, FbTk::StringConvertor &conv,
236void 236void
237insertMenuItem(lua::state &l, FbTk::Menu &menu, FbTk::StringConvertor &parent_conv, 237insertMenuItem(lua::state &l, FbTk::Menu &menu, FbTk::StringConvertor &parent_conv,
238 FbTk::AutoReloadHelper *reloader) { 238 FbTk::AutoReloadHelper *reloader) {
239 _FB_USES_NLS;
239 lua::stack_sentry s(l, -1); 240 lua::stack_sentry s(l, -1);
240 l.checkstack(1); 241 l.checkstack(1);
241 242
@@ -351,6 +352,7 @@ MenuCreator::createMenu(FbTk::Menu &inject_into, lua::state &l, FbTk::AutoReload
351 lua::stack_sentry s(l, -1); 352 lua::stack_sentry s(l, -1);
352 353
353 if(l.type(-1) != lua::TTABLE) { 354 if(l.type(-1) != lua::TTABLE) {
355 _FB_USES_NLS;
354 cerr << _FB_CONSOLETEXT(Menu, MenuNotTable, "Warning: Menu is not a lua table", 356 cerr << _FB_CONSOLETEXT(Menu, MenuNotTable, "Warning: Menu is not a lua table",
355 "Menu is not a lua table") << endl; 357 "Menu is not a lua table") << endl;
356 return; 358 return;