mirror of
https://github.com/rizinorg/cutter.git
synced 2024-12-22 12:56:11 +00:00
Reset Settings for asm options (Fix #123)
This commit is contained in:
parent
7d9cfca2d8
commit
fde759b6ae
@ -21,19 +21,26 @@ AsmOptionsDialog::AsmOptionsDialog(QWidget *parent)
|
|||||||
ui->syntaxComboBox->addItem(syntax, syntax);
|
ui->syntaxComboBox->addItem(syntax, syntax);
|
||||||
ui->syntaxComboBox->blockSignals(false);
|
ui->syntaxComboBox->blockSignals(false);
|
||||||
|
|
||||||
QFont currentFont = Config()->getFont();
|
|
||||||
ui->fontSelectionLabel->setText(currentFont.toString());
|
|
||||||
|
|
||||||
// asm.offset=false would break reading the offset in DisassemblyWidget
|
// asm.offset=false would break reading the offset in DisassemblyWidget
|
||||||
// TODO: remove this when DisassemblyWidget::readDisassemblyOffset() allows it
|
// TODO: remove this when DisassemblyWidget::readDisassemblyOffset() allows it
|
||||||
ui->offsetCheckBox->setVisible(false);
|
ui->offsetCheckBox->setVisible(false);
|
||||||
|
|
||||||
updateFromVars();
|
updateAsmOptionsFromVars();
|
||||||
|
updateFontFromConfig();
|
||||||
|
|
||||||
|
connect(core, SIGNAL(asmOptionsChanged()), this, SLOT(updateAsmOptionsFromVars()));
|
||||||
|
connect(Config(), SIGNAL(fontsUpdated()), this, SLOT(updateFontFromConfig()));
|
||||||
}
|
}
|
||||||
|
|
||||||
AsmOptionsDialog::~AsmOptionsDialog() {}
|
AsmOptionsDialog::~AsmOptionsDialog() {}
|
||||||
|
|
||||||
void AsmOptionsDialog::updateFromVars()
|
void AsmOptionsDialog::updateFontFromConfig()
|
||||||
|
{
|
||||||
|
QFont currentFont = Config()->getFont();
|
||||||
|
ui->fontSelectionLabel->setText(currentFont.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
void AsmOptionsDialog::updateAsmOptionsFromVars()
|
||||||
{
|
{
|
||||||
qhelpers::setCheckedWithoutSignals(ui->esilCheckBox, core->getConfigb("asm.esil"));
|
qhelpers::setCheckedWithoutSignals(ui->esilCheckBox, core->getConfigb("asm.esil"));
|
||||||
qhelpers::setCheckedWithoutSignals(ui->pseudoCheckBox, core->getConfigb("asm.pseudo"));
|
qhelpers::setCheckedWithoutSignals(ui->pseudoCheckBox, core->getConfigb("asm.pseudo"));
|
||||||
@ -92,39 +99,46 @@ void AsmOptionsDialog::saveAsDefault()
|
|||||||
void AsmOptionsDialog::resetToDefault()
|
void AsmOptionsDialog::resetToDefault()
|
||||||
{
|
{
|
||||||
core->resetDefaultAsmOptions();
|
core->resetDefaultAsmOptions();
|
||||||
updateFromVars();
|
updateAsmOptionsFromVars();
|
||||||
|
triggerAsmOptionsChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
void AsmOptionsDialog::triggerAsmOptionsChanged()
|
||||||
|
{
|
||||||
|
disconnect(core, SIGNAL(asmOptionsChanged()), this, SLOT(updateAsmOptionsFromVars()));
|
||||||
core->triggerAsmOptionsChanged();
|
core->triggerAsmOptionsChanged();
|
||||||
|
connect(core, SIGNAL(asmOptionsChanged()), this, SLOT(updateAsmOptionsFromVars()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void AsmOptionsDialog::on_esilCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_esilCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.esil", checked);
|
core->setConfig("asm.esil", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_pseudoCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_pseudoCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.pseudo", checked);
|
core->setConfig("asm.pseudo", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_offsetCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_offsetCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.offset", checked);
|
core->setConfig("asm.offset", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_describeCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_describeCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.describe", checked);
|
core->setConfig("asm.describe", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_stackpointerCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_stackpointerCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.stackptr", checked);
|
core->setConfig("asm.stackptr", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_bytesCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_bytesCheckBox_toggled(bool checked)
|
||||||
@ -132,25 +146,25 @@ void AsmOptionsDialog::on_bytesCheckBox_toggled(bool checked)
|
|||||||
core->setConfig("asm.bytes", checked);
|
core->setConfig("asm.bytes", checked);
|
||||||
ui->bytespaceCheckBox->setEnabled(checked);
|
ui->bytespaceCheckBox->setEnabled(checked);
|
||||||
ui->lbytesCheckBox->setEnabled(checked);
|
ui->lbytesCheckBox->setEnabled(checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_bytespaceCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_bytespaceCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.bytespace", checked);
|
core->setConfig("asm.bytespace", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_lbytesCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_lbytesCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.lbytes", checked);
|
core->setConfig("asm.lbytes", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_syntaxComboBox_currentIndexChanged(int index)
|
void AsmOptionsDialog::on_syntaxComboBox_currentIndexChanged(int index)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.syntax", ui->syntaxComboBox->itemData(index).toString().toUtf8().constData());
|
core->setConfig("asm.syntax", ui->syntaxComboBox->itemData(index).toString().toUtf8().constData());
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_caseComboBox_currentIndexChanged(int index)
|
void AsmOptionsDialog::on_caseComboBox_currentIndexChanged(int index)
|
||||||
@ -182,26 +196,26 @@ void AsmOptionsDialog::on_caseComboBox_currentIndexChanged(int index)
|
|||||||
core->setConfig("asm.ucase", ucase);
|
core->setConfig("asm.ucase", ucase);
|
||||||
core->setConfig("asm.capitalize", capitalize);
|
core->setConfig("asm.capitalize", capitalize);
|
||||||
|
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_bblineCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_bblineCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.bbline", checked);
|
core->setConfig("asm.bbline", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_varsubCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_varsubCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.varsub", checked);
|
core->setConfig("asm.varsub", checked);
|
||||||
ui->varsubOnlyCheckBox->setEnabled(checked);
|
ui->varsubOnlyCheckBox->setEnabled(checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_varsubOnlyCheckBox_toggled(bool checked)
|
void AsmOptionsDialog::on_varsubOnlyCheckBox_toggled(bool checked)
|
||||||
{
|
{
|
||||||
core->setConfig("asm.varsub_only", checked);
|
core->setConfig("asm.varsub_only", checked);
|
||||||
core->triggerAsmOptionsChanged();
|
triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsmOptionsDialog::on_buttonBox_clicked(QAbstractButton *button)
|
void AsmOptionsDialog::on_buttonBox_clicked(QAbstractButton *button)
|
||||||
@ -226,6 +240,5 @@ void AsmOptionsDialog::on_fontSelectionButton_clicked()
|
|||||||
QFont newFont = QFontDialog::getFont(&ok, currentFont, this);
|
QFont newFont = QFontDialog::getFont(&ok, currentFont, this);
|
||||||
if (ok) {
|
if (ok) {
|
||||||
Config()->setFont(newFont);
|
Config()->setFont(newFont);
|
||||||
ui->fontSelectionLabel->setText(newFont.toString());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,11 +25,15 @@ private:
|
|||||||
CutterCore *core;
|
CutterCore *core;
|
||||||
std::unique_ptr<Ui::AsmOptionsDialog> ui;
|
std::unique_ptr<Ui::AsmOptionsDialog> ui;
|
||||||
|
|
||||||
void updateFromVars();
|
|
||||||
void saveAsDefault();
|
void saveAsDefault();
|
||||||
void resetToDefault();
|
void resetToDefault();
|
||||||
|
|
||||||
|
void triggerAsmOptionsChanged();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
void updateFontFromConfig();
|
||||||
|
void updateAsmOptionsFromVars();
|
||||||
|
|
||||||
void on_esilCheckBox_toggled(bool checked);
|
void on_esilCheckBox_toggled(bool checked);
|
||||||
void on_pseudoCheckBox_toggled(bool checked);
|
void on_pseudoCheckBox_toggled(bool checked);
|
||||||
void on_offsetCheckBox_toggled(bool checked);
|
void on_offsetCheckBox_toggled(bool checked);
|
||||||
|
@ -24,8 +24,13 @@ void Configuration::loadInitial()
|
|||||||
void Configuration::resetAll()
|
void Configuration::resetAll()
|
||||||
{
|
{
|
||||||
s.clear();
|
s.clear();
|
||||||
|
Core()->cmd("e-");
|
||||||
|
Core()->setSettings();
|
||||||
|
Core()->resetDefaultAsmOptions();
|
||||||
|
|
||||||
loadInitial();
|
loadInitial();
|
||||||
emit fontsUpdated();
|
emit fontsUpdated();
|
||||||
|
Core()->triggerAsmOptionsChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Configuration::loadDefaultTheme()
|
void Configuration::loadDefaultTheme()
|
||||||
|
Loading…
Reference in New Issue
Block a user