Update to v106r37 release.
byuu says:
Changelog:
- bsnes: cheat code “enabled” option changed to “enable”
- bsnes: connected “Cancel” action on add/edit cheat code window
- hiro: improved BrowserDialog::selectFolder() behavior
- can choose “Select” inside of a target folder when no items are
selected
- bsnes: implemented state manager
- bsnes: save a recovery state before loading a state, quitting, or
changing drivers
- bsnes: input settings, hotkey settings, cheat editor, state manager
entries are now batchable
- this allows bulk clearing/deleting of entries
- bsnes: cheat code list now auto-sorts alphabetically instead of
using up/down move arrows
I know most people will probably prefer to order cheat codes the way
they want, but the issue is that the state manager can't really work
this way. Each state is a file on disk. So yes, we could store a
states-manifest.bml to track the order of the states, or try to insert
numbers into the filenames and do bulk filesystem rename operations on
sorting, but then we would run into oddities when users delete state
files manually. And really, manual sorting is just clumsy. If you really
want a specific ordering, you can prefix cheats/states with numeric
indices instead.
2018-06-07 11:48:41 +00:00
|
|
|
StateWindow::StateWindow() {
|
|
|
|
stateWindow = this;
|
|
|
|
|
|
|
|
layout.setMargin(5);
|
|
|
|
nameLabel.setText("Name:");
|
|
|
|
nameValue.onActivate([&] {
|
|
|
|
if(acceptButton.enabled()) acceptButton.doActivate();
|
|
|
|
});
|
|
|
|
nameValue.onChange([&] {
|
|
|
|
doChange();
|
|
|
|
});
|
|
|
|
acceptButton.onActivate([&] {
|
|
|
|
doAccept();
|
|
|
|
});
|
|
|
|
cancelButton.setText("Cancel").onActivate([&] {
|
|
|
|
setVisible(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
setSize({400, layout.minimumSize().height()});
|
|
|
|
setDismissable();
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateWindow::show(string name) -> void {
|
|
|
|
nameValue.setText(name).setProperty("input", name);
|
|
|
|
doChange();
|
|
|
|
setTitle(!name ? "Add State" : "Edit State");
|
|
|
|
setCentered(*toolsWindow);
|
|
|
|
setVisible();
|
|
|
|
setFocused();
|
|
|
|
nameValue.setFocused();
|
|
|
|
acceptButton.setText(!name ? "Add" : "Edit");
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateWindow::doChange() -> void {
|
|
|
|
bool valid = true;
|
|
|
|
auto name = nameValue.text().strip();
|
|
|
|
if(!name) valid = false;
|
|
|
|
for(auto c : name) {
|
|
|
|
if(c == '\\'
|
|
|
|
|| c == '\"'
|
|
|
|
|| c == '\t'
|
|
|
|
|| c == '/'
|
|
|
|
|| c == ':'
|
|
|
|
|| c == '*'
|
|
|
|
|| c == '?'
|
|
|
|
|| c == '<'
|
|
|
|
|| c == '>'
|
|
|
|
|| c == '|') valid = false;
|
|
|
|
}
|
|
|
|
if(auto input = nameValue.property("input")) {
|
|
|
|
if(name != input && file::exists({program->statePath(), name, ".bst"})) valid = false;
|
|
|
|
}
|
|
|
|
nameValue.setBackgroundColor(valid ? Color{} : Color{255, 224, 224});
|
|
|
|
acceptButton.setEnabled(valid);
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateWindow::doAccept() -> void {
|
|
|
|
if(acceptButton.text() == "Add") {
|
|
|
|
toolsWindow->stateManager.createState(nameValue.text());
|
|
|
|
} else {
|
|
|
|
toolsWindow->stateManager.modifyState(nameValue.text());
|
|
|
|
}
|
|
|
|
setVisible(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
StateManager::StateManager(TabFrame* parent) : TabFrameItem(parent) {
|
|
|
|
setIcon(Icon::Application::FileManager);
|
|
|
|
setText("State Manager");
|
|
|
|
|
|
|
|
layout.setMargin(5);
|
|
|
|
stateList.setBatchable();
|
|
|
|
stateList.onActivate([&] {
|
|
|
|
editButton.doActivate();
|
|
|
|
});
|
|
|
|
stateList.onChange([&] {
|
|
|
|
auto batched = stateList.batched();
|
|
|
|
loadButton.setEnabled(batched.size() == 1);
|
2018-06-10 08:07:19 +00:00
|
|
|
saveButton.setEnabled(batched.size() == 1);
|
Update to v106r37 release.
byuu says:
Changelog:
- bsnes: cheat code “enabled” option changed to “enable”
- bsnes: connected “Cancel” action on add/edit cheat code window
- hiro: improved BrowserDialog::selectFolder() behavior
- can choose “Select” inside of a target folder when no items are
selected
- bsnes: implemented state manager
- bsnes: save a recovery state before loading a state, quitting, or
changing drivers
- bsnes: input settings, hotkey settings, cheat editor, state manager
entries are now batchable
- this allows bulk clearing/deleting of entries
- bsnes: cheat code list now auto-sorts alphabetically instead of
using up/down move arrows
I know most people will probably prefer to order cheat codes the way
they want, but the issue is that the state manager can't really work
this way. Each state is a file on disk. So yes, we could store a
states-manifest.bml to track the order of the states, or try to insert
numbers into the filenames and do bulk filesystem rename operations on
sorting, but then we would run into oddities when users delete state
files manually. And really, manual sorting is just clumsy. If you really
want a specific ordering, you can prefix cheats/states with numeric
indices instead.
2018-06-07 11:48:41 +00:00
|
|
|
editButton.setEnabled(batched.size() == 1);
|
|
|
|
removeButton.setEnabled(batched.size() >= 1);
|
|
|
|
});
|
|
|
|
loadButton.setText("Load").onActivate([&] {
|
|
|
|
if(auto item = stateList.selected()) {
|
|
|
|
program->loadState(item.cell(0).text());
|
|
|
|
}
|
|
|
|
});
|
|
|
|
saveButton.setText("Save").onActivate([&] {
|
2018-06-10 08:07:19 +00:00
|
|
|
if(auto item = stateList.selected()) {
|
|
|
|
program->saveState(item.cell(0).text());
|
|
|
|
}
|
|
|
|
});
|
|
|
|
addButton.setText("Add").onActivate([&] {
|
Update to v106r37 release.
byuu says:
Changelog:
- bsnes: cheat code “enabled” option changed to “enable”
- bsnes: connected “Cancel” action on add/edit cheat code window
- hiro: improved BrowserDialog::selectFolder() behavior
- can choose “Select” inside of a target folder when no items are
selected
- bsnes: implemented state manager
- bsnes: save a recovery state before loading a state, quitting, or
changing drivers
- bsnes: input settings, hotkey settings, cheat editor, state manager
entries are now batchable
- this allows bulk clearing/deleting of entries
- bsnes: cheat code list now auto-sorts alphabetically instead of
using up/down move arrows
I know most people will probably prefer to order cheat codes the way
they want, but the issue is that the state manager can't really work
this way. Each state is a file on disk. So yes, we could store a
states-manifest.bml to track the order of the states, or try to insert
numbers into the filenames and do bulk filesystem rename operations on
sorting, but then we would run into oddities when users delete state
files manually. And really, manual sorting is just clumsy. If you really
want a specific ordering, you can prefix cheats/states with numeric
indices instead.
2018-06-07 11:48:41 +00:00
|
|
|
stateWindow->show();
|
|
|
|
});
|
|
|
|
editButton.setText("Edit").onActivate([&] {
|
|
|
|
if(auto item = stateList.selected()) {
|
|
|
|
stateWindow->show(item.cell(0).text());
|
|
|
|
}
|
|
|
|
});
|
|
|
|
removeButton.setText("Remove").onActivate([&] {
|
|
|
|
removeStates();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateManager::loadStates() -> void {
|
|
|
|
stateList.reset();
|
|
|
|
stateList.append(TableViewHeader().setVisible(false)
|
|
|
|
.append(TableViewColumn().setExpandable())
|
|
|
|
);
|
|
|
|
for(auto filename : directory::ifiles(program->statePath(), "*.bst")) {
|
|
|
|
stateList.append(TableViewItem()
|
|
|
|
.append(TableViewCell().setText(filename.trimRight(".bst", 1L)))
|
|
|
|
);
|
|
|
|
}
|
|
|
|
stateList.resizeColumns().doChange();
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateManager::createState(string name) -> void {
|
|
|
|
program->saveState(name);
|
|
|
|
loadStates();
|
|
|
|
for(auto item : stateList.items()) {
|
|
|
|
if(item.cell(0).text() == name) item.setSelected();
|
|
|
|
}
|
|
|
|
stateList.doChange();
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateManager::modifyState(string name) -> void {
|
|
|
|
if(auto item = stateList.selected()) {
|
|
|
|
string from = {program->statePath(), item.cell(0).text(), ".bst"};
|
|
|
|
string to = {program->statePath(), name, ".bst"};
|
|
|
|
if(from != to) {
|
|
|
|
file::rename(from, to);
|
|
|
|
loadStates();
|
|
|
|
for(auto item : stateList.items()) {
|
|
|
|
if(item.cell(0).text() == name) item.setSelected();
|
|
|
|
}
|
|
|
|
stateList.doChange();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
auto StateManager::removeStates() -> void {
|
|
|
|
if(auto batched = stateList.batched()) {
|
|
|
|
if(MessageDialog("Are you sure you want to permanently remove the selected state(s)?")
|
|
|
|
.setParent(*toolsWindow).question() == "Yes") {
|
|
|
|
for(auto item : batched) {
|
|
|
|
string location = {program->statePath(), item.cell(0).text(), ".bst"};
|
|
|
|
file::remove(location);
|
|
|
|
}
|
|
|
|
loadStates();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|