mirror of https://github.com/bsnes-emu/bsnes.git
Update to v076r06 release.
byuu says: Changelog: - path code finished for ui/, just need to expose for ui-libsnes/ now - filters and shaders use radio items now, so you know which is active - smooth video was placed inside video mode (list is getting too long) - .bsnes -> .config/bsnes in make install - pixelshaders -> snesshader, added Makefile with make install target - snesfilter, added Makefile with make install and make clean targets - maybe other stuff
This commit is contained in:
parent
d5cd21eb0c
commit
5cbf5b617b
|
@ -1,2 +1,2 @@
|
|||
@mingw32-make -j 2
|
||||
@mingw32-make -j 8
|
||||
@pause
|
||||
|
|
|
@ -3,14 +3,15 @@
|
|||
|
||||
namespace nall {
|
||||
|
||||
string realpath(const char *name) {
|
||||
string currentpath() {
|
||||
char path[PATH_MAX];
|
||||
if(::realpath(name, path)) {
|
||||
if(::getcwd(path)) {
|
||||
string result(path);
|
||||
result.transform("\\", "/");
|
||||
if(result.endswith("/") == false) result.append("/");
|
||||
return result;
|
||||
}
|
||||
return "";
|
||||
return "./";
|
||||
}
|
||||
|
||||
string userpath() {
|
||||
|
@ -21,18 +22,17 @@ string userpath() {
|
|||
if(result.endswith("/") == false) result.append("/");
|
||||
return result;
|
||||
}
|
||||
return "";
|
||||
return currentpath();
|
||||
}
|
||||
|
||||
string currentpath() {
|
||||
string realpath(const char *name) {
|
||||
char path[PATH_MAX];
|
||||
if(::getcwd(path)) {
|
||||
if(::realpath(name, path)) {
|
||||
string result(path);
|
||||
result.transform("\\", "/");
|
||||
if(result.endswith("/") == false) result.append("/");
|
||||
return result;
|
||||
}
|
||||
return "";
|
||||
return userpath();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -80,7 +80,7 @@ void CheckItem::setChecked(bool checked) { state.checked = checked; return p.set
|
|||
void CheckItem::setText(const string &text) { state.text = text; return p.setText(text); }
|
||||
CheckItem::CheckItem() : state(*new State), base_from_member<pCheckItem&>(*new pCheckItem(*this)), Action(base_from_member<pCheckItem&>::value), p(base_from_member<pCheckItem&>::value) { p.constructor(); }
|
||||
|
||||
void RadioItem::group_(const reference_array<RadioItem&> &list) { foreach(item, list) item.p.setGroup(item.state.group = list); if(list.size()) list[0].setChecked(); }
|
||||
void RadioItem::group(const reference_array<RadioItem&> &list) { foreach(item, list) item.p.setGroup(item.state.group = list); if(list.size()) list[0].setChecked(); }
|
||||
bool RadioItem::checked() { return p.checked(); }
|
||||
void RadioItem::setChecked() { foreach(item, state.group) item.state.checked = false; state.checked = true; return p.setChecked(); }
|
||||
void RadioItem::setText(const string &text) { state.text = text; return p.setText(text); }
|
||||
|
@ -148,7 +148,7 @@ ListView::ListView() : state(*new State), base_from_member<pListView&>(*new pLis
|
|||
void ProgressBar::setPosition(unsigned position) { state.position = position; return p.setPosition(position); }
|
||||
ProgressBar::ProgressBar() : state(*new State), base_from_member<pProgressBar&>(*new pProgressBar(*this)), Widget(base_from_member<pProgressBar&>::value), p(base_from_member<pProgressBar&>::value) { p.constructor(); }
|
||||
|
||||
void RadioBox::group_(const reference_array<RadioBox&> &list) { foreach(item, list) item.p.setGroup(item.state.group = list); if(list.size()) list[0].setChecked(); }
|
||||
void RadioBox::group(const reference_array<RadioBox&> &list) { foreach(item, list) item.p.setGroup(item.state.group = list); if(list.size()) list[0].setChecked(); }
|
||||
bool RadioBox::checked() { return p.checked(); }
|
||||
void RadioBox::setChecked() { foreach(item, state.group) item.state.checked = false; state.checked = true; return p.setChecked(); }
|
||||
void RadioBox::setText(const string &text) { state.text = text; return p.setText(text); }
|
||||
|
|
|
@ -179,7 +179,8 @@ struct CheckItem : private nall::base_from_member<pCheckItem&>, Action {
|
|||
};
|
||||
|
||||
struct RadioItem : private nall::base_from_member<pRadioItem&>, Action {
|
||||
template<typename... Args> static void group(Args&... args) { group_({ args... }); }
|
||||
template<typename... Args> static void group(Args&... args) { group({ args... }); }
|
||||
static void group(const nall::reference_array<RadioItem&> &list);
|
||||
|
||||
nall::function<void ()> onTick;
|
||||
|
||||
|
@ -191,9 +192,6 @@ struct RadioItem : private nall::base_from_member<pRadioItem&>, Action {
|
|||
struct State;
|
||||
State &state;
|
||||
pRadioItem &p;
|
||||
|
||||
private:
|
||||
static void group_(const nall::reference_array<RadioItem&> &list);
|
||||
};
|
||||
|
||||
struct Layout : Object {
|
||||
|
@ -348,7 +346,8 @@ struct ProgressBar : private nall::base_from_member<pProgressBar&>, Widget {
|
|||
};
|
||||
|
||||
struct RadioBox : private nall::base_from_member<pRadioBox&>, Widget {
|
||||
template<typename... Args> static void group(Args&... args) { group_({ args... }); }
|
||||
template<typename... Args> static void group(Args&... args) { group({ args... }); }
|
||||
static void group(const nall::reference_array<RadioBox&> &list);
|
||||
|
||||
nall::function<void ()> onTick;
|
||||
|
||||
|
@ -360,9 +359,6 @@ struct RadioBox : private nall::base_from_member<pRadioBox&>, Widget {
|
|||
struct State;
|
||||
State &state;
|
||||
pRadioBox &p;
|
||||
|
||||
private:
|
||||
static void group_(const nall::reference_array<RadioBox&> &list);
|
||||
};
|
||||
|
||||
struct TextEdit : private nall::base_from_member<pTextEdit&>, Widget {
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
/****************************************************************************
|
||||
** Meta object code from reading C++ file 'qt.moc.hpp'
|
||||
**
|
||||
** Created: Sun Mar 13 14:53:22 2011
|
||||
** Created: Mon Mar 14 20:13:45 2011
|
||||
** by: The Qt Meta Object Compiler version 62 (Qt 4.7.0)
|
||||
**
|
||||
** WARNING! All changes made in this file will be lost!
|
||||
|
|
|
@ -13,17 +13,13 @@ public:
|
|||
PAL,
|
||||
};
|
||||
|
||||
enum class Path : unsigned {
|
||||
enum class Slot : unsigned {
|
||||
Base,
|
||||
Bsx,
|
||||
SufamiTurbo,
|
||||
SufamiTurboA,
|
||||
SufamiTurboB,
|
||||
GameBoy,
|
||||
|
||||
NECDSP,
|
||||
MSU1,
|
||||
Serial,
|
||||
};
|
||||
|
||||
MappedRAM rom;
|
||||
|
@ -55,10 +51,10 @@ public:
|
|||
const string id;
|
||||
uint8_t *data;
|
||||
unsigned size;
|
||||
Path path;
|
||||
NonVolatileRAM() : id(""), data(0), size(0), path(Path::Base) {}
|
||||
NonVolatileRAM(const string id, uint8_t *data, unsigned size, Path path = Path::Base)
|
||||
: id(id), data(data), size(size), path(path) {}
|
||||
Slot slot;
|
||||
NonVolatileRAM() : id(""), data(0), size(0), slot(Slot::Base) {}
|
||||
NonVolatileRAM(const string id, uint8_t *data, unsigned size, Slot slot = Slot::Base)
|
||||
: id(id), data(data), size(size), slot(slot) {}
|
||||
};
|
||||
linear_vector<NonVolatileRAM> nvram;
|
||||
|
||||
|
|
|
@ -269,12 +269,13 @@ void Cartridge::xml_parse_necdsp(xml_element &root) {
|
|||
}
|
||||
}
|
||||
|
||||
string path = { dir(system.interface->path(Slot::Base, ".dsp")), program };
|
||||
unsigned promsize = (necdsp.revision == NECDSP::Revision::uPD7725 ? 2048 : 16384);
|
||||
unsigned dromsize = (necdsp.revision == NECDSP::Revision::uPD7725 ? 1024 : 2048);
|
||||
unsigned filesize = promsize * 3 + dromsize * 2;
|
||||
|
||||
file fp;
|
||||
if(fp.open(system.interface->path(Path::NECDSP, program), file::mode::read)) {
|
||||
if(fp.open(path, file::mode::read)) {
|
||||
if(fp.size() == filesize) {
|
||||
for(unsigned n = 0; n < promsize; n++) necdsp.programROM[n] = fp.readm(3);
|
||||
for(unsigned n = 0; n < dromsize; n++) necdsp.dataROM[n] = fp.readm(2);
|
||||
|
|
|
@ -50,7 +50,7 @@ void MSU1::init() {
|
|||
|
||||
void MSU1::load() {
|
||||
if(datafile.open()) datafile.close();
|
||||
datafile.open(system.interface->path(Cartridge::Path::MSU1, ".msu"), file::mode::read);
|
||||
datafile.open(system.interface->path(Cartridge::Slot::Base, ".msu"), file::mode::read);
|
||||
}
|
||||
|
||||
void MSU1::unload() {
|
||||
|
@ -133,7 +133,7 @@ void MSU1::mmio_write(unsigned addr, uint8 data) {
|
|||
if(addr == 0x2005) {
|
||||
mmio.audio_track = (mmio.audio_track & 0x00ff) | (data << 8);
|
||||
if(audiofile.open()) audiofile.close();
|
||||
if(audiofile.open(system.interface->path(Cartridge::Path::MSU1, { "-", (unsigned)mmio.audio_track, ".pcm" }), file::mode::read)) {
|
||||
if(audiofile.open(system.interface->path(Cartridge::Slot::Base, { "-", (unsigned)mmio.audio_track, ".pcm" }), file::mode::read)) {
|
||||
uint32 header = audiofile.readm(4);
|
||||
if(header != 0x4d535531) { //verify 'MSU1' header
|
||||
audiofile.close();
|
||||
|
|
|
@ -16,12 +16,12 @@ void MSU1::serialize(serializer &s) {
|
|||
s.integer(mmio.audio_play);
|
||||
|
||||
if(datafile.open()) datafile.close();
|
||||
if(datafile.open(system.interface->path(Cartridge::Path::MSU1, ".msu"), file::mode::read)) {
|
||||
if(datafile.open(system.interface->path(Cartridge::Slot::Base, ".msu"), file::mode::read)) {
|
||||
datafile.seek(mmio.data_offset);
|
||||
}
|
||||
|
||||
if(audiofile.open()) audiofile.close();
|
||||
if(audiofile.open(system.interface->path(Cartridge::Path::MSU1, { "-", (unsigned)mmio.audio_track, ".pcm" }), file::mode::read)) {
|
||||
if(audiofile.open(system.interface->path(Cartridge::Slot::Base, { "-", (unsigned)mmio.audio_track, ".pcm" }), file::mode::read)) {
|
||||
audiofile.seek(mmio.audio_offset);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -79,7 +79,7 @@ void Serial::init() {
|
|||
|
||||
void Serial::load() {
|
||||
if(opened()) close();
|
||||
string basename = system.interface->path(Cartridge::Path::Serial, "");
|
||||
string basename = system.interface->path(Cartridge::Slot::Base, "");
|
||||
string name = notdir(basename);
|
||||
string path = dir(basename);
|
||||
if(open(name, path)) {
|
||||
|
|
|
@ -11,13 +11,13 @@ void SufamiTurbo::load() {
|
|||
slotB.ram.map(allocate<uint8>(128 * 1024, 0xff), 128 * 1024);
|
||||
|
||||
if(slotA.rom.data()) {
|
||||
cartridge.nvram.append({ ".sts", slotA.ram.data(), slotA.ram.size(), Cartridge::Path::SufamiTurboA });
|
||||
cartridge.nvram.append({ ".sts", slotA.ram.data(), slotA.ram.size(), Cartridge::Slot::SufamiTurboA });
|
||||
} else {
|
||||
slotA.rom.map(allocate<uint8>(128 * 1024, 0xff), 128 * 1024);
|
||||
}
|
||||
|
||||
if(slotB.rom.data()) {
|
||||
cartridge.nvram.append({ ".sts", slotB.ram.data(), slotB.ram.size(), Cartridge::Path::SufamiTurboB });
|
||||
cartridge.nvram.append({ ".sts", slotB.ram.data(), slotB.ram.size(), Cartridge::Slot::SufamiTurboB });
|
||||
} else {
|
||||
slotB.rom.map(allocate<uint8>(128 * 1024, 0xff), 128 * 1024);
|
||||
}
|
||||
|
|
|
@ -6,5 +6,5 @@ public:
|
|||
virtual int16_t input_poll(bool port, Input::Device device, unsigned index, unsigned id) { return 0; }
|
||||
|
||||
virtual void message(const string &text) { print(text, "\n"); }
|
||||
virtual string path(Cartridge::Path path, const string &hint) { return hint; };
|
||||
virtual string path(Cartridge::Slot slot, const string &hint) = 0;
|
||||
};
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
namespace SNES {
|
||||
namespace Info {
|
||||
static const char Name[] = "bsnes";
|
||||
static const char Version[] = "076.05";
|
||||
static const char Version[] = "076.06";
|
||||
static const unsigned SerializerVersion = 18;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -96,9 +96,9 @@ ifeq ($(platform),x)
|
|||
endif
|
||||
install -D -m 644 data/bsnes.png $(DESTDIR)$(prefix)/share/pixmaps/bsnes.png
|
||||
install -D -m 644 data/bsnes.desktop $(DESTDIR)$(prefix)/share/applications/bsnes.desktop
|
||||
test -d ~/.bsnes || mkdir ~/.bsnes
|
||||
cp data/cheats.xml ~/.bsnes/cheats.xml
|
||||
chmod 777 ~/.bsnes ~/.bsnes/cheats.xml
|
||||
mkdir -p ~/.config/bsnes
|
||||
cp data/cheats.xml ~/.config/bsnes/cheats.xml
|
||||
chmod 777 ~/.config/bsnes ~/.config/bsnes/cheats.xml
|
||||
|
||||
uninstall:
|
||||
ifeq ($(platform),x)
|
||||
|
|
|
@ -73,7 +73,7 @@ bool Cartridge::loadSuperGameBoy(const char *basename, const char *slotname) {
|
|||
SNES::cartridge.load(SNES::Cartridge::Mode::SuperGameBoy, { baseXML, "" });
|
||||
|
||||
foreach(memory, SNES::cartridge.nvram) loadMemory(memory);
|
||||
if(GameBoy::cartridge.info.battery && fp.open(path.load(SNES::Cartridge::Path::GameBoy, ".sav"), file::mode::read)) {
|
||||
if(GameBoy::cartridge.info.battery && fp.open(path.load(SNES::Cartridge::Slot::GameBoy, ".sav"), file::mode::read)) {
|
||||
fp.read(GameBoy::cartridge.ramdata, min(GameBoy::cartridge.ramsize, fp.size()));
|
||||
fp.close();
|
||||
}
|
||||
|
@ -89,7 +89,7 @@ void Cartridge::unload() {
|
|||
foreach(memory, SNES::cartridge.nvram) saveMemory(memory);
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::SuperGameBoy) {
|
||||
file fp;
|
||||
if(GameBoy::cartridge.info.battery && fp.open(path.load(SNES::Cartridge::Path::GameBoy, ".sav"), file::mode::write)) {
|
||||
if(GameBoy::cartridge.info.battery && fp.open(path.load(SNES::Cartridge::Slot::GameBoy, ".sav"), file::mode::write)) {
|
||||
fp.write(GameBoy::cartridge.ramdata, GameBoy::cartridge.ramsize);
|
||||
fp.close();
|
||||
}
|
||||
|
@ -133,7 +133,7 @@ bool Cartridge::loadCartridge(SNES::MappedRAM &memory, string &XML, const char *
|
|||
|
||||
bool Cartridge::loadMemory(SNES::Cartridge::NonVolatileRAM &memory) {
|
||||
if(memory.size == 0) return true;
|
||||
string filename = path.load(memory.path, memory.id);
|
||||
string filename = path.load(memory.slot, memory.id);
|
||||
file fp;
|
||||
if(fp.open(filename, file::mode::read) == false) return false;
|
||||
fp.read(memory.data, min(memory.size, fp.size()));
|
||||
|
@ -143,7 +143,7 @@ bool Cartridge::loadMemory(SNES::Cartridge::NonVolatileRAM &memory) {
|
|||
|
||||
bool Cartridge::saveMemory(SNES::Cartridge::NonVolatileRAM &memory) {
|
||||
if(memory.size == 0) return true;
|
||||
string filename = path.load(memory.path, memory.id);
|
||||
string filename = path.load(memory.slot, memory.id);
|
||||
file fp;
|
||||
if(fp.open(filename, file::mode::write) == false) return false;
|
||||
fp.write(memory.data, memory.size);
|
||||
|
|
|
@ -118,6 +118,9 @@ void MainWindow::create() {
|
|||
settingsVideoModeAspectRatioCorrection.setText("Correct Aspect Ratio");
|
||||
settingsVideoMode.append(settingsVideoModeAspectRatioCorrection);
|
||||
|
||||
settingsVideoModeSmoothVideo.setText("Smooth Video");
|
||||
settingsVideoMode.append(settingsVideoModeSmoothVideo);
|
||||
|
||||
settingsVideoMode.append(settingsVideoModeSeparator2);
|
||||
|
||||
settingsVideoModeNTSC.setText("NTSC");
|
||||
|
@ -126,31 +129,12 @@ void MainWindow::create() {
|
|||
settingsVideoModePAL.setText("PAL");
|
||||
settingsVideoMode.append(settingsVideoModePAL);
|
||||
|
||||
settingsVideoFilter.setText("Video Filter");
|
||||
settings.append(settingsVideoFilter);
|
||||
|
||||
settingsVideoFilterNone.setText("None");
|
||||
settingsVideoFilter.append(settingsVideoFilterNone);
|
||||
|
||||
settingsVideoFilter.append(settingsVideoFilterSeparator);
|
||||
|
||||
settingsVideoShader.setText("Video Shader");
|
||||
settings.append(settingsVideoShader);
|
||||
|
||||
settingsVideoShaderNone.setText("None");
|
||||
settingsVideoShader.append(settingsVideoShaderNone);
|
||||
|
||||
settingsVideoShader.append(settingsVideoShaderSeparator);
|
||||
|
||||
setupFiltersAndShaders();
|
||||
|
||||
RadioItem::group(
|
||||
settingsVideoModeNTSC, settingsVideoModePAL
|
||||
);
|
||||
|
||||
settingsSmoothVideo.setText("Smooth Video");
|
||||
settings.append(settingsSmoothVideo);
|
||||
|
||||
settings.append(settingsSeparator1);
|
||||
|
||||
settingsSynchronizeVideo.setText("Synchronize Video");
|
||||
|
@ -258,9 +242,9 @@ void MainWindow::create() {
|
|||
if(config.video.scale == 4) settingsVideoMode4x.setChecked();
|
||||
if(config.video.scale == 5) settingsVideoMode5x.setChecked();
|
||||
settingsVideoModeAspectRatioCorrection.setChecked(config.video.aspectRatioCorrection);
|
||||
settingsVideoModeSmoothVideo.setChecked(config.video.smooth);
|
||||
if(config.video.region == 0) settingsVideoModeNTSC.setChecked();
|
||||
if(config.video.region == 1) settingsVideoModePAL.setChecked();
|
||||
settingsSmoothVideo.setChecked(config.video.smooth);
|
||||
settingsSynchronizeVideo.setChecked(config.video.synchronize);
|
||||
settingsSynchronizeAudio.setChecked(config.audio.synchronize);
|
||||
settingsMuteAudio.setChecked(config.audio.mute);
|
||||
|
@ -317,6 +301,11 @@ void MainWindow::create() {
|
|||
utility.setScale();
|
||||
};
|
||||
|
||||
settingsVideoModeSmoothVideo.onTick = []() {
|
||||
config.video.smooth = mainWindow.settingsVideoModeSmoothVideo.checked();
|
||||
video.set(Video::Filter, (unsigned)config.video.smooth);
|
||||
};
|
||||
|
||||
settingsVideoModeNTSC.onTick = []() { config.video.region = 0; utility.setScale(); };
|
||||
settingsVideoModePAL.onTick = []() { config.video.region = 1; utility.setScale(); };
|
||||
|
||||
|
@ -330,11 +319,6 @@ void MainWindow::create() {
|
|||
utility.setShader();
|
||||
};
|
||||
|
||||
settingsSmoothVideo.onTick = []() {
|
||||
config.video.smooth = mainWindow.settingsSmoothVideo.checked();
|
||||
video.set(Video::Filter, (unsigned)config.video.smooth);
|
||||
};
|
||||
|
||||
settingsSynchronizeVideo.onTick = []() {
|
||||
config.video.synchronize = mainWindow.settingsSynchronizeVideo.checked();
|
||||
video.set(Video::Synchronize, config.video.synchronize);
|
||||
|
@ -405,11 +389,27 @@ void MainWindow::synchronize() {
|
|||
void MainWindow::setupFiltersAndShaders() {
|
||||
string folderPath;
|
||||
lstring files;
|
||||
reference_array<RadioItem&> group;
|
||||
signed active;
|
||||
|
||||
settingsVideoFilter.setText("Video Filter");
|
||||
|
||||
settingsVideoFilterNone.setText("None");
|
||||
settingsVideoFilter.append(settingsVideoFilterNone);
|
||||
|
||||
settingsVideoFilter.append(settingsVideoFilterSeparator);
|
||||
|
||||
group.append(settingsVideoFilterNone);
|
||||
active = -1;
|
||||
|
||||
folderPath = { path.base, "filters/" };
|
||||
files = directory::files(folderPath, "*.filter");
|
||||
if(files.size() == 0) {
|
||||
#if defined(PLATFORM_X) || defined(PLATFORM_OSX)
|
||||
folderPath = { path.user, ".config/bsnes/filters/" };
|
||||
#else
|
||||
folderPath = { path.user, "bsnes/filters/" };
|
||||
#endif
|
||||
files = directory::files(folderPath, "*.filter");
|
||||
}
|
||||
foreach(filename, files) {
|
||||
|
@ -417,11 +417,10 @@ void MainWindow::setupFiltersAndShaders() {
|
|||
}
|
||||
|
||||
if(settingsVideoFilterName.size() == 0) {
|
||||
settingsVideoFilter.setVisible(false);
|
||||
config.video.filter = ""; //as the list (and thus the 'None' option) is invisible,
|
||||
utility.setFilter(); //erase any previously saved filter name
|
||||
} else {
|
||||
settingsVideoFilterItem = new Item[settingsVideoFilterName.size()];
|
||||
settingsVideoFilterItem = new RadioItem[settingsVideoFilterName.size()];
|
||||
foreach(filename, settingsVideoFilterName, n) {
|
||||
settingsVideoFilterItem[n].onTick = [n]() {
|
||||
config.video.filter = mainWindow.settingsVideoFilterName[n];
|
||||
|
@ -429,13 +428,34 @@ void MainWindow::setupFiltersAndShaders() {
|
|||
};
|
||||
settingsVideoFilterItem[n].setText(nall::basename(notdir(filename)));
|
||||
settingsVideoFilter.append(settingsVideoFilterItem[n]);
|
||||
group.append(settingsVideoFilterItem[n]);
|
||||
if(filename == config.video.filter) active = n;
|
||||
}
|
||||
|
||||
RadioItem::group(group);
|
||||
group.reset();
|
||||
active < 0 ? settingsVideoFilterNone.setChecked() : settingsVideoFilterItem[active].setChecked();
|
||||
settings.append(settingsVideoFilter);
|
||||
}
|
||||
|
||||
settingsVideoShader.setText("Video Shader");
|
||||
|
||||
settingsVideoShaderNone.setText("None");
|
||||
settingsVideoShader.append(settingsVideoShaderNone);
|
||||
|
||||
settingsVideoShader.append(settingsVideoShaderSeparator);
|
||||
|
||||
group.append(settingsVideoShaderNone);
|
||||
active = -1;
|
||||
|
||||
folderPath = { path.base, "shaders/" };
|
||||
files = directory::files(folderPath, { "*.", config.video.driver, ".shader" });
|
||||
if(files.size() == 0) {
|
||||
#if defined(PLATFORM_X) || defined(PLATFORM_OSX)
|
||||
folderPath = { path.user, ".config/bsnes/shaders/" };
|
||||
#else
|
||||
folderPath = { path.user, "bsnes/shaders/" };
|
||||
#endif
|
||||
files = directory::files(folderPath, { "*.", config.video.driver, ".shader" });
|
||||
}
|
||||
foreach(filename, files) {
|
||||
|
@ -443,11 +463,10 @@ void MainWindow::setupFiltersAndShaders() {
|
|||
}
|
||||
|
||||
if(settingsVideoShaderName.size() == 0) {
|
||||
settingsVideoShader.setVisible(false);
|
||||
config.video.shader = "";
|
||||
utility.setShader();
|
||||
} else {
|
||||
settingsVideoShaderItem = new Item[settingsVideoShaderName.size()];
|
||||
settingsVideoShaderItem = new RadioItem[settingsVideoShaderName.size()];
|
||||
foreach(filename, settingsVideoShaderName, n) {
|
||||
settingsVideoShaderItem[n].onTick = [n]() {
|
||||
config.video.shader = mainWindow.settingsVideoShaderName[n];
|
||||
|
@ -455,6 +474,13 @@ void MainWindow::setupFiltersAndShaders() {
|
|||
};
|
||||
settingsVideoShaderItem[n].setText(nall::basename(nall::basename(notdir(filename))));
|
||||
settingsVideoShader.append(settingsVideoShaderItem[n]);
|
||||
}
|
||||
group.append(settingsVideoShaderItem[n]);
|
||||
if(filename == config.video.shader) active = n;
|
||||
}
|
||||
|
||||
RadioItem::group(group);
|
||||
group.reset();
|
||||
active < 0 ? settingsVideoShaderNone.setChecked() : settingsVideoShaderItem[active].setChecked();
|
||||
settings.append(settingsVideoShader);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -33,23 +33,23 @@ struct MainWindow : TopLevelWindow {
|
|||
RadioItem settingsVideoMode5x;
|
||||
Separator settingsVideoModeSeparator1;
|
||||
CheckItem settingsVideoModeAspectRatioCorrection;
|
||||
CheckItem settingsVideoModeSmoothVideo;
|
||||
Separator settingsVideoModeSeparator2;
|
||||
RadioItem settingsVideoModeNTSC;
|
||||
RadioItem settingsVideoModePAL;
|
||||
|
||||
Menu settingsVideoFilter;
|
||||
Item settingsVideoFilterNone;
|
||||
RadioItem settingsVideoFilterNone;
|
||||
Separator settingsVideoFilterSeparator;
|
||||
Item *settingsVideoFilterItem;
|
||||
RadioItem *settingsVideoFilterItem;
|
||||
lstring settingsVideoFilterName;
|
||||
|
||||
Menu settingsVideoShader;
|
||||
Item settingsVideoShaderNone;
|
||||
RadioItem settingsVideoShaderNone;
|
||||
Separator settingsVideoShaderSeparator;
|
||||
Item *settingsVideoShaderItem;
|
||||
RadioItem *settingsVideoShaderItem;
|
||||
lstring settingsVideoShaderName;
|
||||
|
||||
CheckItem settingsSmoothVideo;
|
||||
Separator settingsSeparator1;
|
||||
CheckItem settingsSynchronizeVideo;
|
||||
CheckItem settingsSynchronizeAudio;
|
||||
|
|
|
@ -138,6 +138,6 @@ void Interface::message(const string &text) {
|
|||
MessageWindow::information(mainWindow, text);
|
||||
}
|
||||
|
||||
string Interface::path(SNES::Cartridge::Path path, const string &hint) {
|
||||
return ::path.load(path, hint);
|
||||
string Interface::path(SNES::Cartridge::Slot slot, const string &hint) {
|
||||
return ::path.load(slot, hint);
|
||||
}
|
||||
|
|
|
@ -21,7 +21,7 @@ struct Interface : public SNES::Interface {
|
|||
int16_t input_poll(bool port, SNES::Input::Device device, unsigned index, unsigned id);
|
||||
|
||||
void message(const string &text);
|
||||
string path(SNES::Cartridge::Path path, const string &hint);
|
||||
string path(SNES::Cartridge::Slot slot, const string &hint);
|
||||
};
|
||||
|
||||
extern Palette palette;
|
||||
|
|
|
@ -48,63 +48,69 @@ void Path::save(const string &path, const string &value) {
|
|||
}
|
||||
}
|
||||
|
||||
string Path::load(SNES::Cartridge::Path pathHint, const string &hint) {
|
||||
string romPath;
|
||||
switch(pathHint) {
|
||||
case SNES::Cartridge::Path::Base: {
|
||||
romPath = cartridge.baseName;
|
||||
break;
|
||||
}
|
||||
case SNES::Cartridge::Path::Bsx: {
|
||||
romPath = cartridge.bsxName != "" ? cartridge.bsxName : cartridge.baseName;
|
||||
break;
|
||||
}
|
||||
case SNES::Cartridge::Path::SufamiTurbo: {
|
||||
if(cartridge.sufamiTurboAName == "" && cartridge.sufamiTurboBName == "") {
|
||||
romPath = cartridge.baseName;
|
||||
} else if(cartridge.sufamiTurboAName != "" && cartridge.sufamiTurboBName == "") {
|
||||
romPath = cartridge.sufamiTurboAName;
|
||||
} else if(cartridge.sufamiTurboAName == "" && cartridge.sufamiTurboBName != "") {
|
||||
romPath = cartridge.sufamiTurboBName;
|
||||
} else {
|
||||
romPath = { cartridge.sufamiTurboAName, "+", notdir(cartridge.sufamiTurboBName) };
|
||||
}
|
||||
break;
|
||||
}
|
||||
case SNES::Cartridge::Path::SufamiTurboA: {
|
||||
romPath = cartridge.sufamiTurboAName != "" ? cartridge.sufamiTurboAName : cartridge.baseName;
|
||||
break;
|
||||
}
|
||||
case SNES::Cartridge::Path::SufamiTurboB: {
|
||||
romPath = cartridge.sufamiTurboBName != "" ? cartridge.sufamiTurboBName : cartridge.baseName;
|
||||
break;
|
||||
}
|
||||
case SNES::Cartridge::Path::GameBoy: {
|
||||
romPath = cartridge.gameBoyName != "" ? cartridge.gameBoyName : cartridge.baseName;
|
||||
break;
|
||||
string Path::load(SNES::Cartridge::Slot slot, const string &hint) {
|
||||
string basePath = basepath(slot);
|
||||
string baseName = notdir(basePath);
|
||||
string filePath = dir(basePath);
|
||||
|
||||
if(hint == ".srm" && srm != "") filePath = srm;
|
||||
if(hint == ".bsp" && bsp != "") filePath = bsp;
|
||||
if(hint == ".bss" && bss != "") filePath = bss;
|
||||
if(hint == ".sts" && sts != "") filePath = sts;
|
||||
if(hint == ".sav" && sav != "") filePath = sav;
|
||||
if(hint == ".rtc" && rtc != "") filePath = rtc;
|
||||
|
||||
if(hint.endswith(".dsp") && necdsp != "") filePath = necdsp;
|
||||
if(hint.endswith(".msu") && msu1 != "") filePath = msu1;
|
||||
if(hint.endswith(".pcm") && msu1 != "") filePath = msu1;
|
||||
if(hint.endswith(".so") && serial != "") filePath = serial;
|
||||
|
||||
if(hint.endswith(".bsa") && bsa != "") filePath = bsa;
|
||||
if(hint.endswith(".bst") && bst != "") filePath = bst;
|
||||
if(hint.endswith(".cht") && cht != "") filePath = cht;
|
||||
if(hint.endswith(".log") && log != "") filePath = log;
|
||||
|
||||
filePath = decode(filePath, basePath);
|
||||
return { filePath, baseName, hint };
|
||||
}
|
||||
|
||||
case SNES::Cartridge::Path::NECDSP: romPath = cartridge.baseName; break;
|
||||
case SNES::Cartridge::Path::MSU1: romPath = cartridge.baseName; break;
|
||||
case SNES::Cartridge::Path::Serial: romPath = cartridge.baseName; break;
|
||||
string Path::basepath(SNES::Cartridge::Slot slot) {
|
||||
if(slot == SNES::Cartridge::Slot::Base) {
|
||||
return cartridge.baseName;
|
||||
}
|
||||
|
||||
string path = romPath;
|
||||
if(pathHint == SNES::Cartridge::Path::NECDSP && necdsp != "") path = necdsp;
|
||||
if(pathHint == SNES::Cartridge::Path::MSU1 && msu1 != "") path = string(msu1, notdir(path));
|
||||
if(pathHint == SNES::Cartridge::Path::Serial && serial != "") path = string(serial, notdir(path));
|
||||
if(slot == SNES::Cartridge::Slot::Bsx) {
|
||||
if(cartridge.bsxName == "") return cartridge.baseName;
|
||||
return cartridge.bsxName;
|
||||
}
|
||||
|
||||
if(hint == ".srm" && srm != "") path = string(srm, notdir(path));
|
||||
if(hint == ".bsp" && bsp != "") path = string(bsp, notdir(path));
|
||||
if(hint == ".bss" && bss != "") path = string(bss, notdir(path));
|
||||
if(hint == ".sts" && sts != "") path = string(sts, notdir(path));
|
||||
if(hint == ".sav" && sav != "") path = string(sav, notdir(path));
|
||||
if(hint == ".rtc" && rtc != "") path = string(rtc, notdir(path));
|
||||
if(slot == SNES::Cartridge::Slot::SufamiTurbo) {
|
||||
if(cartridge.sufamiTurboAName == "" && cartridge.sufamiTurboBName == "") return cartridge.baseName;
|
||||
if(cartridge.sufamiTurboAName != "" && cartridge.sufamiTurboBName == "") return cartridge.sufamiTurboAName;
|
||||
if(cartridge.sufamiTurboAName == "" && cartridge.sufamiTurboBName != "") return cartridge.sufamiTurboBName;
|
||||
return { cartridge.sufamiTurboAName, "+", notdir(cartridge.sufamiTurboBName) };
|
||||
}
|
||||
|
||||
if(hint == ".bsa" && bsa != "") path = string(bsa, notdir(path));
|
||||
if(hint.endswith(".bst") && bst != "") path = string(bst, notdir(path));
|
||||
if(hint == ".cht" && cht != "") path = string(cht, notdir(path));
|
||||
if(hint == ".log" && log != "") path = string(log, notdir(path));
|
||||
if(slot == SNES::Cartridge::Slot::SufamiTurboA) {
|
||||
if(cartridge.sufamiTurboAName == "") return cartridge.baseName;
|
||||
return cartridge.sufamiTurboAName;
|
||||
}
|
||||
|
||||
if(slot == SNES::Cartridge::Slot::SufamiTurboB) {
|
||||
if(cartridge.sufamiTurboBName == "") return cartridge.baseName;
|
||||
return cartridge.sufamiTurboBName;
|
||||
}
|
||||
|
||||
if(slot == SNES::Cartridge::Slot::GameBoy) {
|
||||
if(cartridge.gameBoyName == "") return cartridge.baseName;
|
||||
return cartridge.gameBoyName;
|
||||
}
|
||||
|
||||
throw "Path::basepath(): invalid slot ID.";
|
||||
}
|
||||
|
||||
string Path::decode(const string &filePath, const string &basePath) {
|
||||
string path = filePath;
|
||||
|
||||
if(path.beginswith("user/")) {
|
||||
path.ltrim<1>("user/");
|
||||
|
@ -118,19 +124,15 @@ string Path::load(SNES::Cartridge::Path pathHint, const string &hint) {
|
|||
path = string(base, path);
|
||||
} else if(path.beginswith("./")) {
|
||||
path.ltrim<1>("./");
|
||||
path = string(dir(romPath), path);
|
||||
path = string(dir(basePath), path);
|
||||
} else if(path.beginswith("../")) {
|
||||
string base = dir(romPath);
|
||||
string base = dir(basePath);
|
||||
base.rtrim<1>("/");
|
||||
path.ltrim<1>("../");
|
||||
path = string(dir(base), path);
|
||||
}
|
||||
|
||||
if(pathHint == SNES::Cartridge::Path::NECDSP) return { dir(path), hint };
|
||||
if(pathHint == SNES::Cartridge::Path::MSU1) return { path, hint };
|
||||
if(pathHint == SNES::Cartridge::Path::Serial) return { path, hint };
|
||||
|
||||
return { path, hint };
|
||||
return path;
|
||||
}
|
||||
|
||||
void Path::load() {
|
||||
|
|
|
@ -30,7 +30,10 @@ struct Path : public configuration {
|
|||
string home(const string &filename);
|
||||
string load(const string &path);
|
||||
void save(const string &path, const string &value);
|
||||
string load(SNES::Cartridge::Path path, const string &hint);
|
||||
string load(SNES::Cartridge::Slot slot, const string &hint);
|
||||
|
||||
string basepath(SNES::Cartridge::Slot slot);
|
||||
string decode(const string &filePath, const string &basePath);
|
||||
|
||||
void load();
|
||||
void save();
|
||||
|
|
|
@ -167,12 +167,12 @@ void Utility::cartridgeUnloaded() {
|
|||
mainWindow.synchronize();
|
||||
}
|
||||
|
||||
SNES::Cartridge::Path Utility::slotPath() {
|
||||
SNES::Cartridge::Path path = SNES::Cartridge::Path::Base;
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::Bsx) path = SNES::Cartridge::Path::Bsx;
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::SufamiTurbo) path = SNES::Cartridge::Path::SufamiTurbo;
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::SuperGameBoy) path = SNES::Cartridge::Path::GameBoy;
|
||||
return path;
|
||||
SNES::Cartridge::Slot Utility::slotPath() {
|
||||
SNES::Cartridge::Slot slot = SNES::Cartridge::Slot::Base;
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::Bsx) slot = SNES::Cartridge::Slot::Bsx;
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::SufamiTurbo) slot = SNES::Cartridge::Slot::SufamiTurbo;
|
||||
if(SNES::cartridge.mode() == SNES::Cartridge::Mode::SuperGameBoy) slot = SNES::Cartridge::Slot::GameBoy;
|
||||
return slot;
|
||||
}
|
||||
|
||||
void Utility::saveState(unsigned slot) {
|
||||
|
|
|
@ -15,7 +15,7 @@ struct Utility : property<Utility> {
|
|||
void cartridgeLoaded();
|
||||
void cartridgeUnloaded();
|
||||
|
||||
SNES::Cartridge::Path slotPath();
|
||||
SNES::Cartridge::Slot slotPath();
|
||||
void saveState(unsigned slot);
|
||||
void loadState(unsigned slot);
|
||||
|
||||
|
|
Loading…
Reference in New Issue