mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
Class hierarchy: - InputEventHandler - TextInput - EditableField derives from InputEventHandler - LayoutField, TextField and ExpressioField derives from EditableField - TextArea and TextField derives from TextInput
79 lines
2.1 KiB
C++
79 lines
2.1 KiB
C++
#include <escher/responder.h>
|
|
#include <escher/app.h>
|
|
#include <escher/metric.h>
|
|
#include <assert.h>
|
|
|
|
Responder::Responder(Responder * parentResponder) :
|
|
m_parentResponder(parentResponder)
|
|
{
|
|
}
|
|
|
|
Responder * Responder::parentResponder() const {
|
|
return m_parentResponder;
|
|
}
|
|
|
|
void Responder::setParentResponder(Responder * responder) {
|
|
m_parentResponder = responder;
|
|
}
|
|
|
|
void Responder::didBecomeFirstResponder() {
|
|
}
|
|
|
|
void Responder::willResignFirstResponder() {
|
|
}
|
|
|
|
void Responder::didEnterResponderChain(Responder * previousFirstResponder) {
|
|
}
|
|
|
|
void Responder::willExitResponderChain(Responder * nextFirstResponder) {
|
|
}
|
|
|
|
Responder * Responder::commonAncestorWith(Responder * responder) {
|
|
if (responder == nullptr) {
|
|
return nullptr;
|
|
}
|
|
if (this == responder) {
|
|
return this;
|
|
}
|
|
Responder * rootResponder = this;
|
|
while (rootResponder->parentResponder() != responder && rootResponder->parentResponder() != nullptr) {
|
|
rootResponder = rootResponder->parentResponder();
|
|
}
|
|
if (rootResponder->parentResponder() == responder) {
|
|
return responder;
|
|
}
|
|
rootResponder = responder;
|
|
while (rootResponder->parentResponder() != this && rootResponder->parentResponder() != nullptr) {
|
|
rootResponder = rootResponder->parentResponder();
|
|
}
|
|
if (rootResponder->parentResponder() == this) {
|
|
return this;
|
|
}
|
|
Responder * r = nullptr;
|
|
if (parentResponder()) {
|
|
r = parentResponder()->commonAncestorWith(responder);
|
|
}
|
|
Responder * s = nullptr;
|
|
if (responder->parentResponder()) {
|
|
s = commonAncestorWith(responder->parentResponder());
|
|
}
|
|
if (r) {
|
|
return r;
|
|
}
|
|
return s;
|
|
}
|
|
|
|
/* We assume the app is the root parent. */
|
|
App * Responder::app() const {
|
|
const Responder * rootResponder = this;
|
|
while (rootResponder->parentResponder() != nullptr) {
|
|
rootResponder = rootResponder->parentResponder();
|
|
}
|
|
/* If we used RTTI we could use a dynamic_cast, which would be a lot more
|
|
* safe, as such:
|
|
* return dynamic_cast<App *>(rootResponder); */
|
|
App * result = (App *)rootResponder;
|
|
assert(result->m_magic == App::Magic); // Poor man's RTTI
|
|
return result;
|
|
}
|