2015-06-18 10:48:53 +00:00
|
|
|
#define DeclareShared(Name) \
|
|
|
|
using type = Name; \
|
2018-08-04 11:44:00 +00:00
|
|
|
using internalType = m##Name; \
|
2015-06-18 10:48:53 +00:00
|
|
|
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); } \
|
2018-08-04 11:44:00 +00:00
|
|
|
template<typename T> Name(const T& source, \
|
|
|
|
std::enable_if_t<std::is_base_of<internalType, typename T::internalType>::value>* = 0) : \
|
|
|
|
s##Name((s##Name&)source) { assert(source); } \
|
2015-06-20 05:44:05 +00:00
|
|
|
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
|
|
|
} \
|
2018-08-04 11:44:00 +00:00
|
|
|
template<typename T> auto is() -> bool { \
|
Update to v106r59 release.
byuu says:
Changelog:
- fixed bug in Emulator::Game::Memory::operator bool()
- nall: renamed view<string> back to `string_view`
- nall:: implemented `array_view`
- Game Boy: split cartridge-specific input mappings (rumble,
accelerometer) to their own separate ports
- Game Boy: fixed MBC7 accelerometer x-axis
- icarus: Game Boy, Super Famicom, Mega Drive cores output internal
header game titles to heuristics manifests
- higan, icarus, hiro/gtk: improve viewport geometry configuration;
fixed higan crashing bug with XShm driver
- higan: connect Video::poll(),update() functionality
- hiro, ruby: several compilation / bugfixes, should get the macOS
port compiling again, hopefully [Sintendo]
- ruby/video/xshm: fix crashing bug on window resize
- a bit hacky; it's throwing BadAccess Xlib warnings, but they're
not fatal, so I am catching and ignoring them
- bsnes: removed Application::Windows::onModalChange hook that's no
longer needed [Screwtape]
2018-08-26 06:49:54 +00:00
|
|
|
return dynamic_cast<typename T::internalType*>(s##Name::data()); \
|
2018-08-04 11:44:00 +00:00
|
|
|
} \
|
Update to v106r51 release.
byuu says:
Changelog:
- added `Emulator::Interface::connected(uint port) -> uint device;`
- higan, bsnes: updated emulators to use the new
Emulator::Interface::connected() function
- hiro: fixed Object::cast<T> finally
So, Emulator::Interface::connected() solves two annoying problems at the
same time.
First, on first run of the emulator when the settings file is blank, it
will retrieve the default "sane" device ID, which is usually a gamepad
for a controller port, or nothing for an expansion/extension port.
Second, if you were to select a multi-port device, like the NES Four
Score, the core will set the other port to the Four Score device as
well, and the GUIs query connected() right after any call to connect(),
so it gets updated without needing a system for the emulation core to
send messages alerting the GUI of changes.
2018-07-21 11:49:48 +00:00
|
|
|
template<typename T> auto cast() -> T { \
|
Update to v106r59 release.
byuu says:
Changelog:
- fixed bug in Emulator::Game::Memory::operator bool()
- nall: renamed view<string> back to `string_view`
- nall:: implemented `array_view`
- Game Boy: split cartridge-specific input mappings (rumble,
accelerometer) to their own separate ports
- Game Boy: fixed MBC7 accelerometer x-axis
- icarus: Game Boy, Super Famicom, Mega Drive cores output internal
header game titles to heuristics manifests
- higan, icarus, hiro/gtk: improve viewport geometry configuration;
fixed higan crashing bug with XShm driver
- higan: connect Video::poll(),update() functionality
- hiro, ruby: several compilation / bugfixes, should get the macOS
port compiling again, hopefully [Sintendo]
- ruby/video/xshm: fix crashing bug on window resize
- a bit hacky; it's throwing BadAccess Xlib warnings, but they're
not fatal, so I am catching and ignoring them
- bsnes: removed Application::Windows::onModalChange hook that's no
longer needed [Screwtape]
2018-08-26 06:49:54 +00:00
|
|
|
if(auto pointer = dynamic_cast<typename T::internalType*>(s##Name::data())) { \
|
Update to v106r51 release.
byuu says:
Changelog:
- added `Emulator::Interface::connected(uint port) -> uint device;`
- higan, bsnes: updated emulators to use the new
Emulator::Interface::connected() function
- hiro: fixed Object::cast<T> finally
So, Emulator::Interface::connected() solves two annoying problems at the
same time.
First, on first run of the emulator when the settings file is blank, it
will retrieve the default "sane" device ID, which is usually a gamepad
for a controller port, or nothing for an expansion/extension port.
Second, if you were to select a multi-port device, like the NES Four
Score, the core will set the other port to the Four Score device as
well, and the GUIs query connected() right after any call to connect(),
so it gets updated without needing a system for the emulation core to
send messages alerting the GUI of changes.
2018-07-21 11:49:48 +00:00
|
|
|
if(auto shared = pointer->instance.acquire()) return T(shared); \
|
|
|
|
} \
|
|
|
|
return T(); \
|
|
|
|
} \
|
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) \
|
2019-01-01 23:52:08 +00:00
|
|
|
auto collapsible() const { return self().collapsible(); } \
|
Update to v106r57 release.
byuu says:
I've added tool tips to hiro for Windows, GTK, and Qt. I'm unsure how to
add them for Cocoa. I wasted am embarrassing ~14 hours implementing tool
tips from scratch on Windows, because the `TOOLTIPS_CLASS` widget just
absolutely refused to show up, no matter what I tried. As such, they're
not quite 100% native, but I would really appreciate any patch
submissions to help improve my implementation.
I added tool tips to all of the confusing settings in bsnes. And of
course, for those of you who don't like them, there's a configuration
file setting to turn them off globally.
I also improved Mega Drive handling of the Game Genie a bit, and
restructured the way the Settings class works in bsnes.
Starting now, I'm feature-freezing bsnes and higan. From this point
forward:
- polishing up and fixing bugs caused by the ruby/hiro changes
- adding DRC to XAudio2, and maybe exclusive mode to WGL
- correcting FEoEZ (English) to load and work again out of the box
Once that's done, a final beta of bsnes will go out, I'll fix any
reported bugs that I'm able to, and then v107 should be ready. This time
with higan being functional, but marked as v107 beta. v108 will restore
higan to production status again, alongside bsnes.
2018-08-08 08:46:58 +00:00
|
|
|
auto doSize() const { return self().doSize(); } \
|
2015-06-18 10:48:53 +00:00
|
|
|
auto geometry() const { return self().geometry(); } \
|
|
|
|
auto minimumSize() const { return self().minimumSize(); } \
|
Update to v106r57 release.
byuu says:
I've added tool tips to hiro for Windows, GTK, and Qt. I'm unsure how to
add them for Cocoa. I wasted am embarrassing ~14 hours implementing tool
tips from scratch on Windows, because the `TOOLTIPS_CLASS` widget just
absolutely refused to show up, no matter what I tried. As such, they're
not quite 100% native, but I would really appreciate any patch
submissions to help improve my implementation.
I added tool tips to all of the confusing settings in bsnes. And of
course, for those of you who don't like them, there's a configuration
file setting to turn them off globally.
I also improved Mega Drive handling of the Game Genie a bit, and
restructured the way the Settings class works in bsnes.
Starting now, I'm feature-freezing bsnes and higan. From this point
forward:
- polishing up and fixing bugs caused by the ruby/hiro changes
- adding DRC to XAudio2, and maybe exclusive mode to WGL
- correcting FEoEZ (English) to load and work again out of the box
Once that's done, a final beta of bsnes will go out, I'll fix any
reported bugs that I'm able to, and then v107 should be ready. This time
with higan being functional, but marked as v107 beta. v108 will restore
higan to production status again, alongside bsnes.
2018-08-08 08:46:58 +00:00
|
|
|
auto onSize(const function<void ()>& callback = {}) { return self().onSize(callback), *this; } \
|
2019-01-01 23:52:08 +00:00
|
|
|
auto setCollapsible(bool collapsible = true) { return self().setCollapsible(collapsible), *this; } \
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setGeometry(Geometry geometry) { return self().setGeometry(geometry), *this; } \
|
|
|
|
|
|
|
|
#define DeclareSharedWidget(Name) \
|
|
|
|
DeclareSharedSizable(Name) \
|
Update to v106r57 release.
byuu says:
I've added tool tips to hiro for Windows, GTK, and Qt. I'm unsure how to
add them for Cocoa. I wasted am embarrassing ~14 hours implementing tool
tips from scratch on Windows, because the `TOOLTIPS_CLASS` widget just
absolutely refused to show up, no matter what I tried. As such, they're
not quite 100% native, but I would really appreciate any patch
submissions to help improve my implementation.
I added tool tips to all of the confusing settings in bsnes. And of
course, for those of you who don't like them, there's a configuration
file setting to turn them off globally.
I also improved Mega Drive handling of the Game Genie a bit, and
restructured the way the Settings class works in bsnes.
Starting now, I'm feature-freezing bsnes and higan. From this point
forward:
- polishing up and fixing bugs caused by the ruby/hiro changes
- adding DRC to XAudio2, and maybe exclusive mode to WGL
- correcting FEoEZ (English) to load and work again out of the box
Once that's done, a final beta of bsnes will go out, I'll fix any
reported bugs that I'm able to, and then v107 should be ready. This time
with higan being functional, but marked as v107 beta. v108 will restore
higan to production status again, alongside bsnes.
2018-08-08 08:46:58 +00:00
|
|
|
auto setToolTip(const string& toolTip = "") { return self().setToolTip(toolTip), *this; } \
|
|
|
|
auto toolTip() const { return self().toolTip(); } \
|
2015-06-18 10:48:53 +00:00
|
|
|
|
|
|
|
#if defined(Hiro_Object)
|
|
|
|
struct Object : sObject {
|
|
|
|
DeclareSharedObject(Object)
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Group)
|
|
|
|
struct Group : sGroup {
|
|
|
|
DeclareShared(Group)
|
|
|
|
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
|
|
|
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;
|
|
|
|
}
|
Update to v106r57 release.
byuu says:
I've added tool tips to hiro for Windows, GTK, and Qt. I'm unsure how to
add them for Cocoa. I wasted am embarrassing ~14 hours implementing tool
tips from scratch on Windows, because the `TOOLTIPS_CLASS` widget just
absolutely refused to show up, no matter what I tried. As such, they're
not quite 100% native, but I would really appreciate any patch
submissions to help improve my implementation.
I added tool tips to all of the confusing settings in bsnes. And of
course, for those of you who don't like them, there's a configuration
file setting to turn them off globally.
I also improved Mega Drive handling of the Game Genie a bit, and
restructured the way the Settings class works in bsnes.
Starting now, I'm feature-freezing bsnes and higan. From this point
forward:
- polishing up and fixing bugs caused by the ruby/hiro changes
- adding DRC to XAudio2, and maybe exclusive mode to WGL
- correcting FEoEZ (English) to load and work again out of the box
Once that's done, a final beta of bsnes will go out, I'll fix any
reported bugs that I'm able to, and then v107 should be ready. This time
with higan being functional, but marked as v107 beta. v108 will restore
higan to production status again, alongside bsnes.
2018-08-08 08:46:58 +00:00
|
|
|
auto remove(sObject object) -> type& { return self().remove(object), *this; }
|
2015-12-14 09:41:06 +00:00
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Menu)
|
|
|
|
struct Menu : sMenu {
|
|
|
|
DeclareSharedAction(Menu)
|
|
|
|
|
|
|
|
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)
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_MenuItem)
|
|
|
|
struct MenuItem : sMenuItem {
|
|
|
|
DeclareSharedAction(MenuItem)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Widget)
|
|
|
|
struct Widget : sWidget {
|
|
|
|
DeclareSharedWidget(Widget)
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_Button)
|
|
|
|
struct Button : sButton {
|
|
|
|
DeclareSharedWidget(Button)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
auto color() const { return self().color(); }
|
|
|
|
auto data() { return self().data(); }
|
|
|
|
auto droppable() const { return self().droppable(); }
|
2018-07-25 12:24:03 +00:00
|
|
|
auto doDrop(vector<string> 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(); }
|
2018-07-25 12:24:03 +00:00
|
|
|
auto onDrop(const function<void (vector<string>)>& 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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto append(sSizable sizable) { return self().append(sizable), *this; }
|
|
|
|
auto remove(sSizable sizable) { return self().remove(sizable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto reset() { return self().reset(), *this; }
|
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto sizable() const { return self().sizable(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_HexEdit)
|
|
|
|
struct HexEdit : sHexEdit {
|
|
|
|
DeclareSharedWidget(HexEdit)
|
|
|
|
|
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-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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
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(); }
|
2018-06-24 04:53:44 +00:00
|
|
|
auto backgroundColor() const { return self().backgroundColor(); }
|
2019-01-01 23:52:08 +00:00
|
|
|
auto doMousePress(Mouse::Button button) const { return self().doMousePress(button); }
|
|
|
|
auto doMouseRelease(Mouse::Button button) const { return self().doMouseRelease(button); }
|
2018-06-24 04:53:44 +00:00
|
|
|
auto foregroundColor() const { return self().foregroundColor(); }
|
2019-01-01 23:52:08 +00:00
|
|
|
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; }
|
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; }
|
2018-06-24 04:53:44 +00:00
|
|
|
auto setBackgroundColor(Color color = {}) { return self().setBackgroundColor(color), *this; }
|
|
|
|
auto setForegroundColor(Color color = {}) { return self().setForegroundColor(color), *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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
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(); }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto editable() const { return self().editable(); }
|
2019-01-01 23:52:08 +00:00
|
|
|
auto language() const { return self().language(); }
|
|
|
|
auto numbered() const { return self().numbered(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onChange(const function<void ()>& callback = {}) { return self().onChange(callback), *this; }
|
|
|
|
auto onMove(const function<void ()>& callback = {}) { return self().onMove(callback), *this; }
|
2019-01-01 23:52:08 +00:00
|
|
|
auto scheme() const { return self().scheme(); }
|
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; }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto setEditable(bool editable = true) { return self().setEditable(editable), *this; }
|
2019-01-01 23:52:08 +00:00
|
|
|
auto setLanguage(const string& language = "") { return self().setLanguage(language), *this; }
|
|
|
|
auto setNumbered(bool numbered = true) { return self().setNumbered(numbered), *this; }
|
|
|
|
auto setScheme(const string& scheme = "") { return self().setScheme(scheme), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto setText(const string& text = "") { return self().setText(text), *this; }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto setWordWrap(bool wordWrap = true) { return self().setWordWrap(wordWrap), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto text() const { return self().text(); }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto wordWrap() const { return self().wordWrap(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TabFrame)
|
|
|
|
struct TabFrameItem : sTabFrameItem {
|
|
|
|
DeclareSharedObject(TabFrameItem)
|
|
|
|
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto append(sSizable sizable) { return self().append(sizable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
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 movable() const { return self().movable(); }
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto remove(sSizable sizable) { return self().remove(sizable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
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; }
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto sizable() const { return self().sizable(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto text() const { return self().text(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TabFrame)
|
|
|
|
struct TabFrame : sTabFrame {
|
|
|
|
DeclareSharedWidget(TabFrame)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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; }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto setSorting(Sort sorting = Sort::None) { return self().setSorting(sorting), *this; }
|
2016-05-04 10:07:13 +00:00
|
|
|
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; }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto sort(Sort sorting) { return self().sort(sorting), *this; }
|
|
|
|
auto sorting() const { return self().sorting(); }
|
2016-05-04 10:07:13 +00:00
|
|
|
auto text() const { return self().text(); }
|
|
|
|
auto verticalAlignment() const { return self().verticalAlignment(); }
|
|
|
|
auto width() const { return self().width(); }
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(Hiro_TableView)
|
|
|
|
struct TableViewCell : sTableViewCell {
|
|
|
|
DeclareSharedObject(TableViewCell)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
auto alignment() const { return self().alignment(); }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto append(sTableViewColumn column) { return self().append(column), *this; }
|
2016-05-04 10:07:13 +00:00
|
|
|
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(); }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto column(uint position) const { return self().column(position); }
|
|
|
|
auto columnCount() const { return self().columnCount(); }
|
|
|
|
auto columns() const { return self().columns(); }
|
2016-05-04 10:07:13 +00:00
|
|
|
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(); }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto headered() const { return self().headered(); }
|
2016-05-04 10:07:13 +00:00
|
|
|
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; }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto remove(sTableViewColumn column) { return self().remove(column), *this; }
|
2016-05-04 10:07:13 +00:00
|
|
|
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; }
|
2018-08-04 11:44:00 +00:00
|
|
|
auto setHeadered(bool headered = true) { return self().setHeadered(headered), *this; }
|
|
|
|
auto setSortable(bool sortable = true) { return self().setSortable(sortable), *this; }
|
|
|
|
auto sort() { return self().sort(), *this; }
|
|
|
|
auto sortable() const { return self().sortable(); }
|
2016-05-04 10:07:13 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2015-06-18 10:48:53 +00:00
|
|
|
#if defined(Hiro_TextEdit)
|
|
|
|
struct TextEdit : sTextEdit {
|
|
|
|
DeclareSharedWidget(TextEdit)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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(); }
|
2019-01-01 23:52:08 +00:00
|
|
|
auto expanded() const { return self().expanded(); }
|
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)
|
|
|
|
|
|
|
|
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-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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
2018-07-25 12:24:03 +00:00
|
|
|
auto doDrop(vector<string> 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(); }
|
2018-07-25 12:24:03 +00:00
|
|
|
auto onDrop(const function<void (vector<string>)>& 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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
auto append(sMenuBar menuBar) { return self().append(menuBar), *this; }
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto append(sSizable sizable) { return self().append(sizable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
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(); }
|
2018-07-25 12:24:03 +00:00
|
|
|
auto doDrop(vector<string> 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(); }
|
2018-07-08 04:58:27 +00:00
|
|
|
auto maximized() const { return self().maximized(); }
|
|
|
|
auto maximumSize() const { return self().maximumSize(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto menuBar() const { return self().menuBar(); }
|
2018-07-08 04:58:27 +00:00
|
|
|
auto minimized() const { return self().minimized(); }
|
|
|
|
auto minimumSize() const { return self().minimumSize(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto modal() const { return self().modal(); }
|
Update to 20180729 release.
byuu wrote:
Sigh ...
asio.hpp needs #include <nall/windows/registry.hpp>
[Since the last WIP, byuu also posted the following message. -Ed.]
ruby drivers have all been updated (but not tested outside of BSD), and
I redesigned the settings window. The driver functionality all exists on
a new "Drivers" panel, the emulator/hack settings go to a
"Configuration" panel, and the video/audio panels lose driver settings.
As does the settings menu and its synchronize options.
I want to start pushing toward a v107 release. Critically, I will need
DirectSound and ALSA to support dynamic rate control. I'd also like to
eliminate the other system manifest.bml files. I need to update the
cheat code database format, and bundle at least a few quark shaders --
although I still need to default to Direct3D on Windows.
Turbo keys would be nice, if it's not too much effort. Aside from
netplay, it's the last significant feature I'm missing.
I think for v107, higan is going to be a bit rough around the edges
compared to bsnes. And I don't think it's practical to finish the bsnes
localization support.
I'm thinking we probably want another WIP to iron out any critical
issues, but this time there should be a feature freeze with the next
WIP.
2018-07-29 13:24:38 +00:00
|
|
|
auto monitor() const { return self().monitor(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto onClose(const function<void ()>& callback = {}) { return self().onClose(callback), *this; }
|
2018-07-25 12:24:03 +00:00
|
|
|
auto onDrop(const function<void (vector<string>)>& 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(sMenuBar menuBar) { return self().remove(menuBar), *this; }
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto remove(sSizable sizable) { return self().remove(sizable), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
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; }
|
2018-07-08 04:58:27 +00:00
|
|
|
auto setMaximized(bool maximized) { return self().setMaximized(maximized), *this; }
|
|
|
|
auto setMaximumSize(Size size = {}) { return self().setMaximumSize(size), *this; }
|
|
|
|
auto setMinimized(bool minimized) { return self().setMinimized(minimized), *this; }
|
|
|
|
auto setMinimumSize(Size size = {}) { return self().setMinimumSize(size), *this; }
|
2015-06-18 10:48:53 +00:00
|
|
|
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; }
|
Update to v106r47 release.
byuu says:
This is probably the largest code-change diff I've done in years.
I spent four days working 10-16 hours a day reworking layouts in hiro
completely.
The result is we now have TableLayout, which will allow for better
horizontal+vertical combined alignment.
Windows, GTK2, and now GTK3 are fully supported.
Windows is getting the initial window geometry wrong by a bit.
GTK2 and GTK3 work perfectly. I basically abandoned trying to detect
resize signals, and instead keep a list of all hiro windows that are
allocated, and every time the main loop runs, it will query all of them
to see if they've been resized. I'm disgusted that I have to do this,
but after fighting with GTK for years, I'm about sick of it. GTK was
doing this crazy thing where it would trigger another size-allocate
inside of a previous size-allocate, and so my layouts would be halfway
through resizing all the widgets, and then the size-allocate would kick
off another one. That would end up leaving the rest of the first layout
loop with bad widget sizes. And if I detected a second re-entry and
blocked it, then the entire window would end up with the older geometry.
I started trying to build a message queue system to allow the second
layout resize to occur after the first one completed, but this was just
too much madness, so I went with the simpler solution.
Qt4 has some geometry problems, and doesn't show tab frame layouts
properly yet.
Qt5 causes an ICE error and tanks my entire Xorg display server, so ...
something is seriously wrong there, and it's not hiro's fault. Creating
a dummy Qt5 application without even using hiro, just int main() {
TestObject object; } with object performing a dynamic\_cast to a derived
type segfaults. Memory is getting corrupted where GCC allocates the
vtables for classes, just by linking in Qt. Could be somehow related to
the -fPIC requirement that only Qt5 has ... could just be that FreeBSD
10.1 has a buggy implementation of Qt5. I don't know. It's beyond my
ability to debug, so this one's going to stay broken.
The Cocoa port is busted. I'll fix it up to compile again, but that's
about all I'm going to do.
Many optimizations mean bsnes and higan open faster. GTK2 and GTK3 both
resize windows very quickly now.
higan crashes when you load a game, so that's not good. bsnes works
though.
bsnes also has the start of a localization engine now. Still a long way
to go.
The makefiles received a rather substantial restructuring. Including the
ruby and hiro makefiles will add the necessary compilation rules for
you, which also means that moc will run for the qt4 and qt5 targets, and
windres will run for the Windows targets.
2018-07-14 03:59:29 +00:00
|
|
|
auto sizable() const { return self().sizable(); }
|
2015-06-18 10:48:53 +00:00
|
|
|
auto statusBar() const { return self().statusBar(); }
|
|
|
|
auto title() const { return self().title(); }
|
|
|
|
};
|
|
|
|
#endif
|