aboutsummaryrefslogtreecommitdiff
path: root/lib/actions
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2005-09-02 01:33:07 +0000
committerFelix Domke <tmbinc@elitedvb.net>2005-09-02 01:33:07 +0000
commit59988ec504f4129c2b1af7df4c3133036f5de92b (patch)
treee830a33edf157daf9ab8ae550d9a1cc68140af0e /lib/actions
parentb3056981450c5f45450afdfcf7e7671610611522 (diff)
downloadenigma2-59988ec504f4129c2b1af7df4c3133036f5de92b.tar.gz
enigma2-59988ec504f4129c2b1af7df4c3133036f5de92b.zip
- fix action return codes across c++ and python
Diffstat (limited to 'lib/actions')
-rw-r--r--lib/actions/action.cpp42
1 files changed, 29 insertions, 13 deletions
diff --git a/lib/actions/action.cpp b/lib/actions/action.cpp
index 494c252d..0fa52361 100644
--- a/lib/actions/action.cpp
+++ b/lib/actions/action.cpp
@@ -124,9 +124,18 @@ void eActionMap::bindKey(const std::string &device, int key, int flags, const st
m_python_keys.insert(std::pair<std::string,ePythonKeyBinding>(context, bind));
}
+struct call_entry
+{
+ PyObject *m_fnc, *m_arg;
+ eWidget *m_widget;
+ void *m_widget_arg;
+ call_entry(PyObject *fnc, PyObject *arg): m_fnc(fnc), m_arg(arg) { }
+ call_entry(eWidget *widget, void *arg): m_widget(widget), m_widget_arg(arg) { }
+};
+
void eActionMap::keyPressed(int device, int key, int flags)
{
- std::list<std::pair<PyObject*,PyObject*> > call_list;
+ std::list<call_entry> call_list;
/* iterate active contexts. */
for (std::multimap<int,eActionBinding>::const_iterator c(m_bindings.begin()); c != m_bindings.end();)
@@ -147,12 +156,9 @@ void eActionMap::keyPressed(int device, int key, int flags)
{
if (
// (k->second.m_device == m_device) &&
- (k->second.m_key == key) &&
- (k->second.m_flags & (1<<flags)))
- {
- if (i->second.m_widget->event(eWidget::evtAction, 0, (void*)k->second.m_action))
- return;
- }
+ (k->second.m_key == key) &&
+ (k->second.m_flags & (1<<flags)))
+ call_list.push_back(call_entry(i->second.m_widget, (void*)k->second.m_action));
}
} else
{
@@ -180,7 +186,7 @@ void eActionMap::keyPressed(int device, int key, int flags)
PyTuple_SetItem(pArgs, 1, PyString_FromString(k->second.m_action.c_str()));
++k;
Py_INCREF(i->second.m_fnc);
- call_list.push_back(std::pair<PyObject*,PyObject*>(i->second.m_fnc, pArgs));
+ call_list.push_back(call_entry(i->second.m_fnc, pArgs));
} else
++k;
}
@@ -190,16 +196,26 @@ void eActionMap::keyPressed(int device, int key, int flags)
PyTuple_SetItem(pArgs, 0, PyInt_FromLong(key));
PyTuple_SetItem(pArgs, 1, PyInt_FromLong(flags));
Py_INCREF(i->second.m_fnc);
- call_list.push_back(std::pair<PyObject*,PyObject*>(i->second.m_fnc, pArgs));
+ call_list.push_back(call_entry(i->second.m_fnc, pArgs));
}
}
}
- for (std::list<std::pair<PyObject*,PyObject*> >::iterator i(call_list.begin()); i != call_list.end(); ++i)
+ int res = 0;
+ /* we need to iterate over all to not loose a reference */
+ for (std::list<call_entry>::iterator i(call_list.begin()); i != call_list.end(); ++i)
{
- ePython::call(i->first, i->second);
- Py_DECREF(i->first);
- Py_DECREF(i->second);
+ if (i->m_fnc)
+ {
+ if (!res)
+ res = ePython::call(i->m_fnc, i->m_arg);
+ Py_DECREF(i->m_fnc);
+ Py_DECREF(i->m_arg);
+ } else if (i->m_widget)
+ {
+ if (!res)
+ res = i->m_widget->event(eWidget::evtAction, 0, (void*)i->m_widget_arg);
+ }
}
}