mirror of https://github.com/KLayout/klayout.git
Macro editor enhancements (stop on exceptions)
This commit tries to address #85 and provide these features: - dynamic configuration of the macro IDE behaviour - side effect: a new entry in the setup dialog for the IDE settings - "stop on exceptions" can be taught to ignore certain files
This commit is contained in:
parent
51e40cc9ab
commit
5fbc20702e
|
|
@ -1,7 +1,7 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<ui version="4.0">
|
||||
<class>MacroEditorSetupDialog</class>
|
||||
<widget class="QDialog" name="MacroEditorSetupDialog">
|
||||
<class>MacroEditorSetupPage</class>
|
||||
<widget class="QWidget" name="MacroEditorSetupPage">
|
||||
<property name="geometry">
|
||||
<rect>
|
||||
<x>0</x>
|
||||
|
|
@ -32,7 +32,7 @@
|
|||
<item>
|
||||
<widget class="QTabWidget" name="tabWidget">
|
||||
<property name="currentIndex">
|
||||
<number>0</number>
|
||||
<number>3</number>
|
||||
</property>
|
||||
<widget class="QWidget" name="tab_4">
|
||||
<attribute name="title">
|
||||
|
|
@ -452,10 +452,71 @@
|
|||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QCheckBox" name="stop_on_exception">
|
||||
<property name="text">
|
||||
<string>Ask whether to stop in debugger on exception</string>
|
||||
<widget class="QGroupBox" name="stop_on_exception">
|
||||
<property name="title">
|
||||
<string>As&k whether to stop in debugger on exception</string>
|
||||
</property>
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="checked">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_3">
|
||||
<item row="0" column="1">
|
||||
<widget class="QLabel" name="label_11">
|
||||
<property name="text">
|
||||
<string>Don't stop inside these files:</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignBottom|Qt::AlignLeading|Qt::AlignLeft</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="3">
|
||||
<widget class="QPushButton" name="clear_el">
|
||||
<property name="text">
|
||||
<string>Clear List</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<spacer name="horizontalSpacer">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="sizeType">
|
||||
<enum>QSizePolicy::Fixed</enum>
|
||||
</property>
|
||||
<property name="sizeHint" stdset="0">
|
||||
<size>
|
||||
<width>32</width>
|
||||
<height>20</height>
|
||||
</size>
|
||||
</property>
|
||||
</spacer>
|
||||
</item>
|
||||
<item row="0" column="2">
|
||||
<spacer name="horizontalSpacer_2">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="sizeHint" stdset="0">
|
||||
<size>
|
||||
<width>40</width>
|
||||
<height>20</height>
|
||||
</size>
|
||||
</property>
|
||||
</spacer>
|
||||
</item>
|
||||
<item row="1" column="1" colspan="3">
|
||||
<widget class="QListWidget" name="exception_list">
|
||||
<property name="selectionMode">
|
||||
<enum>QAbstractItemView::NoSelection</enum>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
|
|
@ -475,16 +536,6 @@
|
|||
</widget>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="standardButtons">
|
||||
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<customwidgets>
|
||||
|
|
@ -495,38 +546,5 @@
|
|||
</customwidget>
|
||||
</customwidgets>
|
||||
<resources/>
|
||||
<connections>
|
||||
<connection>
|
||||
<sender>buttonBox</sender>
|
||||
<signal>accepted()</signal>
|
||||
<receiver>MacroEditorSetupDialog</receiver>
|
||||
<slot>accept()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>248</x>
|
||||
<y>254</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>157</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>buttonBox</sender>
|
||||
<signal>rejected()</signal>
|
||||
<receiver>MacroEditorSetupDialog</receiver>
|
||||
<slot>reject()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>316</x>
|
||||
<y>260</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>286</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
</connections>
|
||||
<connections/>
|
||||
</ui>
|
||||
|
|
@ -20,7 +20,6 @@ HEADERS = \
|
|||
layLogViewerDialog.h \
|
||||
layMacroEditorDialog.h \
|
||||
layMacroEditorPage.h \
|
||||
layMacroEditorSetupDialog.h \
|
||||
layMacroEditorTree.h \
|
||||
layMacroPropertiesDialog.h \
|
||||
layMacroVariableView.h \
|
||||
|
|
@ -57,7 +56,8 @@ HEADERS = \
|
|||
layLibraryController.h \
|
||||
layFontController.h \
|
||||
layNativePlugin.h \
|
||||
laySystemPaths.h
|
||||
laySystemPaths.h \
|
||||
layMacroEditorSetupPage.h
|
||||
|
||||
FORMS = \
|
||||
ClipDialog.ui \
|
||||
|
|
@ -69,7 +69,6 @@ FORMS = \
|
|||
LayoutStatistics.ui \
|
||||
LogViewerDialog.ui \
|
||||
MacroEditorDialog.ui \
|
||||
MacroEditorSetupDialog.ui \
|
||||
MacroPropertiesDialog.ui \
|
||||
MacroTemplateSelectionDialog.ui \
|
||||
MainConfigPage.ui \
|
||||
|
|
@ -106,7 +105,8 @@ FORMS = \
|
|||
SaltGrainPropertiesDialog.ui \
|
||||
SaltGrainTemplateSelectionDialog.ui \
|
||||
SaltManagerInstallConfirmationDialog.ui \
|
||||
CustomizeMenuConfigPage.ui
|
||||
CustomizeMenuConfigPage.ui \
|
||||
MacroEditorSetupPage.ui
|
||||
|
||||
SOURCES = \
|
||||
gsiDeclLayApplication.cc \
|
||||
|
|
@ -125,7 +125,6 @@ SOURCES = \
|
|||
layLogViewerDialog.cc \
|
||||
layMacroEditorDialog.cc \
|
||||
layMacroEditorPage.cc \
|
||||
layMacroEditorSetupDialog.cc \
|
||||
layMacroEditorTree.cc \
|
||||
layMacroPropertiesDialog.cc \
|
||||
layMacroVariableView.cc \
|
||||
|
|
@ -161,7 +160,8 @@ SOURCES = \
|
|||
layLibraryController.cc \
|
||||
layFontController.cc \
|
||||
layNativePlugin.cc \
|
||||
laySystemPaths.cc
|
||||
laySystemPaths.cc \
|
||||
layMacroEditorSetupPage.cc
|
||||
|
||||
RESOURCES = layBuildInMacros.qrc \
|
||||
layHelpResources.qrc \
|
||||
|
|
|
|||
|
|
@ -22,10 +22,11 @@
|
|||
|
||||
|
||||
#include "ui_MacroTemplateSelectionDialog.h"
|
||||
#include "layConfigurationDialog.h"
|
||||
#include "layMacroController.h"
|
||||
#include "layMacroEditorTree.h"
|
||||
#include "layMacroEditorDialog.h"
|
||||
#include "layMacroEditorSetupDialog.h"
|
||||
#include "layMacroEditorSetupPage.h"
|
||||
#include "layMacroPropertiesDialog.h"
|
||||
#include "layFileDialog.h"
|
||||
#include "layMainWindow.h"
|
||||
|
|
@ -58,6 +59,9 @@
|
|||
#include <QHeaderView>
|
||||
#include <QResource>
|
||||
|
||||
namespace lay
|
||||
{
|
||||
|
||||
const std::string cfg_macro_editor_styles ("macro-editor-styles");
|
||||
const std::string cfg_macro_editor_save_all_on_run ("macro-editor-save-all-on-run");
|
||||
const std::string cfg_macro_editor_stop_on_exception ("macro-editor-stop-on-exception");
|
||||
|
|
@ -74,9 +78,7 @@ const std::string cfg_macro_editor_current_macro ("macro-editor-current-macro");
|
|||
const std::string cfg_macro_editor_active_macro ("macro-editor-active-macro");
|
||||
const std::string cfg_macro_editor_watch_expressions ("macro-editor-watch-expressions");
|
||||
const std::string cfg_macro_editor_debugging_enabled ("macro-editor-debugging-enabled");
|
||||
|
||||
namespace lay
|
||||
{
|
||||
const std::string cfg_macro_editor_ignore_exception_list ("macro-editor-ignore-exception-list");
|
||||
|
||||
// -----------------------------------------------------------------------------------------
|
||||
// Implementation of the macro template selection dialog
|
||||
|
|
@ -225,8 +227,10 @@ public:
|
|||
|
||||
static lay::MacroEditorDialog *s_macro_editor_instance = 0;
|
||||
|
||||
MacroEditorDialog::MacroEditorDialog (QWidget * /*parent*/, lym::MacroCollection *root)
|
||||
MacroEditorDialog::MacroEditorDialog (lay::MainWindow *mw, lym::MacroCollection *root)
|
||||
: QDialog (0 /*show as individual top widget*/, Qt::Window),
|
||||
lay::Plugin (mw, true),
|
||||
mp_plugin_root (mw),
|
||||
mp_root (root),
|
||||
m_first_show (true), m_in_processing (false), m_debugging_on (true),
|
||||
mp_run_macro (0),
|
||||
|
|
@ -245,6 +249,7 @@ MacroEditorDialog::MacroEditorDialog (QWidget * /*parent*/, lym::MacroCollection
|
|||
m_eval_context (-1),
|
||||
m_process_events_interval (0.0),
|
||||
m_window_closed (true),
|
||||
m_needs_update (true),
|
||||
m_ntab (8),
|
||||
m_nindent (2),
|
||||
m_save_all_on_run (false),
|
||||
|
|
@ -598,6 +603,8 @@ MacroEditorDialog::MacroEditorDialog (QWidget * /*parent*/, lym::MacroCollection
|
|||
if (! s_macro_editor_instance) {
|
||||
s_macro_editor_instance = this;
|
||||
}
|
||||
|
||||
config_setup ();
|
||||
}
|
||||
|
||||
MacroEditorDialog::~MacroEditorDialog ()
|
||||
|
|
@ -716,6 +723,113 @@ MacroEditorDialog::current_macro_tree ()
|
|||
return t;
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorDialog::config_finalize ()
|
||||
{
|
||||
if (m_needs_update) {
|
||||
|
||||
for (int i = 0; i < tabWidget->count (); ++i) {
|
||||
MacroEditorPage *page = dynamic_cast<MacroEditorPage *> (tabWidget->widget (i));
|
||||
if (page) {
|
||||
page->set_ntab (m_ntab);
|
||||
page->set_nindent (m_nindent);
|
||||
page->apply_attributes ();
|
||||
page->set_font (m_font_family, m_font_size);
|
||||
}
|
||||
}
|
||||
|
||||
refresh_file_watcher ();
|
||||
|
||||
m_needs_update = false;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
bool
|
||||
MacroEditorDialog::configure (const std::string &name, const std::string &value)
|
||||
{
|
||||
// Reads the dynamic configuration
|
||||
|
||||
if (name == cfg_macro_editor_styles) {
|
||||
|
||||
if (m_styles != value) {
|
||||
m_styles = value;
|
||||
m_needs_update = true;
|
||||
}
|
||||
m_highlighters.load (value);
|
||||
return true;
|
||||
|
||||
} else if (name == cfg_macro_editor_save_all_on_run) {
|
||||
tl::from_string (value, m_save_all_on_run);
|
||||
return true;
|
||||
} else if (name == cfg_macro_editor_stop_on_exception) {
|
||||
tl::from_string (value, m_stop_on_exception);
|
||||
return true;
|
||||
} else if (name == cfg_macro_editor_file_watcher_enabled) {
|
||||
|
||||
bool en = m_file_watcher_enabled;
|
||||
tl::from_string (value, en);
|
||||
if (en != m_file_watcher_enabled) {
|
||||
m_file_watcher_enabled = en;
|
||||
m_needs_update = true;
|
||||
}
|
||||
return true;
|
||||
|
||||
} else if (name == cfg_macro_editor_font_family) {
|
||||
|
||||
if (m_font_family != value) {
|
||||
m_font_family = value;
|
||||
m_needs_update = true;
|
||||
}
|
||||
return true;
|
||||
|
||||
} else if (name == cfg_macro_editor_font_size) {
|
||||
|
||||
int v = m_font_size;
|
||||
tl::from_string (value, v);
|
||||
if (v != m_font_size) {
|
||||
m_font_size = v;
|
||||
m_needs_update = true;
|
||||
}
|
||||
return true;
|
||||
|
||||
} else if (name == cfg_macro_editor_tab_width) {
|
||||
|
||||
int v = m_ntab;
|
||||
tl::from_string (value, v);
|
||||
if (v != m_ntab) {
|
||||
m_ntab = v;
|
||||
m_needs_update = true;
|
||||
}
|
||||
return true;
|
||||
|
||||
} else if (name == cfg_macro_editor_indent) {
|
||||
|
||||
int v = m_nindent;
|
||||
tl::from_string (value, v);
|
||||
if (v != m_nindent) {
|
||||
m_nindent = v;
|
||||
m_needs_update = true;
|
||||
}
|
||||
return true;
|
||||
|
||||
} else if (name == cfg_macro_editor_ignore_exception_list) {
|
||||
|
||||
m_ignore_exception_list.clear ();
|
||||
tl::Extractor ex (value.c_str ());
|
||||
while (! ex.at_end ()) {
|
||||
std::string f;
|
||||
ex.read_word_or_quoted (f);
|
||||
ex.test (";");
|
||||
m_ignore_exception_list.insert (f);
|
||||
}
|
||||
return true;
|
||||
|
||||
} else {
|
||||
return lay::Plugin::configure (name, value);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorDialog::showEvent (QShowEvent *)
|
||||
{
|
||||
|
|
@ -726,29 +840,19 @@ MacroEditorDialog::showEvent (QShowEvent *)
|
|||
|
||||
m_window_closed = false;
|
||||
|
||||
// read configuration
|
||||
std::string styles;
|
||||
if (MainWindow::instance ()->config_get (cfg_macro_editor_styles, styles)) {
|
||||
m_highlighters.load (styles);
|
||||
}
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_save_all_on_run, m_save_all_on_run);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_stop_on_exception, m_stop_on_exception);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_file_watcher_enabled, m_file_watcher_enabled);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_font_family, m_font_family);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_font_size, m_font_size);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_tab_width, m_ntab);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_indent, m_nindent);
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_debugging_enabled, m_debugging_on);
|
||||
// read debugger environment from configuration
|
||||
|
||||
mp_plugin_root->config_get (cfg_macro_editor_debugging_enabled, m_debugging_on);
|
||||
|
||||
std::string ws;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_window_state, ws);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_window_state, ws);
|
||||
lay::restore_dialog_state (this, ws);
|
||||
|
||||
input_field->clear ();
|
||||
|
||||
try {
|
||||
std::string hi;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_console_mru, hi);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_console_mru, hi);
|
||||
tl::Extractor ex (hi.c_str ());
|
||||
while (! ex.at_end ()) {
|
||||
std::string h;
|
||||
|
|
@ -770,7 +874,7 @@ MacroEditorDialog::showEvent (QShowEvent *)
|
|||
}
|
||||
|
||||
std::string ci;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_console_interpreter, ci);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_console_interpreter, ci);
|
||||
if (ci == "ruby") {
|
||||
pythonLangSel->setChecked (false);
|
||||
rubyLangSel->setChecked (true);
|
||||
|
|
@ -784,7 +888,7 @@ MacroEditorDialog::showEvent (QShowEvent *)
|
|||
m_watch_expressions.clear ();
|
||||
|
||||
std::string we;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_watch_expressions, we);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_watch_expressions, we);
|
||||
tl::Extractor ex (we.c_str ());
|
||||
while (! ex.at_end ()) {
|
||||
|
||||
|
|
@ -806,7 +910,7 @@ MacroEditorDialog::showEvent (QShowEvent *)
|
|||
|
||||
try {
|
||||
std::string om;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_open_macros, om);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_open_macros, om);
|
||||
tl::Extractor ex (om.c_str ());
|
||||
while (! ex.at_end ()) {
|
||||
std::string h;
|
||||
|
|
@ -818,7 +922,7 @@ MacroEditorDialog::showEvent (QShowEvent *)
|
|||
} catch (...) { }
|
||||
|
||||
std::string am;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_active_macro, am);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_active_macro, am);
|
||||
if (! am.empty ()) {
|
||||
lym::Macro *macro = mp_root->find_macro (am);
|
||||
if (macro) {
|
||||
|
|
@ -829,7 +933,7 @@ MacroEditorDialog::showEvent (QShowEvent *)
|
|||
dbgOn->setChecked (m_debugging_on);
|
||||
|
||||
std::string cm;
|
||||
MainWindow::instance ()->config_get (cfg_macro_editor_current_macro, cm);
|
||||
mp_plugin_root->config_get (cfg_macro_editor_current_macro, cm);
|
||||
if (! cm.empty ()) {
|
||||
// this will make that macro the current one
|
||||
editor_for_file (cm);
|
||||
|
|
@ -866,10 +970,10 @@ void
|
|||
MacroEditorDialog::closeEvent (QCloseEvent *)
|
||||
{
|
||||
// save the debugging enabled state
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_debugging_enabled, m_debugging_on);
|
||||
mp_plugin_root->config_set (cfg_macro_editor_debugging_enabled, m_debugging_on);
|
||||
|
||||
// save the window state
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_window_state, lay::save_dialog_state (this));
|
||||
mp_plugin_root->config_set (cfg_macro_editor_window_state, lay::save_dialog_state (this));
|
||||
|
||||
// save the console history (at maximum the last 200 entries)
|
||||
std::string hi;
|
||||
|
|
@ -879,7 +983,7 @@ MacroEditorDialog::closeEvent (QCloseEvent *)
|
|||
}
|
||||
hi += tl::to_quoted_string (tl::to_string (input_field->itemText (i)));
|
||||
}
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_console_mru, hi);
|
||||
mp_plugin_root->config_set (cfg_macro_editor_console_mru, hi);
|
||||
|
||||
// save the open macro list
|
||||
std::string om;
|
||||
|
|
@ -892,7 +996,7 @@ MacroEditorDialog::closeEvent (QCloseEvent *)
|
|||
om += tl::to_quoted_string (page->macro ()->path ());
|
||||
}
|
||||
}
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_open_macros, om);
|
||||
mp_plugin_root->config_set (cfg_macro_editor_open_macros, om);
|
||||
|
||||
// save the watch expressions
|
||||
std::string we;
|
||||
|
|
@ -908,15 +1012,15 @@ MacroEditorDialog::closeEvent (QCloseEvent *)
|
|||
we += ":";
|
||||
we += tl::to_quoted_string (i->second);
|
||||
}
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_watch_expressions, we);
|
||||
mp_plugin_root->config_set (cfg_macro_editor_watch_expressions, we);
|
||||
|
||||
// save the active (run) macro
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_active_macro, mp_run_macro ? mp_run_macro->path () : std::string ());
|
||||
mp_plugin_root->config_set (cfg_macro_editor_active_macro, mp_run_macro ? mp_run_macro->path () : std::string ());
|
||||
|
||||
// save the current macro
|
||||
MacroEditorPage *page = dynamic_cast<MacroEditorPage *> (tabWidget->currentWidget ());
|
||||
std::string cm = page && page->macro () ? page->macro ()->path () : std::string ();
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_current_macro, cm);
|
||||
mp_plugin_root->config_set (cfg_macro_editor_current_macro, cm);
|
||||
|
||||
// save the current interpreter in the console
|
||||
std::string ci;
|
||||
|
|
@ -925,7 +1029,7 @@ MacroEditorDialog::closeEvent (QCloseEvent *)
|
|||
} else if (pythonLangSel->isChecked ()) {
|
||||
ci = "python";
|
||||
}
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_console_interpreter, ci);
|
||||
mp_plugin_root->config_set (cfg_macro_editor_console_interpreter, ci);
|
||||
|
||||
// stop execution when the window is closed
|
||||
m_in_exec = false;
|
||||
|
|
@ -1914,73 +2018,9 @@ MacroEditorDialog::setup_button_clicked ()
|
|||
return;
|
||||
}
|
||||
|
||||
// fill data
|
||||
|
||||
lay::MacroEditorSetupDialogData data;
|
||||
data.tab_width = m_ntab;
|
||||
data.indent = m_nindent;
|
||||
data.save_all_on_run = m_save_all_on_run;
|
||||
data.stop_on_exception = m_stop_on_exception;
|
||||
data.file_watcher_enabled = m_file_watcher_enabled;
|
||||
data.font_family = m_font_family;
|
||||
data.font_size = m_font_size;
|
||||
|
||||
if (m_highlighters.basic_attributes ()) {
|
||||
data.basic_attributes.assign (*m_highlighters.basic_attributes ());
|
||||
}
|
||||
for (MacroEditorHighlighters::const_iterator a = m_highlighters.begin (); a != m_highlighters.end (); ++a) {
|
||||
data.specific_attributes.push_back (std::make_pair (a->first, GenericSyntaxHighlighterAttributes (& data.basic_attributes)));
|
||||
data.specific_attributes.back ().second.assign (a->second);
|
||||
}
|
||||
|
||||
lay::MacroEditorSetupDialog dialog (this);
|
||||
if (dialog.exec_dialog (data)) {
|
||||
|
||||
m_ntab = data.tab_width;
|
||||
m_nindent = data.indent;
|
||||
m_stop_on_exception = data.stop_on_exception;
|
||||
m_file_watcher_enabled = data.file_watcher_enabled;
|
||||
m_font_family = data.font_family;
|
||||
m_font_size = data.font_size;
|
||||
|
||||
if (m_highlighters.basic_attributes ()) {
|
||||
m_highlighters.basic_attributes ()->assign (data.basic_attributes);
|
||||
}
|
||||
|
||||
for (MacroEditorHighlighters::iterator a = m_highlighters.begin (); a != m_highlighters.end (); ++a) {
|
||||
for (std::vector< std::pair<std::string, GenericSyntaxHighlighterAttributes> >::const_iterator i = data.specific_attributes.begin (); i != data.specific_attributes.end (); ++i) {
|
||||
if (i->first == a->first) {
|
||||
a->second.assign (i->second);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
m_save_all_on_run = data.save_all_on_run;
|
||||
|
||||
for (int i = 0; i < tabWidget->count (); ++i) {
|
||||
MacroEditorPage *page = dynamic_cast<MacroEditorPage *> (tabWidget->widget (i));
|
||||
if (page) {
|
||||
page->set_ntab (m_ntab);
|
||||
page->set_nindent (m_nindent);
|
||||
page->apply_attributes ();
|
||||
page->set_font (m_font_family, m_font_size);
|
||||
}
|
||||
}
|
||||
|
||||
// write configuration
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_styles, m_highlighters.to_string ());
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_save_all_on_run, m_save_all_on_run);
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_file_watcher_enabled, m_file_watcher_enabled);
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_stop_on_exception, m_stop_on_exception);
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_tab_width, m_ntab);
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_indent, m_nindent);
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_font_family, m_font_family);
|
||||
MainWindow::instance ()->config_set (cfg_macro_editor_font_size, m_font_size);
|
||||
MainWindow::instance ()->config_end ();
|
||||
|
||||
lay::ConfigurationDialog config_dialog (this, mp_plugin_root, "MacroEditor");
|
||||
if (config_dialog.exec ()) {
|
||||
refresh_file_watcher ();
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -2253,12 +2293,12 @@ MacroEditorDialog::ensure_writeable_collection_selected ()
|
|||
}
|
||||
|
||||
static std::vector<std::pair<std::string, std::string> >
|
||||
get_custom_paths ()
|
||||
get_custom_paths (lay::PluginRoot *root)
|
||||
{
|
||||
std::vector <std::pair<std::string, std::string> > paths;
|
||||
|
||||
std::string mp;
|
||||
MainWindow::instance ()->config_get (cfg_custom_macro_paths, mp);
|
||||
root->config_get (cfg_custom_macro_paths, mp);
|
||||
|
||||
try {
|
||||
|
||||
|
|
@ -2281,7 +2321,7 @@ get_custom_paths ()
|
|||
}
|
||||
|
||||
static void
|
||||
set_custom_paths (const std::vector<std::pair<std::string, std::string> > &paths)
|
||||
set_custom_paths (lay::PluginRoot *root, const std::vector<std::pair<std::string, std::string> > &paths)
|
||||
{
|
||||
std::string mp;
|
||||
|
||||
|
|
@ -2295,7 +2335,7 @@ set_custom_paths (const std::vector<std::pair<std::string, std::string> > &paths
|
|||
mp += p->second;
|
||||
}
|
||||
|
||||
MainWindow::instance ()->config_set (cfg_custom_macro_paths, mp);
|
||||
root->config_set (cfg_custom_macro_paths, mp);
|
||||
}
|
||||
|
||||
void
|
||||
|
|
@ -2494,7 +2534,7 @@ BEGIN_PROTECTED
|
|||
|
||||
std::string cat = current_macro_tree ()->category ();
|
||||
|
||||
std::vector <std::pair<std::string, std::string> > paths = get_custom_paths ();
|
||||
std::vector <std::pair<std::string, std::string> > paths = get_custom_paths (mp_plugin_root);
|
||||
std::string new_path = tl::to_string (QFileInfo (new_dir).absoluteFilePath ());
|
||||
paths.push_back (std::make_pair (new_path, cat));
|
||||
|
||||
|
|
@ -2503,7 +2543,7 @@ BEGIN_PROTECTED
|
|||
throw tl::Exception (tl::to_string (QObject::tr ("The selected directory is already installed as custom location")));
|
||||
}
|
||||
|
||||
set_custom_paths (paths);
|
||||
set_custom_paths (mp_plugin_root, paths);
|
||||
|
||||
if (c->has_autorun ()) {
|
||||
if (QMessageBox::question (this, QObject::tr ("Run Macros"), QObject::tr ("The selected folder has macros configured to run automatically.\n\nChoose 'Yes' to run these macros now. Choose 'No' to not run them."), QMessageBox::Yes | QMessageBox::No) == QMessageBox::Yes) {
|
||||
|
|
@ -2538,7 +2578,7 @@ BEGIN_PROTECTED
|
|||
throw tl::Exception (tl::to_string (QObject::tr ("Select tree location to remove")));
|
||||
}
|
||||
|
||||
std::vector <std::pair <std::string, std::string> > paths = get_custom_paths ();
|
||||
std::vector <std::pair <std::string, std::string> > paths = get_custom_paths (mp_plugin_root);
|
||||
|
||||
bool found = false;
|
||||
|
||||
|
|
@ -2560,7 +2600,7 @@ BEGIN_PROTECTED
|
|||
mp_root->erase (collection);
|
||||
|
||||
// save the new paths
|
||||
set_custom_paths (paths);
|
||||
set_custom_paths (mp_plugin_root, paths);
|
||||
|
||||
END_PROTECTED
|
||||
}
|
||||
|
|
@ -2809,10 +2849,34 @@ MacroEditorDialog::exception_thrown (gsi::Interpreter *interpreter, size_t file_
|
|||
return;
|
||||
}
|
||||
|
||||
if (QMessageBox::critical (this, QObject::tr ("Exception Caught"),
|
||||
tl::to_qstring (tl::to_string (QObject::tr ("Caught the following exception:\n")) + emsg + " (Class " + eclass + ")\n\n" + tl::to_string (QObject::tr ("Press 'Ok' to continue and 'Cancel' to stop in the debugger"))),
|
||||
QMessageBox::Cancel, QMessageBox::Ok) == QMessageBox::Ok) {
|
||||
std::string p;
|
||||
if (file_id > 0 && file_id <= m_file_to_widget.size () && m_file_to_widget [file_id - 1].first) {
|
||||
p = m_file_to_widget [file_id - 1].first->path ();
|
||||
if (m_ignore_exception_list.find (p) != m_ignore_exception_list.end ()) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
int res = QMessageBox::critical (this, QObject::tr ("Exception Caught"),
|
||||
tl::to_qstring (tl::to_string (QObject::tr ("Caught the following exception:\n")) + emsg + " (Class " + eclass + ")\n\n" + tl::to_string (QObject::tr ("Press 'Ok' to continue.\nPress 'Ignore' to ignore this and future exceptions from this file.\nPress 'Cancel' to stop in the debugger"))),
|
||||
QMessageBox::Cancel | QMessageBox::Ok | QMessageBox::Ignore,
|
||||
QMessageBox::Ok);
|
||||
|
||||
if (res == QMessageBox::Ok) {
|
||||
|
||||
return;
|
||||
|
||||
} else if (res == QMessageBox::Ignore) {
|
||||
|
||||
std::string il;
|
||||
il += tl::to_quoted_string (p);
|
||||
for (std::set<std::string>::const_iterator i = m_ignore_exception_list.begin (); i != m_ignore_exception_list.end (); ++i) {
|
||||
il += ";";
|
||||
il += tl::to_quoted_string (*i);
|
||||
}
|
||||
mp_plugin_root->config_set (cfg_macro_editor_ignore_exception_list, il);
|
||||
return;
|
||||
|
||||
}
|
||||
|
||||
write_str (emsg.c_str (), OS_stderr);
|
||||
|
|
@ -3399,6 +3463,12 @@ class MacroEditorPluginDeclaration
|
|||
: public lay::PluginDeclaration
|
||||
{
|
||||
public:
|
||||
virtual lay::ConfigPage *config_page (QWidget *parent, std::string &title) const
|
||||
{
|
||||
title = tl::to_string (QObject::tr ("Application|Macro Development IDE"));
|
||||
return new MacroEditorSetupPage (parent);
|
||||
}
|
||||
|
||||
virtual void get_options (std::vector < std::pair<std::string, std::string> > &options) const
|
||||
{
|
||||
options.push_back (std::pair<std::string, std::string> (cfg_macro_editor_styles, ""));
|
||||
|
|
|
|||
|
|
@ -29,6 +29,7 @@
|
|||
#include "ui_MacroEditorDialog.h"
|
||||
#include "layMacroEditorPage.h"
|
||||
#include "layMacroController.h"
|
||||
#include "layPlugin.h"
|
||||
#include "tlDeferredExecution.h"
|
||||
#include "tlTimer.h"
|
||||
#include "tlFileSystemWatcher.h"
|
||||
|
|
@ -50,11 +51,34 @@ class QTreeWidgetItem;
|
|||
namespace lay
|
||||
{
|
||||
|
||||
extern const std::string cfg_macro_editor_styles;
|
||||
extern const std::string cfg_macro_editor_save_all_on_run;
|
||||
extern const std::string cfg_macro_editor_stop_on_exception;
|
||||
extern const std::string cfg_macro_editor_file_watcher_enabled;
|
||||
extern const std::string cfg_macro_editor_font_family;
|
||||
extern const std::string cfg_macro_editor_font_size;
|
||||
extern const std::string cfg_macro_editor_tab_width;
|
||||
extern const std::string cfg_macro_editor_indent;
|
||||
extern const std::string cfg_macro_editor_window_state;
|
||||
extern const std::string cfg_macro_editor_console_mru;
|
||||
extern const std::string cfg_macro_editor_console_interpreter;
|
||||
extern const std::string cfg_macro_editor_open_macros;
|
||||
extern const std::string cfg_macro_editor_current_macro;
|
||||
extern const std::string cfg_macro_editor_active_macro;
|
||||
extern const std::string cfg_macro_editor_watch_expressions;
|
||||
extern const std::string cfg_macro_editor_debugging_enabled;
|
||||
extern const std::string cfg_macro_editor_ignore_exception_list;
|
||||
|
||||
class MacroEditorTree;
|
||||
class BrowserPanel;
|
||||
class MainWindow;
|
||||
|
||||
class MacroEditorDialog
|
||||
: public QDialog, public gsi::Console, private Ui::MacroEditorDialog, public gsi::ExecutionHandler
|
||||
: public QDialog,
|
||||
public lay::Plugin,
|
||||
public gsi::Console,
|
||||
public gsi::ExecutionHandler,
|
||||
private Ui::MacroEditorDialog
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
|
|
@ -74,7 +98,7 @@ public:
|
|||
/**
|
||||
* @brief Constructor
|
||||
*/
|
||||
MacroEditorDialog (QWidget *parent, lym::MacroCollection *root);
|
||||
MacroEditorDialog (lay::MainWindow *parent, lym::MacroCollection *root);
|
||||
|
||||
/**
|
||||
* @brief Destructor
|
||||
|
|
@ -262,7 +286,10 @@ private:
|
|||
lym::Macro *new_macro ();
|
||||
void do_search_edited ();
|
||||
void select_trace (size_t index);
|
||||
bool configure (const std::string &name, const std::string &value);
|
||||
void config_finalize ();
|
||||
|
||||
lay::PluginRoot *mp_plugin_root;
|
||||
lym::MacroCollection *mp_root;
|
||||
bool m_first_show;
|
||||
bool m_in_processing;
|
||||
|
|
@ -294,10 +321,13 @@ private:
|
|||
double m_process_events_interval;
|
||||
tl::Clock m_last_process_events;
|
||||
bool m_window_closed;
|
||||
bool m_needs_update;
|
||||
std::string m_styles;
|
||||
int m_ntab;
|
||||
int m_nindent;
|
||||
bool m_save_all_on_run;
|
||||
bool m_stop_on_exception;
|
||||
std::set<std::string> m_ignore_exception_list;
|
||||
bool m_file_watcher_enabled;
|
||||
std::string m_font_family;
|
||||
int m_font_size;
|
||||
|
|
|
|||
|
|
@ -21,15 +21,114 @@
|
|||
*/
|
||||
|
||||
|
||||
#include "layMacroEditorSetupDialog.h"
|
||||
#include "layMacroEditorSetupPage.h"
|
||||
#include "layMacroEditorPage.h"
|
||||
#include "layMacroEditorDialog.h"
|
||||
#include "layGenericSyntaxHighlighter.h"
|
||||
|
||||
#include "lymMacro.h"
|
||||
|
||||
#include "tlString.h"
|
||||
|
||||
#include <vector>
|
||||
#include <cstdio>
|
||||
|
||||
namespace lay
|
||||
{
|
||||
|
||||
struct MacroEditorSetupDialogData
|
||||
{
|
||||
MacroEditorSetupDialogData ()
|
||||
: basic_attributes (0), tab_width (8), indent (2), save_all_on_run (true), stop_on_exception (true), file_watcher_enabled (true), font_size (0)
|
||||
{
|
||||
}
|
||||
|
||||
GenericSyntaxHighlighterAttributes basic_attributes;
|
||||
std::vector <std::pair <std::string, GenericSyntaxHighlighterAttributes> > specific_attributes;
|
||||
int tab_width;
|
||||
int indent;
|
||||
bool save_all_on_run;
|
||||
bool stop_on_exception;
|
||||
bool file_watcher_enabled;
|
||||
std::string font_family;
|
||||
int font_size;
|
||||
std::set <std::string> ignore_exceptions_list;
|
||||
|
||||
void setup (lay::PluginRoot *root)
|
||||
{
|
||||
lay::MacroEditorHighlighters highlighters (0);
|
||||
std::string styles;
|
||||
root->config_get (cfg_macro_editor_styles, styles);
|
||||
highlighters.load (styles);
|
||||
|
||||
if (highlighters.basic_attributes ()) {
|
||||
basic_attributes.assign (*highlighters.basic_attributes ());
|
||||
}
|
||||
for (lay::MacroEditorHighlighters::const_iterator a = highlighters.begin (); a != highlighters.end (); ++a) {
|
||||
specific_attributes.push_back (std::make_pair (a->first, GenericSyntaxHighlighterAttributes (& basic_attributes)));
|
||||
specific_attributes.back ().second.assign (a->second);
|
||||
}
|
||||
|
||||
root->config_get (cfg_macro_editor_save_all_on_run, save_all_on_run);
|
||||
root->config_get (cfg_macro_editor_file_watcher_enabled, file_watcher_enabled);
|
||||
root->config_get (cfg_macro_editor_stop_on_exception, stop_on_exception);
|
||||
root->config_get (cfg_macro_editor_tab_width, tab_width);
|
||||
root->config_get (cfg_macro_editor_indent, indent);
|
||||
root->config_get (cfg_macro_editor_font_family, font_family);
|
||||
root->config_get (cfg_macro_editor_font_size, font_size);
|
||||
|
||||
std::string il;
|
||||
root->config_get (cfg_macro_editor_ignore_exception_list, il);
|
||||
ignore_exceptions_list.clear ();
|
||||
tl::Extractor ex (il.c_str ());
|
||||
while (! ex.at_end ()) {
|
||||
std::string f;
|
||||
ex.read_word_or_quoted (f);
|
||||
ex.test (";");
|
||||
ignore_exceptions_list.insert (f);
|
||||
}
|
||||
}
|
||||
|
||||
void commit (lay::PluginRoot *root)
|
||||
{
|
||||
lay::MacroEditorHighlighters highlighters (0);
|
||||
|
||||
if (highlighters.basic_attributes ()) {
|
||||
highlighters.basic_attributes ()->assign (basic_attributes);
|
||||
}
|
||||
|
||||
for (MacroEditorHighlighters::iterator a = highlighters.begin (); a != highlighters.end (); ++a) {
|
||||
for (std::vector< std::pair<std::string, GenericSyntaxHighlighterAttributes> >::const_iterator i = specific_attributes.begin (); i != specific_attributes.end (); ++i) {
|
||||
if (i->first == a->first) {
|
||||
a->second.assign (i->second);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// write configuration
|
||||
|
||||
root->config_set (cfg_macro_editor_styles, highlighters.to_string ());
|
||||
root->config_set (cfg_macro_editor_save_all_on_run, save_all_on_run);
|
||||
root->config_set (cfg_macro_editor_file_watcher_enabled, file_watcher_enabled);
|
||||
root->config_set (cfg_macro_editor_stop_on_exception, stop_on_exception);
|
||||
root->config_set (cfg_macro_editor_tab_width, tab_width);
|
||||
root->config_set (cfg_macro_editor_indent, indent);
|
||||
root->config_set (cfg_macro_editor_font_family, font_family);
|
||||
root->config_set (cfg_macro_editor_font_size, font_size);
|
||||
|
||||
std::string il;
|
||||
for (std::set<std::string>::const_iterator i = ignore_exceptions_list.begin (); i != ignore_exceptions_list.end (); ++i) {
|
||||
if (! il.empty ()) {
|
||||
il += ";";
|
||||
}
|
||||
il += tl::to_quoted_string (*i);
|
||||
}
|
||||
root->config_set (cfg_macro_editor_ignore_exception_list, il);
|
||||
|
||||
}
|
||||
};
|
||||
|
||||
static void
|
||||
update_item (QListWidgetItem *item, QTextCharFormat format)
|
||||
{
|
||||
|
|
@ -38,8 +137,8 @@ update_item (QListWidgetItem *item, QTextCharFormat format)
|
|||
item->setData (Qt::BackgroundRole, format.background ());
|
||||
}
|
||||
|
||||
MacroEditorSetupDialog::MacroEditorSetupDialog (QWidget *parent)
|
||||
: QDialog (parent), mp_data (0)
|
||||
MacroEditorSetupPage::MacroEditorSetupPage (QWidget *parent)
|
||||
: lay::ConfigPage (parent), mp_data (0)
|
||||
{
|
||||
setupUi (this);
|
||||
|
||||
|
|
@ -52,22 +151,49 @@ MacroEditorSetupDialog::MacroEditorSetupDialog (QWidget *parent)
|
|||
connect (background_color_button, SIGNAL (color_changed (QColor)), this, SLOT (color_changed (QColor)));
|
||||
connect (font_sel, SIGNAL (currentFontChanged (const QFont &)), this, SLOT (update_font ()));
|
||||
connect (font_size, SIGNAL (valueChanged (int)), this, SLOT (update_font ()));
|
||||
connect (clear_el, SIGNAL (clicked ()), this, SLOT (clear_exception_list ()));
|
||||
}
|
||||
|
||||
MacroEditorSetupPage::~MacroEditorSetupPage ()
|
||||
{
|
||||
delete mp_data;
|
||||
mp_data = 0;
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupDialog::color_changed (QColor)
|
||||
MacroEditorSetupPage::color_changed (QColor)
|
||||
{
|
||||
commit_attributes (styles_list->currentItem ());
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupDialog::cb_changed (int)
|
||||
MacroEditorSetupPage::cb_changed (int)
|
||||
{
|
||||
commit_attributes (styles_list->currentItem ());
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupPage::clear_exception_list ()
|
||||
{
|
||||
if (mp_data) {
|
||||
mp_data->ignore_exceptions_list.clear ();
|
||||
update_ignore_exception_list ();
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupPage::update_ignore_exception_list ()
|
||||
{
|
||||
if (mp_data) {
|
||||
exception_list->clear ();
|
||||
for (std::set<std::string>::const_iterator i = mp_data->ignore_exceptions_list.begin (); i != mp_data->ignore_exceptions_list.end (); ++i) {
|
||||
exception_list->addItem (tl::to_qstring (*i));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupDialog::update_font ()
|
||||
MacroEditorSetupPage::update_font ()
|
||||
{
|
||||
QFont f;
|
||||
f.setFamily (font_sel->currentFont().family ());
|
||||
|
|
@ -76,26 +202,30 @@ MacroEditorSetupDialog::update_font ()
|
|||
styles_list->setFont (f);
|
||||
}
|
||||
|
||||
int
|
||||
MacroEditorSetupDialog::exec_dialog (MacroEditorSetupDialogData &data)
|
||||
void
|
||||
MacroEditorSetupPage::setup (PluginRoot *root)
|
||||
{
|
||||
mp_data = &data;
|
||||
delete mp_data;
|
||||
mp_data = new MacroEditorSetupDialogData ();
|
||||
mp_data->setup (root);
|
||||
|
||||
tab_width->setValue (data.tab_width);
|
||||
indent->setValue (data.indent);
|
||||
save_all_cb->setChecked (data.save_all_on_run);
|
||||
stop_on_exception->setChecked (data.stop_on_exception);
|
||||
watch_files->setChecked (data.file_watcher_enabled);
|
||||
update_ignore_exception_list ();
|
||||
|
||||
if (data.font_size <= 0) {
|
||||
data.font_size = font ().pointSize ();
|
||||
data.font_family = "Monospace";
|
||||
tab_width->setValue (mp_data->tab_width);
|
||||
indent->setValue (mp_data->indent);
|
||||
save_all_cb->setChecked (mp_data->save_all_on_run);
|
||||
stop_on_exception->setChecked (mp_data->stop_on_exception);
|
||||
watch_files->setChecked (mp_data->file_watcher_enabled);
|
||||
|
||||
if (mp_data->font_size <= 0) {
|
||||
mp_data->font_size = font ().pointSize ();
|
||||
mp_data->font_family = "Monospace";
|
||||
}
|
||||
|
||||
QFont f;
|
||||
f.setFamily (tl::to_qstring (data.font_family));
|
||||
f.setFamily (tl::to_qstring (mp_data->font_family));
|
||||
font_sel->setCurrentFont (f);
|
||||
font_size->setValue (data.font_size);
|
||||
font_size->setValue (mp_data->font_size);
|
||||
|
||||
styles_list->blockSignals (true);
|
||||
|
||||
|
|
@ -103,18 +233,18 @@ MacroEditorSetupDialog::exec_dialog (MacroEditorSetupDialogData &data)
|
|||
|
||||
std::map <int, QString> basic_names;
|
||||
|
||||
for (GenericSyntaxHighlighterAttributes::const_iterator a = data.basic_attributes.begin (); a != data.basic_attributes.end (); ++a) {
|
||||
for (GenericSyntaxHighlighterAttributes::const_iterator a = mp_data->basic_attributes.begin (); a != mp_data->basic_attributes.end (); ++a) {
|
||||
QListWidgetItem *item = new QListWidgetItem (styles_list);
|
||||
QString n = tl::to_qstring (tl::to_string (QObject::tr ("(basic)")) + " ") + a->first;
|
||||
item->setText (n);
|
||||
item->setData (Qt::UserRole, -1);
|
||||
item->setData (Qt::UserRole + 1, a->second);
|
||||
basic_names.insert (std::make_pair (a->second, n));
|
||||
update_item (item, data.basic_attributes.format_for (a->second));
|
||||
update_item (item, mp_data->basic_attributes.format_for (a->second));
|
||||
}
|
||||
|
||||
int na = 0;
|
||||
for (std::vector <std::pair <std::string, GenericSyntaxHighlighterAttributes> >::const_iterator sa = data.specific_attributes.begin (); sa != data.specific_attributes.end (); ++sa, ++na) {
|
||||
for (std::vector <std::pair <std::string, GenericSyntaxHighlighterAttributes> >::const_iterator sa = mp_data->specific_attributes.begin (); sa != mp_data->specific_attributes.end (); ++sa, ++na) {
|
||||
|
||||
QString l = tl::to_qstring ("(" + sa->first + ") ");
|
||||
|
||||
|
|
@ -137,30 +267,32 @@ MacroEditorSetupDialog::exec_dialog (MacroEditorSetupDialogData &data)
|
|||
|
||||
update_attributes (styles_list->currentItem ());
|
||||
update_font ();
|
||||
}
|
||||
|
||||
int r = QDialog::exec ();
|
||||
if (r) {
|
||||
|
||||
if (styles_list->currentItem ()) {
|
||||
commit_attributes (styles_list->currentItem ());
|
||||
}
|
||||
|
||||
data.tab_width = tab_width->value ();
|
||||
data.indent = indent->value ();
|
||||
data.save_all_on_run = save_all_cb->isChecked ();
|
||||
data.stop_on_exception = stop_on_exception->isChecked ();
|
||||
data.file_watcher_enabled = watch_files->isChecked ();
|
||||
|
||||
data.font_family = tl::to_string (font_sel->currentFont ().family ());
|
||||
data.font_size = font_size->value ();
|
||||
|
||||
void
|
||||
MacroEditorSetupPage::commit (PluginRoot *root)
|
||||
{
|
||||
if (styles_list->currentItem ()) {
|
||||
commit_attributes (styles_list->currentItem ());
|
||||
}
|
||||
|
||||
return r;
|
||||
if (mp_data) {
|
||||
|
||||
mp_data->tab_width = tab_width->value ();
|
||||
mp_data->indent = indent->value ();
|
||||
mp_data->save_all_on_run = save_all_cb->isChecked ();
|
||||
mp_data->stop_on_exception = stop_on_exception->isChecked ();
|
||||
mp_data->file_watcher_enabled = watch_files->isChecked ();
|
||||
|
||||
mp_data->font_family = tl::to_string (font_sel->currentFont ().family ());
|
||||
mp_data->font_size = font_size->value ();
|
||||
|
||||
mp_data->commit (root);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupDialog::current_attribute_changed (QListWidgetItem *current, QListWidgetItem *previous)
|
||||
MacroEditorSetupPage::current_attribute_changed (QListWidgetItem *current, QListWidgetItem *previous)
|
||||
{
|
||||
if (previous) {
|
||||
commit_attributes (previous);
|
||||
|
|
@ -170,7 +302,7 @@ MacroEditorSetupDialog::current_attribute_changed (QListWidgetItem *current, QLi
|
|||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupDialog::commit_attributes (QListWidgetItem *to_item)
|
||||
MacroEditorSetupPage::commit_attributes (QListWidgetItem *to_item)
|
||||
{
|
||||
if (! to_item) {
|
||||
return;
|
||||
|
|
@ -252,7 +384,7 @@ MacroEditorSetupDialog::commit_attributes (QListWidgetItem *to_item)
|
|||
}
|
||||
|
||||
void
|
||||
MacroEditorSetupDialog::update_attributes (QListWidgetItem *from_item)
|
||||
MacroEditorSetupPage::update_attributes (QListWidgetItem *from_item)
|
||||
{
|
||||
if (from_item) {
|
||||
|
||||
|
|
@ -21,60 +21,43 @@
|
|||
*/
|
||||
|
||||
|
||||
#ifndef HDR_layMacroEditorSetupDialog
|
||||
#define HDR_layMacroEditorSetupDialog
|
||||
#ifndef HDR_layMacroEditorSetupPage
|
||||
#define HDR_layMacroEditorSetupPage
|
||||
|
||||
#include "layGenericSyntaxHighlighter.h"
|
||||
#include "lymMacro.h"
|
||||
#include "ui_MacroEditorSetupDialog.h"
|
||||
|
||||
#include <QDialog>
|
||||
|
||||
#include <vector>
|
||||
#include "layPlugin.h"
|
||||
#include "ui_MacroEditorSetupPage.h"
|
||||
|
||||
namespace lay
|
||||
{
|
||||
|
||||
struct MacroEditorSetupDialogData
|
||||
{
|
||||
MacroEditorSetupDialogData ()
|
||||
: basic_attributes (0), tab_width (8), indent (2), save_all_on_run (true), stop_on_exception (true), file_watcher_enabled (true), font_size (0)
|
||||
{
|
||||
}
|
||||
|
||||
GenericSyntaxHighlighterAttributes basic_attributes;
|
||||
std::vector <std::pair <std::string, GenericSyntaxHighlighterAttributes> > specific_attributes;
|
||||
int tab_width;
|
||||
int indent;
|
||||
bool save_all_on_run;
|
||||
bool stop_on_exception;
|
||||
bool file_watcher_enabled;
|
||||
std::string font_family;
|
||||
int font_size;
|
||||
};
|
||||
struct MacroEditorSetupDialogData;
|
||||
|
||||
/**
|
||||
* @brief The dialog for editing the properties of the debugger/editor
|
||||
*/
|
||||
class MacroEditorSetupDialog
|
||||
: public QDialog, private Ui::MacroEditorSetupDialog
|
||||
class MacroEditorSetupPage
|
||||
: public lay::ConfigPage, private Ui::MacroEditorSetupPage
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
MacroEditorSetupDialog (QWidget *parent);
|
||||
MacroEditorSetupPage (QWidget *parent);
|
||||
~MacroEditorSetupPage ();
|
||||
|
||||
int exec_dialog (MacroEditorSetupDialogData &data);
|
||||
virtual void setup (PluginRoot *root);
|
||||
virtual void commit (PluginRoot *root);
|
||||
|
||||
protected slots:
|
||||
void current_attribute_changed (QListWidgetItem *current, QListWidgetItem *previous);
|
||||
void cb_changed (int n);
|
||||
void color_changed (QColor c);
|
||||
void update_font ();
|
||||
void clear_exception_list ();
|
||||
|
||||
private:
|
||||
void commit_attributes (QListWidgetItem *to_item);
|
||||
void update_attributes (QListWidgetItem *from_item);
|
||||
void update_ignore_exception_list ();
|
||||
|
||||
MacroEditorSetupDialogData *mp_data;
|
||||
};
|
||||
Loading…
Reference in New Issue