diff --git a/Common/GmshMessage.cpp b/Common/GmshMessage.cpp index 3cd9d08536be92b6d9fccbbf3ecbe4896a921701..caaa02b8e7e1e0b51266dcb03a00004f2555b36a 100644 --- a/Common/GmshMessage.cpp +++ b/Common/GmshMessage.cpp @@ -778,6 +778,7 @@ static void _setStandardOptions(onelab::parameter *p, if(copt.count("Highlight")) p->setAttribute("Highlight", copt["Highlight"][0]); if(copt.count("AutoCheck")) p->setAttribute("AutoCheck", copt["AutoCheck"][0]); if(copt.count("Macro")) p->setAttribute("Macro", copt["Macro"][0]); + if(copt.count("GmshOption")) p->setAttribute("GmshOption", copt["GmshOption"][0]); } static std::string _getParameterName(const std::string &key, diff --git a/Fltk/onelabGroup.cpp b/Fltk/onelabGroup.cpp index bff60f9f4bb344f96027d253ad382b5f38d74ff6..57ff593b2a6fa07dc6dbe96f49fbc15643e2b739 100644 --- a/Fltk/onelabGroup.cpp +++ b/Fltk/onelabGroup.cpp @@ -27,6 +27,7 @@ typedef unsigned long intptr_t; #include "graphicWindow.h" #include "fileDialogs.h" #include "onelabGroup.h" +#include "Gmsh.h" #include "FlGui.h" #include "Context.h" #include "GModel.h" @@ -853,6 +854,16 @@ viewButton *onelabGroup::getViewButton(int num) return 0; } +static void setGmshOption(onelab::number &n) +{ + std::string opt = n.getAttribute("GmshOption"); + if(opt.empty()) return; + std::string::size_type dot = opt.find('.'); + if(dot == std::string::npos) return; + GmshSetOption(opt.substr(0, dot), opt.substr(dot + 1), n.getValue()); + drawContext::global()->draw(); +} + static void onelab_number_check_button_cb(Fl_Widget *w, void *data) { if(!data) return; @@ -864,6 +875,7 @@ static void onelab_number_check_button_cb(Fl_Widget *w, void *data) onelab::number old = numbers[0]; numbers[0].setValue(o->value()); onelab::server::instance()->set(numbers[0]); + setGmshOption(numbers[0]); autoCheck(old, numbers[0]); } } @@ -880,6 +892,7 @@ static void onelab_number_choice_cb(Fl_Widget *w, void *data) onelab::number old = numbers[0]; if(o->value() < (int)choices.size()) numbers[0].setValue(choices[o->value()]); onelab::server::instance()->set(numbers[0]); + setGmshOption(numbers[0]); autoCheck(old, numbers[0]); } } @@ -904,6 +917,7 @@ static void onelab_number_input_range_cb(Fl_Widget *w, void *data) numbers[0].setAttribute("Loop", o->loop()); numbers[0].setAttribute("Graph", o->graph()); onelab::server::instance()->set(numbers[0]); + setGmshOption(numbers[0]); updateGraphs(); autoCheck(old, numbers[0]); }