Files
Upsilon/escher/src/container.cpp
2019-07-19 15:06:25 +02:00

78 lines
1.6 KiB
C++

#include <escher/container.h>
#include <assert.h>
Container::Container() :
RunLoop()
{
}
// Initialize private static member
App * Container::s_activeApp = nullptr;
Container::~Container() {
if (s_activeApp) {
s_activeApp->~App();
}
}
bool Container::switchTo(App::Snapshot * snapshot) {
if (s_activeApp && snapshot == s_activeApp->snapshot()) {
return true;
}
if (s_activeApp && !s_activeApp->prepareForExit()) {
/* activeApp()->prepareForExit() returned false, which means that the app
* needs another event loop to prepare for being switched off. */
return false;
}
if (s_activeApp) {
s_activeApp->willBecomeInactive();
s_activeApp->snapshot()->pack(s_activeApp);
s_activeApp = nullptr;
}
if (snapshot) {
s_activeApp = snapshot->unpack(this);
}
if (s_activeApp) {
s_activeApp->didBecomeActive(window());
window()->redraw();
}
return true;
}
bool Container::dispatchEvent(Ion::Events::Event event) {
if (event == Ion::Events::TimerFire ) {
window()->redraw();
return true;
}
if (s_activeApp->processEvent(event)) {
window()->redraw();
return true;
}
return false;
}
void Container::run() {
window()->redraw();
RunLoop::run();
}
int Container::numberOfTimers() {
return s_activeApp->numberOfTimers() + numberOfContainerTimers();
}
Timer * Container::timerAtIndex(int i) {
if (i < s_activeApp->numberOfTimers()) {
return s_activeApp->timerAtIndex(i);
}
return containerTimerAtIndex(i-s_activeApp->numberOfTimers());
}
int Container::numberOfContainerTimers() {
return 0;
}
Timer * Container::containerTimerAtIndex(int i) {
assert(false);
return nullptr;
}