X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5ee69f22d5f6ab219b59132ade49e92978ecdc21..3836e4e27a13a0d389812e41a4d5d651ff0c158b:/include/xbt/config.hpp diff --git a/include/xbt/config.hpp b/include/xbt/config.hpp index 6f3283562a..d25e1c41ce 100644 --- a/include/xbt/config.hpp +++ b/include/xbt/config.hpp @@ -76,15 +76,7 @@ extern template XBT_PUBLIC void declareFlag(const char* name, const char* descri // ***** alias ***** -XBT_PUBLIC void alias(const char* realname, const char* aliasname); - -inline -void alias(std::initializer_list names) -{ - auto i = names.begin(); - for (++i; i != names.end(); ++i) - alias(*names.begin(), *i); -} +XBT_PUBLIC void alias(const char* realname, std::initializer_list aliases); /** Bind a variable to configuration flag * @@ -100,11 +92,11 @@ void bindFlag(T& value, const char* name, const char* description) }); } -template -void bindFlag(T& value, std::initializer_list names, const char* description) +template +void bindFlag(T& value, const char* name, std::initializer_list aliases, const char* description) { - bindFlag(value, *names.begin(), description); - alias(names); + bindFlag(value, name, description); + alias(name, std::move(aliases)); } /** Bind a variable to configuration flag @@ -118,33 +110,24 @@ void bindFlag(T& value, std::initializer_list names, const char* de * */ // F is a checker, F : T& -> () -template -typename std::enable_if()(std::declval()) ) ->::value, void>::type -bindFlag(T& value, std::initializer_list names, const char* description, - F callback) +template +typename std::enable_if()(std::declval()))>::value, void>::type +bindFlag(T& value, const char* name, const char* description, F callback) { - bindFlag(value, *names.begin(), description); - alias(names); + declareFlag(name, description, value, std::function([&value, callback](const T& val) { + callback(val); + value = std::move(val); + })); } -template -typename std::enable_if()(std::declval()) ) ->::value, void>::type -bindFlag(T& value, const char* name, const char* description, - F callback) +template +typename std::enable_if()(std::declval()))>::value, void>::type +bindFlag(T& value, const char* name, std::initializer_list aliases, const char* description, F callback) { - declareFlag(name, description, value, - std::function([&value,callback](const T& val) { - callback(val); - value = std::move(val); - } - )); + bindFlag(value, name, description, std::move(callback)); + alias(name, std::move(aliases)); } + template typename std::enable_if()(std::declval()))>::value, void>::type bindFlag(T& value, const char* name, const char* description, std::map valid_values, F callback) @@ -218,10 +201,10 @@ public: simgrid::config::bindFlag(value_, name, desc); } - /** Constructor taking an array of aliases as name */ - Flag(std::initializer_list names, const char* desc, T value) : value_(value) + /** Constructor taking also an array of aliases for name */ + Flag(const char* name, std::initializer_list aliases, const char* desc, T value) : value_(value) { - simgrid::config::bindFlag(value_, names, desc); + simgrid::config::bindFlag(value_, name, std::move(aliases), desc); } /* A constructor accepting a callback that will be passed the parameter.