2015-06-18 10:48:53 +00:00
|
|
|
#define DeclareShared(Name) \
|
|
|
|
using type = Name; \
|
|
|
|
Name() : s##Name(new m##Name, [](auto p) { \
|
|
|
|
p->unbind(); \
|
|
|
|
delete p; \
|
|
|
|
}) { \
|
|
|
|
(*this)->bind(*this); \
|
|
|
|
} \
|
2015-06-20 05:44:05 +00:00
|
|
|
Name(const s##Name& source) : s##Name(source) { assert(source); } \
|
|
|
|
explicit operator bool() const { return self().operator bool(); } \
|
2015-06-18 10:48:53 +00:00
|
|
|
auto self() const -> m##Name& { return (m##Name&)operator*(); } \
|
|
|
|
|
|
|
|
#define DeclareSharedObject(Name) \
|
|
|
|
DeclareShared(Name) \
|
|
|
|
template<typename T, typename... P> Name(T* parent, P&&... p) : Name() { \
|
2015-06-20 05:44:05 +00:00
|
|
|
if(parent) (*parent)->append(*this, std::forward<P>(p)...); \
|
2015-06-18 10:48:53 +00:00
|
|
|
} \
|
|
|
|
auto enabled(bool recursive = false) const { return self().enabled(recursive); } \
|
|
|
|
auto focused() const { return self().focused(); } \
|
|
|
|
auto font(bool recursive = false) const { return self().font(recursive); } \
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto offset() const { return self().offset(); } \
|
|
|
|
auto parent() const { \
|
|
|
|
if(auto object = self().parent()) { \
|
|
|
|
if(auto instance = object->instance.acquire()) return Object(instance); \
|
|
|
|
} \
|
|
|
|
return Object(); \
|
|
|
|
} \
|
2015-11-14 00:52:51 +00:00
|
|
|
auto property(const string& name) const { return self().property(name); } \
|
2015-06-18 10:48:53 +00:00
|
|
|
auto remove() { return self().remove(), *this; } \
|
|
|
|
auto setEnabled(bool enabled = true) { return self().setEnabled(enabled), *this; } \
|
|
|
|
auto setFocused() { return self().setFocused(), *this; } \
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setFont(const Font& font = {}) { return self().setFont(font), *this; } \
|
2015-11-14 00:52:51 +00:00
|
|
|
auto setProperty(const string& name, const string& value = "") { return self().setProperty(name, value), *this; } \
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setVisible(bool visible = true) { return self().setVisible(visible), *this; } \
|
|
|
|
auto visible(bool recursive = false) const { return self().visible(recursive); } \
|
|
|
|
|
|
|
|
#define DeclareSharedAction(Name) \
|
|
|
|
DeclareSharedObject(Name) \
|
|
|
|
|
|
|
|
#define DeclareSharedSizable(Name) \
|
|
|
|
DeclareSharedObject(Name) \
|
|
|
|
auto geometry() const { return self().geometry(); } \
|
|
|
|
auto minimumSize() const { return self().minimumSize(); } \
|
|
|
|
auto setGeometry(Geometry geometry) { return self().setGeometry(geometry), *this; } \
|
|
|
|
|
|
|
|
#define DeclareSharedLayout(Name) \
|
|
|
|
DeclareSharedSizable(Name) \
|
|
|
|
auto append(sSizable sizable) { return self().append(sizable), *this; } \
|
|
|
|
auto remove(sSizable sizable) { return self().remove(sizable), *this; } \
|
|
|
|
auto reset() { return self().reset(), *this; } \
|
|
|
|
auto sizable(unsigned position) { return self().sizable(position); } \
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto sizableCount() const { return self().sizableCount(); } \
|
2015-06-18 10:48:53 +00:00
|
|
|
auto sizables() const { return self().sizables(); } \
|
|
|
|
|
|
|
|
#define DeclareSharedWidget(Name) \
|
|
|
|
DeclareSharedSizable(Name) \
|
|
|
|
auto doSize() const { return self().doSize(); } \
|
|
|
|
auto onSize(const function<void ()>& callback = {}) { return self().onSize(callback), *this; } \
|
|
|
|
|
|
|
|
#if defined(Hiro_Object)
|
|
|
|
struct Object : sObject {
|
|
|
|
DeclareSharedObject(Object)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mObject;
|
2015-11-16 08:38:05 +00:00
|
|
|
|
|
|
|
template<typename T> auto cast() -> T {
|
|
|
|
if(auto pointer = dynamic_cast<typename T::internalType*>(data())) {
|
|
|
|
if(auto shared = pointer->instance.acquire()) return T(shared);
|
|
|
|
}
|
|
|
|
return T();
|
|
|
|
}
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Group)
|
|
|
|
struct Group : sGroup {
|
|
|
|
DeclareShared(Group)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mGroup;
|
2015-06-18 10:48:53 +00:00
|
|
|
template<typename... P> Group(P&&... p) : Group() { _append(std::forward<P>(p)...); }
|
|
|
|
|
|
|
|
auto append(sObject object) -> type& { return self().append(object), *this; }
|
|
|
|
auto object(unsigned position) const { return self().object(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto objectCount() const { return self().objectCount(); }
|
2015-12-14 09:41:06 +00:00
|
|
|
//auto objects() const { return self().objects(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto remove(sObject object) -> type& { return self().remove(object), *this; }
|
|
|
|
|
2015-12-14 09:41:06 +00:00
|
|
|
template<typename T = Object> auto objects() const -> vector<T> {
|
|
|
|
vector<T> objects;
|
|
|
|
for(auto object : self().objects()) {
|
2016-05-02 09:57:04 +00:00
|
|
|
if(auto casted = object.cast<T>()) objects.append(casted);
|
2015-12-14 09:41:06 +00:00
|
|
|
}
|
|
|
|
return objects;
|
|
|
|
}
|
|
|
|
|
2015-06-18 10:48:53 +00:00
|
|
|
private:
|
|
|
|
auto _append() {}
|
|
|
|
template<typename T, typename... P> auto _append(T* object, P&&... p) {
|
|
|
|
append(*object);
|
|
|
|
_append(std::forward<P>(p)...);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Timer)
|
|
|
|
struct Timer : sTimer {
|
|
|
|
DeclareSharedObject(Timer)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mTimer;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto interval() const { return self().interval(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto setInterval(unsigned interval = 0) { return self().setInterval(interval), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Action)
|
|
|
|
struct Action : sAction {
|
|
|
|
DeclareSharedAction(Action)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mAction;
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Menu)
|
|
|
|
struct Menu : sMenu {
|
|
|
|
DeclareSharedAction(Menu)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mMenu;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto action(unsigned position) const { return self().action(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto actionCount() const { return self().actionCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto actions() const { return self().actions(); }
|
|
|
|
auto append(sAction action) { return self().append(action), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto remove(sAction action) { return self().remove(action), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_MenuSeparator)
|
|
|
|
struct MenuSeparator : sMenuSeparator {
|
|
|
|
DeclareSharedAction(MenuSeparator)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mMenuSeparator;
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_MenuItem)
|
|
|
|
struct MenuItem : sMenuItem {
|
|
|
|
DeclareSharedAction(MenuItem)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mMenuItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_MenuCheckItem)
|
|
|
|
struct MenuCheckItem : sMenuCheckItem {
|
|
|
|
DeclareSharedAction(MenuCheckItem)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mMenuCheckItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto doToggle() const { return self().doToggle(); }
|
|
|
|
auto onToggle(const function<void ()>& callback = {}) { return self().onToggle(callback), *this; }
|
|
|
|
auto setChecked(bool checked = true) { return self().setChecked(checked), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_MenuRadioItem)
|
|
|
|
struct MenuRadioItem : sMenuRadioItem {
|
|
|
|
DeclareSharedAction(MenuRadioItem)
|
2015-11-16 08:38:05 +00:00
|
|
|
using internalType = mMenuRadioItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto group() const { return self().group(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto setChecked() { return self().setChecked(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Sizable)
|
|
|
|
struct Sizable : sSizable {
|
|
|
|
DeclareSharedSizable(Sizable)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mSizable;
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Layout)
|
|
|
|
struct Layout : sLayout {
|
|
|
|
DeclareSharedLayout(Layout)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mLayout;
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Widget)
|
|
|
|
struct Widget : sWidget {
|
|
|
|
DeclareSharedWidget(Widget)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mWidget;
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Button)
|
|
|
|
struct Button : sButton {
|
|
|
|
DeclareSharedWidget(Button)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mButton;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto bordered() const { return self().bordered(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto orientation() const { return self().orientation(); }
|
|
|
|
auto setBordered(bool bordered = true) { return self().setBordered(bordered), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setOrientation(Orientation orientation = Orientation::Horizontal) { return self().setOrientation(orientation), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Canvas)
|
|
|
|
struct Canvas : sCanvas {
|
|
|
|
DeclareSharedWidget(Canvas)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mCanvas;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto color() const { return self().color(); }
|
|
|
|
auto data() { return self().data(); }
|
|
|
|
auto droppable() const { return self().droppable(); }
|
2016-07-01 11:58:12 +00:00
|
|
|
auto doDrop(string_vector names) { return self().doDrop(names); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doMouseLeave() const { return self().doMouseLeave(); }
|
|
|
|
auto doMouseMove(Position position) const { return self().doMouseMove(position); }
|
|
|
|
auto doMousePress(Mouse::Button button) const { return self().doMousePress(button); }
|
|
|
|
auto doMouseRelease(Mouse::Button button) const { return self().doMouseRelease(button); }
|
|
|
|
auto gradient() const { return self().gradient(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2016-07-01 11:58:12 +00:00
|
|
|
auto onDrop(const function<void (string_vector)>& callback = {}) { return self().onDrop(callback), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onMouseLeave(const function<void ()>& callback = {}) { return self().onMouseLeave(callback), *this; }
|
|
|
|
auto onMouseMove(const function<void (Position)>& callback = {}) { return self().onMouseMove(callback), *this; }
|
|
|
|
auto onMousePress(const function<void (Mouse::Button)>& callback = {}) { return self().onMousePress(callback), *this; }
|
|
|
|
auto onMouseRelease(const function<void (Mouse::Button)>& callback = {}) { return self().onMouseRelease(callback), *this; }
|
|
|
|
auto setColor(Color color) { return self().setColor(color), *this; }
|
|
|
|
auto setDroppable(bool droppable = true) { return self().setDroppable(droppable), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setGradient(Gradient gradient = {}) { return self().setGradient(gradient), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setSize(Size size = {}) { return self().setSize(size), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto update() { return self().update(), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_CheckButton)
|
|
|
|
struct CheckButton : sCheckButton {
|
|
|
|
DeclareSharedWidget(CheckButton)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mCheckButton;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto bordered() const { return self().bordered(); }
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto doToggle() const { return self().doToggle(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onToggle(const function<void ()>& callback = {}) { return self().onToggle(callback), *this; }
|
|
|
|
auto orientation() const { return self().orientation(); }
|
|
|
|
auto setBordered(bool bordered = true) { return self().setBordered(bordered), *this; }
|
|
|
|
auto setChecked(bool checked = true) { return self().setChecked(checked), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setOrientation(Orientation orientation = Orientation::Horizontal) { return self().setOrientation(orientation), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_CheckLabel)
|
|
|
|
struct CheckLabel : sCheckLabel {
|
|
|
|
DeclareSharedWidget(CheckLabel)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mCheckLabel;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto doToggle() const { return self().doToggle(); }
|
|
|
|
auto onToggle(const function<void ()>& callback = {}) { return self().onToggle(callback), *this; }
|
|
|
|
auto setChecked(bool checked = true) { return self().setChecked(checked), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_ComboButton)
|
|
|
|
struct ComboButtonItem : sComboButtonItem {
|
|
|
|
DeclareSharedObject(ComboButtonItem)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mComboButtonItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto selected() const { return self().selected(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setSelected() { return self().setSelected(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_ComboButton)
|
|
|
|
struct ComboButton : sComboButton {
|
|
|
|
DeclareSharedWidget(ComboButton)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mComboButton;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sComboButtonItem item) { return self().append(item), *this; }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto item(unsigned position) const { return self().item(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto itemCount() const { return self().itemCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto items() const { return self().items(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto remove(sComboButtonItem item) { return self().remove(item), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
|
|
|
auto setParent(mObject* parent = nullptr, signed offset = -1) { return self().setParent(parent, offset), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2016-05-16 09:51:12 +00:00
|
|
|
#if defined(Hiro_ComboEdit)
|
|
|
|
struct ComboEditItem : sComboEditItem {
|
|
|
|
DeclareSharedObject(ComboEditItem)
|
|
|
|
using internalType = mComboEditItem;
|
|
|
|
|
|
|
|
auto icon() const { return self().icon(); }
|
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_ComboEdit)
|
|
|
|
struct ComboEdit : sComboEdit {
|
|
|
|
DeclareSharedWidget(ComboEdit)
|
|
|
|
using internalType = mComboEdit;
|
|
|
|
|
|
|
|
auto append(sComboEditItem item) { return self().append(item), *this; }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
Update to v106r15 release.
byuu says:
Changelog:
- Super Game Boy: fixed loading of boot ROM
- hiro: added ComboEdit::setEditable(bool = true);
- tomoko: added new systems settings panel
Note!!: this release will not compile on Windows or macOS due to the
missing ComboEdit control! I'll try to merge in hex's implementation
for the Windows release here soon. macOS users will probably be out of
luck for a while, sorry.
The new systems panel is an idea I've been meaning to implement for
quite a while, but finally got around to starting on it. It's still
fairly unpolished, but the basic idea is there for Linux/BSD users to
try out now.
So imagine the Super Game Boy, BS-X Satellaview, Sufami Turbo, and the
associated BS Memory Pack-slotted SNES cartridges. To play any of those,
you needed to choose Nintendo→Super Famicom, and then select the
relevant cartridge, and then select any slotted cartridges to play with
it.
This was acceptable-ish, if not ideal. But now imagine in the future if
we wanted to support the Famicom Disk System, which is technically a
cartridge that plugs into the Famicom deck. Or the PC Engine CD, which
has one of three special HuCards that must be inserted (ignoring the
Turbo Duo where it's built-in—I'm going to be emulating the Super CD
as if you're using a stock PCE CD.) Or the Mega CD, where there are
probably a half dozen or more BIOS + hardware revisions that are
region-specific, which connect to an expansion port that is identical to
the cartridge port save for the Mega Drive seeing an I/O register bit
toggled here.
In all of these cases, it's going to be a real pain to have to choose
the 'BIOS' every time you want to play a game for them.
I can't distribute these BIOSes with higan due to copyright
restrictions, and trying to ship dummy folders for every possible
combination would become quite odious, and difficult for people to use
(compare to setting up the Game Boy Advance system BIOS.)
And so I've created the new systems settings panel. Here, you can manage
a list of systems that show up under the higan library menu (now renamed
to “System”), where each entry contains name, boot, and hidden
parameters.
The name parameter is what shows up in the system menu. You can call any
system higan emulates whatever you like here. Don't like “Super
Famicom”? Change it to “SNES”, then.
The boot parameter is a combo edit with a dropdown for all of the
systems higan emulates. If you choose one of these, then the higan
system menu option will work exactly like in previous releases, and
prompt you for a cartridge. But if you choose the browse button next to
the combo edit control, you'll get to pick any gamepak from the higan
library of your choosing.
So you could choose the SGB2 BIOS, and name the menu option “Super Game
Boy 2”, and when you choose the menu option, it will load the SFC core,
load the SGB2 BIOS, and only prompt you for the Game Boy game you wish
to play on it. The same deal goes for the FDS, PCE-CD, Mega CD, Mega
Drive Sonic & Knuckles lock-on cartridge, BS-X Satellaview, SD Gundam
G-Next, etc. Whatever you want to be in the menu, you can put in there
by pointing higan at the appropriate 'BIOS' gamepak to load.
Astute readers have probably already noticed, but you can technically
use this on non-slotted games as well, thus creating instant boot
options for your absolute favorite games, if you so wanted. Point it at
Zelda 3, and you can boot it instantly from the main menu, without any
need for file selection.
The hidden option is a way to hide the system entries from the system
menu. Primarily this would be a fast way for users to disable emulation
cores they never use in higan, without having to remove the options.
The major concession with this change is the collapsing of the
per-manufacturer submenus. What this means is you will now have all
twelve higan emulated systems in the main menu by default. This makes
the list rather long, but ... oh well. I may try to offer some form of
grouping in the future, but the grouping defeats the “list order =
display order” design, and I'm not willing to auto-sort the list. I want
people to be able to control the ordering of the system menu, and have
added (as yet non-functional) sorting arrows for that purpose. I also
don't have a combined tree+table view widget in higan to try to and
group things. But ... we'll see how things go in the future.
Another idea is to add a specialty load option that opens up the user's
Emulation library path, and lets you pick a gamepak for any system,
which would boot the same way as when you drop a gamepak onto the higan
executable or main window. So say you almost never play Wonderswan
games, this would be a way to play them without them cluttering your
system menu list.
The “import ROM files” option has been removed. All it does is launch
icarus directly. I would rather users become familiar with using icarus.
The “load ROM file” option remains.
Anyway, this is all still a work in progress, so please give it time and
don't overload me with too many suggested changes right now, thanks :3
2018-04-16 08:58:13 +00:00
|
|
|
auto editable() const { return self().editable(); }
|
2016-05-16 09:51:12 +00:00
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto item(uint position) const { return self().item(position); }
|
|
|
|
auto itemCount() const { return self().itemCount(); }
|
|
|
|
auto items() const { return self().items(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto remove(sComboEditItem item) { return self().remove(item), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
Update to v106r15 release.
byuu says:
Changelog:
- Super Game Boy: fixed loading of boot ROM
- hiro: added ComboEdit::setEditable(bool = true);
- tomoko: added new systems settings panel
Note!!: this release will not compile on Windows or macOS due to the
missing ComboEdit control! I'll try to merge in hex's implementation
for the Windows release here soon. macOS users will probably be out of
luck for a while, sorry.
The new systems panel is an idea I've been meaning to implement for
quite a while, but finally got around to starting on it. It's still
fairly unpolished, but the basic idea is there for Linux/BSD users to
try out now.
So imagine the Super Game Boy, BS-X Satellaview, Sufami Turbo, and the
associated BS Memory Pack-slotted SNES cartridges. To play any of those,
you needed to choose Nintendo→Super Famicom, and then select the
relevant cartridge, and then select any slotted cartridges to play with
it.
This was acceptable-ish, if not ideal. But now imagine in the future if
we wanted to support the Famicom Disk System, which is technically a
cartridge that plugs into the Famicom deck. Or the PC Engine CD, which
has one of three special HuCards that must be inserted (ignoring the
Turbo Duo where it's built-in—I'm going to be emulating the Super CD
as if you're using a stock PCE CD.) Or the Mega CD, where there are
probably a half dozen or more BIOS + hardware revisions that are
region-specific, which connect to an expansion port that is identical to
the cartridge port save for the Mega Drive seeing an I/O register bit
toggled here.
In all of these cases, it's going to be a real pain to have to choose
the 'BIOS' every time you want to play a game for them.
I can't distribute these BIOSes with higan due to copyright
restrictions, and trying to ship dummy folders for every possible
combination would become quite odious, and difficult for people to use
(compare to setting up the Game Boy Advance system BIOS.)
And so I've created the new systems settings panel. Here, you can manage
a list of systems that show up under the higan library menu (now renamed
to “System”), where each entry contains name, boot, and hidden
parameters.
The name parameter is what shows up in the system menu. You can call any
system higan emulates whatever you like here. Don't like “Super
Famicom”? Change it to “SNES”, then.
The boot parameter is a combo edit with a dropdown for all of the
systems higan emulates. If you choose one of these, then the higan
system menu option will work exactly like in previous releases, and
prompt you for a cartridge. But if you choose the browse button next to
the combo edit control, you'll get to pick any gamepak from the higan
library of your choosing.
So you could choose the SGB2 BIOS, and name the menu option “Super Game
Boy 2”, and when you choose the menu option, it will load the SFC core,
load the SGB2 BIOS, and only prompt you for the Game Boy game you wish
to play on it. The same deal goes for the FDS, PCE-CD, Mega CD, Mega
Drive Sonic & Knuckles lock-on cartridge, BS-X Satellaview, SD Gundam
G-Next, etc. Whatever you want to be in the menu, you can put in there
by pointing higan at the appropriate 'BIOS' gamepak to load.
Astute readers have probably already noticed, but you can technically
use this on non-slotted games as well, thus creating instant boot
options for your absolute favorite games, if you so wanted. Point it at
Zelda 3, and you can boot it instantly from the main menu, without any
need for file selection.
The hidden option is a way to hide the system entries from the system
menu. Primarily this would be a fast way for users to disable emulation
cores they never use in higan, without having to remove the options.
The major concession with this change is the collapsing of the
per-manufacturer submenus. What this means is you will now have all
twelve higan emulated systems in the main menu by default. This makes
the list rather long, but ... oh well. I may try to offer some form of
grouping in the future, but the grouping defeats the “list order =
display order” design, and I'm not willing to auto-sort the list. I want
people to be able to control the ordering of the system menu, and have
added (as yet non-functional) sorting arrows for that purpose. I also
don't have a combined tree+table view widget in higan to try to and
group things. But ... we'll see how things go in the future.
Another idea is to add a specialty load option that opens up the user's
Emulation library path, and lets you pick a gamepak for any system,
which would boot the same way as when you drop a gamepak onto the higan
executable or main window. So say you almost never play Wonderswan
games, this would be a way to play them without them cluttering your
system menu list.
The “import ROM files” option has been removed. All it does is launch
icarus directly. I would rather users become familiar with using icarus.
The “load ROM file” option remains.
Anyway, this is all still a work in progress, so please give it time and
don't overload me with too many suggested changes right now, thanks :3
2018-04-16 08:58:13 +00:00
|
|
|
auto setEditable(bool editable = true) { return self().setEditable(editable), *this; }
|
2016-05-16 09:51:12 +00:00
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2015-06-18 10:48:53 +00:00
|
|
|
#if defined(Hiro_Console)
|
|
|
|
struct Console : sConsole {
|
|
|
|
DeclareSharedWidget(Console)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mConsole;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto doActivate(string command) const { return self().doActivate(command); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto onActivate(const function<void (string)>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto print(const string& text) { return self().print(text), *this; }
|
|
|
|
auto prompt() const { return self().prompt(); }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setPrompt(const string& prompt = "") { return self().setPrompt(prompt), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Frame)
|
|
|
|
struct Frame : sFrame {
|
|
|
|
DeclareSharedWidget(Frame)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mFrame;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sLayout layout) { return self().append(layout), *this; }
|
|
|
|
auto layout() const { return self().layout(); }
|
|
|
|
auto remove(sLayout layout) { return self().remove(layout), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_HexEdit)
|
|
|
|
struct HexEdit : sHexEdit {
|
|
|
|
DeclareSharedWidget(HexEdit)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mHexEdit;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto address() const { return self().address(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto columns() const { return self().columns(); }
|
|
|
|
auto doRead(unsigned offset) const { return self().doRead(offset); }
|
|
|
|
auto doWrite(unsigned offset, uint8_t data) const { return self().doWrite(offset, data); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto length() const { return self().length(); }
|
|
|
|
auto onRead(const function<uint8_t (unsigned)>& callback = {}) { return self().onRead(callback), *this; }
|
|
|
|
auto onWrite(const function<void (unsigned, uint8_t)>& callback = {}) { return self().onWrite(callback), *this; }
|
|
|
|
auto rows() const { return self().rows(); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto setAddress(unsigned address) { return self().setAddress(address), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setColumns(unsigned columns = 16) { return self().setColumns(columns), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setLength(unsigned length) { return self().setLength(length), *this; }
|
|
|
|
auto setRows(unsigned rows = 16) { return self().setRows(rows), *this; }
|
|
|
|
auto update() { return self().update(), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2015-08-21 10:56:39 +00:00
|
|
|
#if defined(Hiro_HorizontalScrollBar)
|
|
|
|
struct HorizontalScrollBar : sHorizontalScrollBar {
|
|
|
|
DeclareSharedWidget(HorizontalScrollBar)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mHorizontalScrollBar;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto length() const { return self().length(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto position() const { return self().position(); }
|
|
|
|
auto setLength(unsigned length = 101) { return self().setLength(length), *this; }
|
|
|
|
auto setPosition(unsigned position = 0) { return self().setPosition(position), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_HorizontalSlider)
|
|
|
|
struct HorizontalSlider : sHorizontalSlider {
|
|
|
|
DeclareSharedWidget(HorizontalSlider)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mHorizontalSlider;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto length() const { return self().length(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto position() const { return self().position(); }
|
|
|
|
auto setLength(unsigned length = 101) { return self().setLength(length), *this; }
|
|
|
|
auto setPosition(unsigned position = 0) { return self().setPosition(position), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_IconView)
|
|
|
|
struct IconViewItem : sIconViewItem {
|
|
|
|
DeclareSharedObject(IconViewItem)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mIconViewItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto selected() const { return self().selected(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setSelected(bool selected = true) { return self().setSelected(selected), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_IconView)
|
|
|
|
struct IconView : sIconView {
|
|
|
|
DeclareSharedWidget(IconView)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mIconView;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sIconViewItem item) { return self().append(item), *this; }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto batchable() const { return self().batchable(); }
|
|
|
|
auto batched() const { return self().batched(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto doContext() const { return self().doContext(); }
|
|
|
|
auto flow() const { return self().flow(); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto item(unsigned position) const { return self().item(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto itemCount() const { return self().itemCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto items() const { return self().items(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onContext(const function<void ()>& callback = {}) { return self().onContext(callback), *this; }
|
|
|
|
auto orientation() const { return self().orientation(); }
|
|
|
|
auto remove(sIconViewItem item) { return self().remove(item), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setBatchable(bool batchable = true) { return self().setBatchable(batchable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setFlow(Orientation orientation = Orientation::Vertical) { return self().setFlow(orientation), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setOrientation(Orientation orientation = Orientation::Horizontal) { return self().setOrientation(orientation), *this; }
|
|
|
|
auto setSelected(const vector<signed>& selections) { return self().setSelected(selections), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Label)
|
|
|
|
struct Label : sLabel {
|
|
|
|
DeclareSharedWidget(Label)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mLabel;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto alignment() const { return self().alignment(); }
|
|
|
|
auto setAlignment(Alignment alignment = {}) { return self().setAlignment(alignment), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_LineEdit)
|
|
|
|
struct LineEdit : sLineEdit {
|
|
|
|
DeclareSharedWidget(LineEdit)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mLineEdit;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto editable() const { return self().editable(); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setEditable(bool editable = true) { return self().setEditable(editable), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_ProgressBar)
|
|
|
|
struct ProgressBar : sProgressBar {
|
|
|
|
DeclareSharedWidget(ProgressBar)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mProgressBar;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto position() const { return self().position(); }
|
|
|
|
auto setPosition(unsigned position = 0) { return self().setPosition(position), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_RadioButton)
|
|
|
|
struct RadioButton : sRadioButton {
|
|
|
|
DeclareSharedWidget(RadioButton)
|
2015-11-16 08:38:05 +00:00
|
|
|
using internalType = mRadioButton;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto bordered() const { return self().bordered(); }
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto group() const { return self().group(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto orientation() const { return self().orientation(); }
|
|
|
|
auto setBordered(bool bordered = true) { return self().setBordered(bordered), *this; }
|
|
|
|
auto setChecked() { return self().setChecked(), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setOrientation(Orientation orientation = Orientation::Horizontal) { return self().setOrientation(orientation), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_RadioLabel)
|
|
|
|
struct RadioLabel : sRadioLabel {
|
|
|
|
DeclareSharedWidget(RadioLabel)
|
2015-11-16 08:38:05 +00:00
|
|
|
using internalType = mRadioLabel;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto group() const { return self().group(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto setChecked() { return self().setChecked(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_SourceEdit)
|
|
|
|
struct SourceEdit : sSourceEdit {
|
|
|
|
DeclareSharedWidget(SourceEdit)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mSourceEdit;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto cursor() const { return self().cursor(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto doMove() const { return self().doMove(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onMove(const function<void ()>& callback = {}) { return self().onMove(callback), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setCursor(Cursor cursor = {}) { return self().setCursor(cursor), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TabFrame)
|
|
|
|
struct TabFrameItem : sTabFrameItem {
|
|
|
|
DeclareSharedObject(TabFrameItem)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mTabFrameItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sLayout layout) { return self().append(layout), *this; }
|
|
|
|
auto closable() const { return self().closable(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto layout() const { return self().layout(); }
|
|
|
|
auto movable() const { return self().movable(); }
|
|
|
|
auto remove(sLayout layout) { return self().remove(layout), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
|
|
|
auto setClosable(bool closable = true) { return self().setClosable(closable), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setMovable(bool movable = true) { return self().setMovable(movable), *this; }
|
|
|
|
auto setSelected() { return self().setSelected(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TabFrame)
|
|
|
|
struct TabFrame : sTabFrame {
|
|
|
|
DeclareSharedWidget(TabFrame)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mTabFrame;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sTabFrameItem item) { return self().append(item), *this; }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto doClose(sTabFrameItem item) const { return self().doClose(item); }
|
|
|
|
auto doMove(sTabFrameItem from, sTabFrameItem to) const { return self().doMove(from, to); }
|
|
|
|
auto item(unsigned position) const { return self().item(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto itemCount() const { return self().itemCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto items() const { return self().items(); }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto navigation() const { return self().navigation(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onClose(const function<void (sTabFrameItem)>& callback = {}) { return self().onClose(callback), *this; }
|
|
|
|
auto onMove(const function<void (sTabFrameItem, sTabFrameItem)>& callback = {}) { return self().onMove(callback), *this; }
|
|
|
|
auto remove(sTabFrameItem item) { return self().remove(item), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setNavigation(Navigation navigation = Navigation::Top) { return self().setNavigation(navigation), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2016-05-04 10:07:13 +00:00
|
|
|
#if defined(Hiro_TableView)
|
|
|
|
struct TableViewColumn : sTableViewColumn {
|
|
|
|
DeclareSharedObject(TableViewColumn)
|
|
|
|
using internalType = mTableViewColumn;
|
|
|
|
|
|
|
|
auto active() const { return self().active(); }
|
|
|
|
auto alignment() const { return self().alignment(); }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto editable() const { return self().editable(); }
|
|
|
|
auto expandable() const { return self().expandable(); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto horizontalAlignment() const { return self().horizontalAlignment(); }
|
|
|
|
auto icon() const { return self().icon(); }
|
|
|
|
auto resizable() const { return self().resizable(); }
|
|
|
|
auto setActive() { return self().setActive(), *this; }
|
|
|
|
auto setAlignment(Alignment alignment = {}) { return self().setAlignment(alignment), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setEditable(bool editable = true) { return self().setEditable(editable), *this; }
|
|
|
|
auto setExpandable(bool expandable = true) { return self().setExpandable(expandable), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
Update to v104r13 release.
byuu says:
Changelog:
- nall/GNUmakefile: build=release changed to -O2, build=optimize is
now -O3
- hiro: added Monitor::dpi(uint index) → Position [returns logical
DPI for x, y]
- Position is a bad name, but dpi(monitor).(x,y)() make more sense
than .(width,height)()
- hiro: Position, Size, Geometry, Font changed from using signed int
to float
- hiro: Alignment changed from using double to float
- hiro: added skeleton (unused) Application::scale(), setScale()
functions
Errata:
- hiro/cocoa's Monitor::dpi() is untested. Probably will cause issues
with macOS' automatic scaling.
- hiro/gtk lacks a way to get both per-monitor and per-axis (x,y) DPI
scaling
- hiro/qt lacks a way to get per-monitor DPI scaling (Qt 5.x has this,
but I still use Qt 4.x)
- and just to get global DPI, hiro/qt's DPI retrieval has to use
undocumented functions ... fun
The goal with this WIP was basically to prepare hiro for potential
automatic scaling. It'll be extremely difficult, but I'm convinced that
it must be possible if macOS can do it.
By moving from signed integers to floats for coordinates, we can now
scale and unscale without losing precision. That of course isn't the
hard part, though. The hard part is where and how to do the scaling. In
the ideal application, hiro/core and hiro/extension will handle 100% of
this, and the per-platform hiro/(cocoa,gtk,qt,windows) will not be aware
of what's going on, but ... to even make that possible, things will need
to change in every per-platform core, eg the per-platform code will have
to call a core function to change geometry, which will know about the
scaling and unscale the values back down again.
Gonna be a lot of work, but ... it's a start.
2017-09-08 06:06:21 +00:00
|
|
|
auto setHorizontalAlignment(float alignment = 0.0) { return self().setHorizontalAlignment(alignment), *this; }
|
2016-05-04 10:07:13 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
|
|
|
auto setResizable(bool resizable = true) { return self().setResizable(resizable), *this; }
|
|
|
|
auto setSortable(bool sortable = true) { return self().setSortable(sortable), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
Update to v104r13 release.
byuu says:
Changelog:
- nall/GNUmakefile: build=release changed to -O2, build=optimize is
now -O3
- hiro: added Monitor::dpi(uint index) → Position [returns logical
DPI for x, y]
- Position is a bad name, but dpi(monitor).(x,y)() make more sense
than .(width,height)()
- hiro: Position, Size, Geometry, Font changed from using signed int
to float
- hiro: Alignment changed from using double to float
- hiro: added skeleton (unused) Application::scale(), setScale()
functions
Errata:
- hiro/cocoa's Monitor::dpi() is untested. Probably will cause issues
with macOS' automatic scaling.
- hiro/gtk lacks a way to get both per-monitor and per-axis (x,y) DPI
scaling
- hiro/qt lacks a way to get per-monitor DPI scaling (Qt 5.x has this,
but I still use Qt 4.x)
- and just to get global DPI, hiro/qt's DPI retrieval has to use
undocumented functions ... fun
The goal with this WIP was basically to prepare hiro for potential
automatic scaling. It'll be extremely difficult, but I'm convinced that
it must be possible if macOS can do it.
By moving from signed integers to floats for coordinates, we can now
scale and unscale without losing precision. That of course isn't the
hard part, though. The hard part is where and how to do the scaling. In
the ideal application, hiro/core and hiro/extension will handle 100% of
this, and the per-platform hiro/(cocoa,gtk,qt,windows) will not be aware
of what's going on, but ... to even make that possible, things will need
to change in every per-platform core, eg the per-platform code will have
to call a core function to change geometry, which will know about the
scaling and unscale the values back down again.
Gonna be a lot of work, but ... it's a start.
2017-09-08 06:06:21 +00:00
|
|
|
auto setVerticalAlignment(float alignment = 0.5) { return self().setVerticalAlignment(alignment), *this; }
|
|
|
|
auto setWidth(float width = 0) { return self().setWidth(width), *this; }
|
2016-05-04 10:07:13 +00:00
|
|
|
auto sortable() const { return self().sortable(); }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
auto verticalAlignment() const { return self().verticalAlignment(); }
|
|
|
|
auto width() const { return self().width(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TableView)
|
|
|
|
struct TableViewHeader : sTableViewHeader {
|
|
|
|
DeclareSharedObject(TableViewHeader)
|
|
|
|
using internalType = mTableViewHeader;
|
|
|
|
|
|
|
|
auto append(sTableViewColumn column) { return self().append(column), *this; }
|
|
|
|
auto column(unsigned position) const { return self().column(position); }
|
|
|
|
auto columnCount() const { return self().columnCount(); }
|
|
|
|
auto columns() const { return self().columns(); }
|
|
|
|
auto remove(sTableViewColumn column) { return self().remove(column), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TableView)
|
|
|
|
struct TableViewCell : sTableViewCell {
|
|
|
|
DeclareSharedObject(TableViewCell)
|
|
|
|
using internalType = mTableViewCell;
|
|
|
|
|
|
|
|
auto alignment() const { return self().alignment(); }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto checkable() const { return self().checkable(); }
|
|
|
|
auto checked() const { return self().checked(); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto icon() const { return self().icon(); }
|
|
|
|
auto setAlignment(Alignment alignment = {}) { return self().setAlignment(alignment), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setCheckable(bool checkable = true) const { return self().setCheckable(checkable), *this; }
|
|
|
|
auto setChecked(bool checked = true) const { return self().setChecked(checked), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TableView)
|
|
|
|
struct TableViewItem : sTableViewItem {
|
|
|
|
DeclareSharedObject(TableViewItem)
|
|
|
|
using internalType = mTableViewItem;
|
|
|
|
|
|
|
|
auto alignment() const { return self().alignment(); }
|
|
|
|
auto append(sTableViewCell cell) { return self().append(cell), *this; }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto cell(unsigned position) const { return self().cell(position); }
|
|
|
|
auto cellCount() const { return self().cellCount(); }
|
|
|
|
auto cells() const { return self().cells(); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto remove(sTableViewCell cell) { return self().remove(cell), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
|
|
|
auto setAlignment(Alignment alignment = {}) { return self().setAlignment(alignment), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setSelected(bool selected = true) { return self().setSelected(selected), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TableView)
|
|
|
|
struct TableView : sTableView {
|
|
|
|
DeclareSharedWidget(TableView)
|
|
|
|
using internalType = mTableView;
|
|
|
|
|
|
|
|
auto alignment() const { return self().alignment(); }
|
|
|
|
auto append(sTableViewHeader header) { return self().append(header), *this; }
|
|
|
|
auto append(sTableViewItem item) { return self().append(item), *this; }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto batchable() const { return self().batchable(); }
|
|
|
|
auto batched() const { return self().batched(); }
|
|
|
|
auto bordered() const { return self().bordered(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto doContext() const { return self().doContext(); }
|
|
|
|
auto doEdit(sTableViewCell cell) const { return self().doEdit(cell); }
|
|
|
|
auto doSort(sTableViewColumn column) const { return self().doSort(column); }
|
|
|
|
auto doToggle(sTableViewCell cell) const { return self().doToggle(cell); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto header() const { return self().header(); }
|
|
|
|
auto item(unsigned position) const { return self().item(position); }
|
|
|
|
auto itemCount() const { return self().itemCount(); }
|
|
|
|
auto items() const { return self().items(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onContext(const function<void ()>& callback = {}) { return self().onContext(callback), *this; }
|
|
|
|
auto onEdit(const function<void (TableViewCell)>& callback = {}) { return self().onEdit(callback), *this; }
|
|
|
|
auto onSort(const function<void (TableViewColumn)>& callback = {}) { return self().onSort(callback), *this; }
|
|
|
|
auto onToggle(const function<void (TableViewCell)>& callback = {}) { return self().onToggle(callback), *this; }
|
|
|
|
auto remove(sTableViewHeader header) { return self().remove(header), *this; }
|
|
|
|
auto remove(sTableViewItem item) { return self().remove(item), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto resizeColumns() { return self().resizeColumns(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
|
|
|
auto setAlignment(Alignment alignment = {}) { return self().setAlignment(alignment), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setBatchable(bool batchable = true) { return self().setBatchable(batchable), *this; }
|
|
|
|
auto setBordered(bool bordered = true) { return self().setBordered(bordered), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2015-06-18 10:48:53 +00:00
|
|
|
#if defined(Hiro_TextEdit)
|
|
|
|
struct TextEdit : sTextEdit {
|
|
|
|
DeclareSharedWidget(TextEdit)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mTextEdit;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto cursor() const { return self().cursor(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto doMove() const { return self().doMove(); }
|
|
|
|
auto editable() const { return self().editable(); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onMove(const function<void ()>& callback = {}) { return self().onMove(callback), *this; }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setCursor(Cursor cursor = {}) { return self().setCursor(cursor), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setEditable(bool editable = true) { return self().setEditable(editable), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto setWordWrap(bool wordWrap = true) { return self().setWordWrap(wordWrap), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
auto wordWrap() const { return self().wordWrap(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TreeView)
|
|
|
|
struct TreeViewItem : sTreeViewItem {
|
|
|
|
DeclareSharedObject(TreeViewItem)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mTreeViewItem;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sTreeViewItem item) { return self().append(item), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto checkable() const { return self().checkable(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto checked() const { return self().checked(); }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto icon() const { return self().icon(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto item(const string& path) const { return self().item(path); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto itemCount() const { return self().itemCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto items() const { return self().items(); }
|
|
|
|
auto path() const { return self().path(); }
|
|
|
|
auto remove(sTreeViewItem item) { return self().remove(item), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setCheckable(bool checkable = true) { return self().setCheckable(checkable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setChecked(bool checked = true) { return self().setChecked(checked), *this; }
|
Update to v094r43 release.
byuu says:
Updated to compile with all of the new hiro changes. My next step is to
write up hiro API documentation, and move the API from alpha (constantly
changing) to beta (rarely changing), in preparation for the first stable
release (backward-compatible changes only.)
Added "--fullscreen" command-line option. I like this over
a configuration file option. Lets you use the emulator in both modes
without having to modify the config file each time.
Also enhanced the command-line game loading. You can now use any of
these methods:
higan /path/to/game-folder.sfc
higan /path/to/game-folder.sfc/
higan /path/to/game-folder.sfc/program.rom
The idea is to support launchers that insist on loading files only.
Technically, the file can be any name (manifest.bml also works); the
only criteria is that the file actually exists and is a file, and not
a directory. This is a requirement to support the first version (a
directory lacking the trailing / identifier), because I don't want my
nall::string class to query the file system to determine if the string
is an actual existing file or directory for its pathname() / dirname()
functions.
Anyway, every game folder I've made so far has program.rom, and that's
very unlikely to change, so this should be fine.
Now, of course, if you drop a regular "game.sfc" file on the emulator,
it won't even try to load it, unless it's in a folder that ends in .fc,
.sfc, etc. In which case, it'll bail out immediately by being unable to
produce a manifest for what is obviously not really a game folder.
2015-08-30 02:08:26 +00:00
|
|
|
auto setExpanded(bool expanded = true) { return self().setExpanded(expanded), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
2016-01-07 08:14:33 +00:00
|
|
|
auto setIcon(const image& icon = {}) { return self().setIcon(icon), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setSelected() { return self().setSelected(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TreeView)
|
|
|
|
struct TreeView : sTreeView {
|
|
|
|
DeclareSharedWidget(TreeView)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mTreeView;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sTreeViewItem item) { return self().append(item), *this; }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
|
|
|
auto doActivate() const { return self().doActivate(); }
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto doContext() const { return self().doContext(); }
|
|
|
|
auto doToggle(sTreeViewItem item) const { return self().doToggle(item); }
|
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
|
|
|
auto item(const string& path) const { return self().item(path); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto itemCount() const { return self().itemCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto items() const { return self().items(); }
|
|
|
|
auto onActivate(const function<void ()>& callback = {}) { return self().onActivate(callback), *this; }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onContext(const function<void ()>& callback = {}) { return self().onContext(callback), *this; }
|
|
|
|
auto onToggle(const function<void (sTreeViewItem)>& callback = {}) { return self().onToggle(callback), *this; }
|
|
|
|
auto remove(sTreeViewItem item) { return self().remove(item), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto selected() const { return self().selected(); }
|
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2015-08-21 10:56:39 +00:00
|
|
|
#if defined(Hiro_VerticalScrollBar)
|
|
|
|
struct VerticalScrollBar : sVerticalScrollBar {
|
|
|
|
DeclareSharedWidget(VerticalScrollBar)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mVerticalScrollBar;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto length() const { return self().length(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto position() const { return self().position(); }
|
|
|
|
auto setLength(unsigned length = 101) { return self().setLength(length), *this; }
|
|
|
|
auto setPosition(unsigned position = 0) { return self().setPosition(position), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_VerticalSlider)
|
|
|
|
struct VerticalSlider : sVerticalSlider {
|
|
|
|
DeclareSharedWidget(VerticalSlider)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mVerticalSlider;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto doChange() const { return self().doChange(); }
|
|
|
|
auto length() const { return self().length(); }
|
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto position() const { return self().position(); }
|
|
|
|
auto setLength(unsigned length = 101) { return self().setLength(length), *this; }
|
|
|
|
auto setPosition(unsigned position = 0) { return self().setPosition(position), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Viewport)
|
|
|
|
struct Viewport : sViewport {
|
|
|
|
DeclareSharedWidget(Viewport)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mViewport;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
2016-07-01 11:58:12 +00:00
|
|
|
auto doDrop(string_vector names) const { return self().doDrop(names); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doMouseLeave() const { return self().doMouseLeave(); }
|
|
|
|
auto doMouseMove(Position position) const { return self().doMouseMove(position); }
|
|
|
|
auto doMousePress(Mouse::Button button) const { return self().doMousePress(button); }
|
|
|
|
auto doMouseRelease(Mouse::Button button) const { return self().doMouseRelease(button); }
|
|
|
|
auto droppable() const { return self().droppable(); }
|
|
|
|
auto handle() const { return self().handle(); }
|
2016-07-01 11:58:12 +00:00
|
|
|
auto onDrop(const function<void (string_vector)>& callback = {}) { return self().onDrop(callback), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onMouseLeave(const function<void ()>& callback = {}) { return self().onMouseLeave(callback), *this; }
|
|
|
|
auto onMouseMove(const function<void (Position)>& callback = {}) { return self().onMouseMove(callback), *this; }
|
|
|
|
auto onMousePress(const function<void (Mouse::Button)>& callback = {}) { return self().onMousePress(callback), *this; }
|
|
|
|
auto onMouseRelease(const function<void (Mouse::Button)>& callback = {}) { return self().onMouseRelease(callback), *this; }
|
|
|
|
auto setDroppable(bool droppable = true) { return self().setDroppable(droppable), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_StatusBar)
|
|
|
|
struct StatusBar : sStatusBar {
|
|
|
|
DeclareSharedObject(StatusBar)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mStatusBar;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_PopupMenu)
|
|
|
|
struct PopupMenu : sPopupMenu {
|
|
|
|
DeclareSharedObject(PopupMenu)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mPopupMenu;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto action(unsigned position) const { return self().action(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto actionCount() const { return self().actionCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto actions() const { return self().actions(); }
|
|
|
|
auto append(sAction action) { return self().append(action), *this; }
|
|
|
|
auto remove(sAction action) { return self().remove(action), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_MenuBar)
|
|
|
|
struct MenuBar : sMenuBar {
|
|
|
|
DeclareSharedObject(MenuBar)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mMenuBar;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sMenu menu) { return self().append(menu), *this; }
|
|
|
|
auto menu(unsigned position) const { return self().menu(position); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto menuCount() const { return self().menuCount(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto menus() const { return self().menus(); }
|
|
|
|
auto remove(sMenu menu) { return self().remove(menu), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Window)
|
|
|
|
struct Window : sWindow {
|
|
|
|
DeclareSharedObject(Window)
|
2015-12-14 09:41:06 +00:00
|
|
|
using internalType = mWindow;
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
auto append(sLayout layout) { return self().append(layout), *this; }
|
|
|
|
auto append(sMenuBar menuBar) { return self().append(menuBar), *this; }
|
|
|
|
auto append(sStatusBar statusBar) { return self().append(statusBar), *this; }
|
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
Update to v103r13 release.
byuu says:
Changelog:
- gb/interface: fix Game Boy Color extension to be "gbc" and not "gb"
[hex\_usr]
- ms/interface: move Master System hardware controls below controller
ports
- sfc/ppu: improve latching behavior of BGnHOFS registers (not
hardware verified) [AWJ]
- tomoko/input: rework port/device mapping to support non-sequential
ports and devices¹
- todo: should add move() to inputDevice.mappings.append and
inputPort.devices.append
- note: there's a weird GCC 4.9 bug with brace initialization of
InputEmulator; have to assign each field separately
- tomoko: all windows sans the main presentation window can be
dismissed with the escape key
- icarus: the single file selection dialog ("Load ROM Image...") can
be dismissed with the escape key
- tomoko: do not pause emulation when FocusLoss/Pause is set during
exclusive fullscreen mode
- hiro/(windows,gtk,qt): implemented Window::setDismissable() function
(missing from cocoa port, sorry)
- nall/string: fixed printing of largest possible negative numbers (eg
`INT_MIN`) [Sintendo]
- only took eight months! :D
¹: When I tried to move the Master System hardware port below the
controller ports, I ran into a world of pain.
The input settings list expects every item in the
`InputEmulator<InputPort<InputDevice<InputMapping>>>>` arrays to be
populated with valid results. But these would be sparsely populated
based on the port and device IDs from inside higan. And that is done so
that the Interface::inputPoll can have O(1) lookup of ports and devices.
This worked because all the port and device IDs were sequential (they
left no gaps in the maps upon creating the lists.)
Unfortunately by changing the expectation of port ID to how it appears
in the list, inputs would not poll correctly. By leaving them alone and
just moving Hardware to the third position, the Game Gear would be
missing port IDs of 0 and 1 (the controller ports of the Master System).
Even by trying to make separate MasterSystemHardware and
GameGearHardware ports, things still fractured when the devices were no
longer contigious.
I got pretty sick of this and just decided to give up on O(1)
port/device lookup, and moved to O(n) lookup. It only knocked the
framerate down by maybe one frame per second, enough to be in the margin
of error. Inputs aren't polled *that* often for loops that usually
terminate after 1-2 cycles to be too detrimental to performance.
So the new input system now allows non-sequential port and device IDs.
Remember that I killed input IDs a while back. There's never any reason
for those to need IDs ... it was easier to just order the inputs in the
order you want to see them in the user interface. So the input lookup is
still O(1). Only now, everything's safer and I return a
maybe<InputMapping&>, and won't crash out the program trying to use a
mapping that isn't found for some reason.
Errata: the escape key isn't working on the browser/message dialogs on
Windows, because of course nothing can ever just be easy and work for
me. If anyone else wouldn't mind looking into that, I'd greatly
appreciate it.
Having the `WM_KEYDOWN` test inside the main `Application_sharedProc`, it
seems to not respond to the escape key on modal dialogs. If I put the
`WM_KEYDOWN` test in the main window proc, then it doesn't seem to get
called for `VK_ESCAPE` at all, and doesn't get called period for modal
windows. So I'm at a loss and it's past 4AM here >_>
2017-07-12 08:24:27 +00:00
|
|
|
auto dismissable() const { return self().dismissable(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doClose() const { return self().doClose(); }
|
2016-07-01 11:58:12 +00:00
|
|
|
auto doDrop(string_vector names) const { return self().doDrop(names); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto doKeyPress(signed key) const { return self().doKeyPress(key); }
|
|
|
|
auto doKeyRelease(signed key) const { return self().doKeyRelease(key); }
|
|
|
|
auto doMove() const { return self().doMove(); }
|
|
|
|
auto doSize() const { return self().doSize(); }
|
|
|
|
auto droppable() const { return self().droppable(); }
|
|
|
|
auto frameGeometry() const { return self().frameGeometry(); }
|
|
|
|
auto fullScreen() const { return self().fullScreen(); }
|
|
|
|
auto geometry() const { return self().geometry(); }
|
|
|
|
auto layout() const { return self().layout(); }
|
|
|
|
auto menuBar() const { return self().menuBar(); }
|
|
|
|
auto modal() const { return self().modal(); }
|
|
|
|
auto onClose(const function<void ()>& callback = {}) { return self().onClose(callback), *this; }
|
2016-07-01 11:58:12 +00:00
|
|
|
auto onDrop(const function<void (string_vector)>& callback = {}) { return self().onDrop(callback), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onKeyPress(const function<void (signed)>& callback = {}) { return self().onKeyPress(callback), *this; }
|
|
|
|
auto onKeyRelease(const function<void (signed)>& callback = {}) { return self().onKeyRelease(callback), *this; }
|
|
|
|
auto onMove(const function<void ()>& callback = {}) { return self().onMove(callback), *this; }
|
|
|
|
auto onSize(const function<void ()>& callback = {}) { return self().onSize(callback), *this; }
|
|
|
|
auto remove(sLayout layout) { return self().remove(layout), *this; }
|
|
|
|
auto remove(sMenuBar menuBar) { return self().remove(menuBar), *this; }
|
|
|
|
auto remove(sStatusBar statusBar) { return self().remove(statusBar), *this; }
|
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto resizable() const { return self().resizable(); }
|
Update to v094r40 release.
byuu says:
Changelog:
- updated to newest hiro API
- SFC performance profile builds once again
- hiro: Qt port completed
Errata 1: the hiro/Qt target won't run tomoko just yet. Starts by
crashing inside InputSettings because hiro/Qt isn't forcefully selecting
the first item added to a ComboButton just yet. Even with a monkey patch
to get around that, the UI is incredibly unstable. Lots of geometry
calculation bugs, and a crash when you try and access certain folders in
the browser dialog. Lots of work left to be done there, sadly.
Errata 2: the hiro/Windows port has black backgrounds on all ListView
items. It's because I need to test for unassigned colors and grab the
default Windows brush colors in those cases.
Note: alternating row colors on multi-column ListView widgets is gone
now. Not a bug. May add it back later, but I'm not sure. It doesn't
interact nicely with per-cell background colors.
Things left to do:
First, I have to fix the Windows and Qt target bugs.
Next, I need to go through and revise the hiro API even more (nothing
too major.)
Next, I need to update icarus to use the new hiro API, and add support
for the SFC games database.
Next, I have to rewrite my TSV->BML cheat code tool.
Next, I need to post a final WIP of higan+icarus publicly and wait a few
days.
Next, I need to fix any bugs reported from the final WIP that I can.
Finally, I should be able to release v095.
2015-08-18 10:18:00 +00:00
|
|
|
auto setAlignment(Alignment alignment) { return self().setAlignment(alignment), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setCentered(sWindow parent = {}) { return self().setCentered(parent), *this; }
|
Update to v103r13 release.
byuu says:
Changelog:
- gb/interface: fix Game Boy Color extension to be "gbc" and not "gb"
[hex\_usr]
- ms/interface: move Master System hardware controls below controller
ports
- sfc/ppu: improve latching behavior of BGnHOFS registers (not
hardware verified) [AWJ]
- tomoko/input: rework port/device mapping to support non-sequential
ports and devices¹
- todo: should add move() to inputDevice.mappings.append and
inputPort.devices.append
- note: there's a weird GCC 4.9 bug with brace initialization of
InputEmulator; have to assign each field separately
- tomoko: all windows sans the main presentation window can be
dismissed with the escape key
- icarus: the single file selection dialog ("Load ROM Image...") can
be dismissed with the escape key
- tomoko: do not pause emulation when FocusLoss/Pause is set during
exclusive fullscreen mode
- hiro/(windows,gtk,qt): implemented Window::setDismissable() function
(missing from cocoa port, sorry)
- nall/string: fixed printing of largest possible negative numbers (eg
`INT_MIN`) [Sintendo]
- only took eight months! :D
¹: When I tried to move the Master System hardware port below the
controller ports, I ran into a world of pain.
The input settings list expects every item in the
`InputEmulator<InputPort<InputDevice<InputMapping>>>>` arrays to be
populated with valid results. But these would be sparsely populated
based on the port and device IDs from inside higan. And that is done so
that the Interface::inputPoll can have O(1) lookup of ports and devices.
This worked because all the port and device IDs were sequential (they
left no gaps in the maps upon creating the lists.)
Unfortunately by changing the expectation of port ID to how it appears
in the list, inputs would not poll correctly. By leaving them alone and
just moving Hardware to the third position, the Game Gear would be
missing port IDs of 0 and 1 (the controller ports of the Master System).
Even by trying to make separate MasterSystemHardware and
GameGearHardware ports, things still fractured when the devices were no
longer contigious.
I got pretty sick of this and just decided to give up on O(1)
port/device lookup, and moved to O(n) lookup. It only knocked the
framerate down by maybe one frame per second, enough to be in the margin
of error. Inputs aren't polled *that* often for loops that usually
terminate after 1-2 cycles to be too detrimental to performance.
So the new input system now allows non-sequential port and device IDs.
Remember that I killed input IDs a while back. There's never any reason
for those to need IDs ... it was easier to just order the inputs in the
order you want to see them in the user interface. So the input lookup is
still O(1). Only now, everything's safer and I return a
maybe<InputMapping&>, and won't crash out the program trying to use a
mapping that isn't found for some reason.
Errata: the escape key isn't working on the browser/message dialogs on
Windows, because of course nothing can ever just be easy and work for
me. If anyone else wouldn't mind looking into that, I'd greatly
appreciate it.
Having the `WM_KEYDOWN` test inside the main `Application_sharedProc`, it
seems to not respond to the escape key on modal dialogs. If I put the
`WM_KEYDOWN` test in the main window proc, then it doesn't seem to get
called for `VK_ESCAPE` at all, and doesn't get called period for modal
windows. So I'm at a loss and it's past 4AM here >_>
2017-07-12 08:24:27 +00:00
|
|
|
auto setDismissable(bool dismissable = true) { return self().setDismissable(dismissable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setDroppable(bool droppable = true) { return self().setDroppable(droppable), *this; }
|
|
|
|
auto setFrameGeometry(Geometry geometry) { return self().setFrameGeometry(geometry), *this; }
|
|
|
|
auto setFramePosition(Position position) { return self().setFramePosition(position), *this; }
|
|
|
|
auto setFrameSize(Size size) { return self().setFrameSize(size), *this; }
|
|
|
|
auto setFullScreen(bool fullScreen = true) { return self().setFullScreen(fullScreen), *this; }
|
|
|
|
auto setGeometry(Geometry geometry) { return self().setGeometry(geometry), *this; }
|
|
|
|
auto setModal(bool modal = true) { return self().setModal(modal), *this; }
|
|
|
|
auto setPosition(Position position) { return self().setPosition(position), *this; }
|
|
|
|
auto setResizable(bool resizable = true) { return self().setResizable(resizable), *this; }
|
|
|
|
auto setSize(Size size) { return self().setSize(size), *this; }
|
|
|
|
auto setTitle(const string& title = "") { return self().setTitle(title), *this; }
|
|
|
|
auto statusBar() const { return self().statusBar(); }
|
|
|
|
auto title() const { return self().title(); }
|
|
|
|
};
|
|
|
|
#endif
|