Update to v106r2 release.

byuu says:

Changelog:

  - Super Famicom: added support for loading manifests without embedded
    mapping information¹
  - genius: initial commit
  - various Makefile cleanups

¹: so the idea here is to try and aim for a stable manifest format,
and to allow direct transposition of icarus/genius database entries into
manifest files. The exact mechanics of how this is going to work is
currently in flux, but we'll get there.

For right now, `Super Famicom.sys` gains `boards.bml`, which is the raw
database from my board-editor tool, and higan itself tries to load
`boards.bml`, match an entry to game/board from the game's `manifest.bml`
file, and then transform it into the format currently used by higan. It
does this only when the game's `manifest.bml` file lacks a board node.
When such a board node exists, it works as previous versions of higan
did.

The only incompatible change right now is information/title is now
located at game/label. I may transition window title display to just use
the filenames instead.

Longer term, some thought is going to need to go into the format of the
`boards.bml` database itself, and at which point in the process I should
be transforming things.

Give it time, we'll refine this into something nicer.
This commit is contained in:
Tim Allen
2018-02-01 19:20:37 +11:00
parent aef8d5e962
commit 2f81b5a3e7
41 changed files with 29372 additions and 13627 deletions

View File

@@ -15,13 +15,16 @@
namespace nall {
auto string::operator[](int position) const -> const char& {
//if(position > size() + 1) throw;
auto string::operator[](uint position) const -> const char& {
#ifdef DEBUG
struct out_of_bounds {};
if(position >= size() + 1) throw out_of_bounds{};
#endif
return data()[position];
}
auto string::operator()(int position, char fallback) const -> char {
if(position > size() + 1) return fallback;
auto string::operator()(uint position, char fallback) const -> char {
if(position >= size() + 1) return fallback;
return data()[position];
}