1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
|
#if defined(Hiro_Menu)
// LIJI: TODO: is there a more reasonable place to have this include?
#include "../../resource/icon.hpp"
auto mMenu::allocate() -> pObject* {
return new pMenu(*this);
}
auto mMenu::destruct() -> void {
for(auto& action : state.actions) action->destruct();
mAction::destruct();
}
//
auto mMenu::action(u32 position) const -> Action {
if(position < actionCount()) return state.actions[position];
return {};
}
auto mMenu::actionCount() const -> u32 {
return state.actions.size();
}
auto mMenu::actions() const -> vector<Action> {
vector<Action> actions;
for(auto& action : state.actions) actions.append(action);
return actions;
}
auto mMenu::append(sAction action) -> type& {
state.actions.append(action);
action->setParent(this, actionCount() - 1);
signal(append, action);
return *this;
}
auto mMenu::icon() const -> multiFactorImage {
return state.icon;
}
auto mMenu::remove(sAction action) -> type& {
signal(remove, action);
state.actions.remove(action->offset());
for(auto n : range(action->offset(), actionCount())) {
state.actions[n]->adjustOffset(-1);
}
action->setParent();
return *this;
}
auto mMenu::reset() -> type& {
while(state.actions) remove(state.actions.right());
return *this;
}
auto mMenu::setIcon(const multiFactorImage& icon, bool force) -> type& {
state.icon = icon;
signal(setIcon, icon, force);
return *this;
}
auto mMenu::setIconForFile(const string& filename) -> type& {
#if defined(PLATFORM_MACOS)
state.icon = {};
signal(setIconForFile, filename);
#else
if(directory::exists(filename)) setIcon(Icon::Emblem::Folder, true);
else setIcon(Icon::Emblem::File, true);
#endif
return *this;
}
auto mMenu::setParent(mObject* parent, s32 offset) -> type& {
for(auto& action : reverse(state.actions)) action->destruct();
mObject::setParent(parent, offset);
for(auto& action : state.actions) action->setParent(this, action->offset());
return *this;
}
auto mMenu::setText(const string& text) -> type& {
state.text = text;
signal(setText, text);
return *this;
}
auto mMenu::text() const -> string {
return state.text;
}
#endif
|