More work for porting Config to XS
This commit is contained in:
parent
4d066840ba
commit
008f38cf68
@ -61,6 +61,7 @@ t/12_extrusionpathcollection.t
|
|||||||
t/13_polylinecollection.t
|
t/13_polylinecollection.t
|
||||||
t/14_geometry.t
|
t/14_geometry.t
|
||||||
xsp/Clipper.xsp
|
xsp/Clipper.xsp
|
||||||
|
xsp/Config.xsp
|
||||||
xsp/ExPolygon.xsp
|
xsp/ExPolygon.xsp
|
||||||
xsp/ExPolygonCollection.xsp
|
xsp/ExPolygonCollection.xsp
|
||||||
xsp/ExtrusionEntityCollection.xsp
|
xsp/ExtrusionEntityCollection.xsp
|
||||||
|
@ -2,6 +2,63 @@
|
|||||||
|
|
||||||
namespace Slic3r {
|
namespace Slic3r {
|
||||||
|
|
||||||
|
t_optiondef_map Options = _build_optiondef_map();
|
||||||
|
FullConfig DefaultConfig = _build_default_config();
|
||||||
|
|
||||||
|
void
|
||||||
|
ConfigBase::apply(ConfigBase &other, bool ignore_nonexistent) {
|
||||||
|
// get list of option keys to apply
|
||||||
|
t_config_option_keys opt_keys;
|
||||||
|
other.keys(&opt_keys);
|
||||||
|
|
||||||
|
// loop through options and apply them
|
||||||
|
for (t_config_option_keys::const_iterator it = opt_keys.begin(); it != opt_keys.end(); ++it) {
|
||||||
|
ConfigOption* my_opt = this->option(*it);
|
||||||
|
if (my_opt == NULL && ignore_nonexistent == false) throw "Attempt to apply non-existent option";
|
||||||
|
*my_opt = *(other.option(*it));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef SLIC3RXS
|
||||||
|
SV*
|
||||||
|
ConfigBase::get(t_config_option_key opt_key) {
|
||||||
|
ConfigOption* opt = this->option(opt_key);
|
||||||
|
if (opt == NULL) return &PL_sv_undef;
|
||||||
|
if (ConfigOptionFloat* v = dynamic_cast<ConfigOptionFloat*>(opt)) {
|
||||||
|
return newSVnv(v->value);
|
||||||
|
} else if (ConfigOptionInt* v = dynamic_cast<ConfigOptionInt*>(opt)) {
|
||||||
|
return newSViv(v->value);
|
||||||
|
} else {
|
||||||
|
throw "Unknown option value type";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ConfigOption*
|
||||||
|
DynamicConfig::option(const t_config_option_key opt_key) {
|
||||||
|
t_options_map::iterator it = this->options.find(opt_key);
|
||||||
|
if (it == this->options.end()) return NULL;
|
||||||
|
return it->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
DynamicConfig::keys(t_config_option_keys *keys) {
|
||||||
|
for (t_options_map::const_iterator it = this->options.begin(); it != this->options.end(); ++it)
|
||||||
|
keys->push_back(it->first);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
DynamicConfig::has(const t_config_option_key opt_key) const {
|
||||||
|
t_options_map::const_iterator it = this->options.find(opt_key);
|
||||||
|
return (it != this->options.end());
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
StaticConfig::keys(t_config_option_keys *keys) {
|
||||||
|
for (t_optiondef_map::const_iterator it = Options.begin(); it != Options.end(); ++it) {
|
||||||
|
ConfigOption* opt = this->option(it->first);
|
||||||
|
if (opt != NULL) keys->push_back(it->first);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -6,29 +6,49 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
keyspace Slic3r {
|
namespace Slic3r {
|
||||||
|
|
||||||
typedef std::string t_config_option_key;
|
typedef std::string t_config_option_key;
|
||||||
typedef std::vector<std::string> t_config_option_keys;
|
typedef std::vector<std::string> t_config_option_keys;
|
||||||
|
|
||||||
class ConfigOption
|
class ConfigOption {
|
||||||
|
public:
|
||||||
|
virtual ~ConfigOption() {};
|
||||||
|
};
|
||||||
|
|
||||||
|
class ConfigOptionFloat : public ConfigOption
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
float float_value;
|
float value;
|
||||||
int int_value;
|
operator float() const { return this->value; };
|
||||||
std::string string_value;
|
};
|
||||||
bool percent;
|
|
||||||
|
|
||||||
operator float() const { return this->float_value; };
|
class ConfigOptionInt : public ConfigOption
|
||||||
operator int() const { return this->int_value; };
|
{
|
||||||
operator std::string() const { return this->string_value; };
|
public:
|
||||||
|
int value;
|
||||||
|
operator int() const { return this->value; };
|
||||||
|
};
|
||||||
|
|
||||||
|
class ConfigOptionString : public ConfigOption
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
std::string value;
|
||||||
|
operator std::string() const { return this->value; };
|
||||||
|
};
|
||||||
|
|
||||||
|
class ConfigOptionFloatOrPercent : public ConfigOption
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
float value;
|
||||||
|
bool percent;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ConfigOptionType {
|
enum ConfigOptionType {
|
||||||
coFloat,
|
coFloat,
|
||||||
coInt,
|
coInt,
|
||||||
coFloatOrPercent,
|
|
||||||
coString,
|
coString,
|
||||||
|
coFloatOrPercent,
|
||||||
};
|
};
|
||||||
|
|
||||||
class ConfigOptionDef
|
class ConfigOptionDef
|
||||||
@ -37,74 +57,45 @@ class ConfigOptionDef
|
|||||||
ConfigOptionType type;
|
ConfigOptionType type;
|
||||||
std::string label;
|
std::string label;
|
||||||
std::string tooltip;
|
std::string tooltip;
|
||||||
ConfigOption default_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::map<t_config_option_key,ConfigOptionDef> t_optiondef_map;
|
typedef std::map<t_config_option_key,ConfigOptionDef> t_optiondef_map;
|
||||||
t_optiondef_map Options;
|
|
||||||
Options["layer_height"].type = coFloat;
|
|
||||||
Options["layer_height"].label = "Layer height";
|
|
||||||
Options["layer_height"].tooltip = "This setting controls the height (and thus the total number) of the slices/layers. Thinner layers give better accuracy but take more time to print.";
|
|
||||||
Options["layer_height"].default_.float_value = 0.4;
|
|
||||||
Options["first_layer_height"].type = coFloatOrPercent;
|
|
||||||
Options["first_layer_height"].default_.percent = false;
|
|
||||||
Options["first_layer_height"].default_.float_value = 0.35;
|
|
||||||
|
|
||||||
class ConfigBase
|
class ConfigBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual ConfigOption* option(const t_config_option_key opt_key) = 0;
|
virtual ConfigOption* option(const t_config_option_key opt_key) = 0;
|
||||||
virtual void keys(t_config_option_keys *keys) = 0;
|
virtual void keys(t_config_option_keys *keys) = 0;
|
||||||
|
void apply(ConfigBase &other, bool ignore_nonexistent = false);
|
||||||
|
|
||||||
void apply(const ConfigBase &other, bool ignore_nonexistent = false)
|
#ifdef SLIC3RXS
|
||||||
{
|
SV* get(t_config_option_key opt_key);
|
||||||
// get list of option keys to apply
|
#endif
|
||||||
t_config_option_keys opt_keys;
|
|
||||||
other.keys(&opt_keys);
|
|
||||||
|
|
||||||
// loop through options and apply them
|
|
||||||
for (t_config_option_keys::const_iterator it = opt_keys.begin(); it != opt_keys.end(); ++it) {
|
|
||||||
ConfigOption* my_opt = this->option(*it);
|
|
||||||
if (my_opt == NULL && ignore_nonexistent == false) throw "Attempt to apply non-existent option";
|
|
||||||
*my_opt = *(other.option(*it));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class DynamicConfig : public ConfigBase
|
class DynamicConfig : public ConfigBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef std::map<t_config_option_key,ConfigOption> t_options_map;
|
ConfigOption* option(const t_config_option_key opt_key);
|
||||||
|
void keys(t_config_option_keys *keys);
|
||||||
|
bool has(const t_config_option_key opt_key) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
typedef std::map<t_config_option_key,ConfigOption*> t_options_map;
|
||||||
t_options_map options;
|
t_options_map options;
|
||||||
|
|
||||||
ConfigOption* option(const t_config_option_key opt_key) {
|
|
||||||
t_options_map::iterator it = this->options.find(opt_key);
|
|
||||||
if (it == this->options.end()) return NULL;
|
|
||||||
return &it->second;
|
|
||||||
};
|
|
||||||
|
|
||||||
void keys(t_config_option_keys *keys) {
|
|
||||||
for (t_options_map::const_iterator it = this->options.begin(); it != this->options.end(); ++it)
|
|
||||||
keys->push_back(*it);
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class StaticConfig : public ConfigBase
|
class StaticConfig : public ConfigBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
void keys(t_config_option_keys *keys) {
|
void keys(t_config_option_keys *keys);
|
||||||
for (t_optiondef_map::const_iterator it = Options.begin(); it != Options.end(); ++it) {
|
|
||||||
ConfigOption* opt = this->option(it->first);
|
|
||||||
if (opt != NULL) keys->push_back(it->first);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class FullConfig : public StaticConfig
|
class FullConfig : public StaticConfig
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ConfigOption layer_height;
|
ConfigOptionFloat layer_height;
|
||||||
ConfigOption first_layer_height;
|
ConfigOptionFloatOrPercent first_layer_height;
|
||||||
|
|
||||||
ConfigOption* option(const t_config_option_key opt_key) {
|
ConfigOption* option(const t_config_option_key opt_key) {
|
||||||
if (opt_key == "layer_height") return &this->layer_height;
|
if (opt_key == "layer_height") return &this->layer_height;
|
||||||
@ -113,6 +104,26 @@ class FullConfig : public StaticConfig
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static t_optiondef_map _build_optiondef_map () {
|
||||||
|
t_optiondef_map Options;
|
||||||
|
Options["layer_height"].type = coFloat;
|
||||||
|
Options["layer_height"].label = "Layer height";
|
||||||
|
Options["layer_height"].tooltip = "This setting controls the height (and thus the total number) of the slices/layers. Thinner layers give better accuracy but take more time to print.";
|
||||||
|
|
||||||
|
Options["first_layer_height"].type = coFloatOrPercent;
|
||||||
|
return Options;
|
||||||
|
}
|
||||||
|
|
||||||
|
static FullConfig _build_default_config () {
|
||||||
|
FullConfig defconf;
|
||||||
|
|
||||||
|
defconf.layer_height.value = 0.4;
|
||||||
|
defconf.first_layer_height.value = 0.35;
|
||||||
|
defconf.first_layer_height.percent = false;
|
||||||
|
|
||||||
|
return defconf;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
15
xs/xsp/Config.xsp
Normal file
15
xs/xsp/Config.xsp
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
%module{Slic3r::XS};
|
||||||
|
|
||||||
|
%{
|
||||||
|
#include <myinit.h>
|
||||||
|
#include "Config.hpp"
|
||||||
|
%}
|
||||||
|
|
||||||
|
%name{Slic3r::Config} class DynamicConfig {
|
||||||
|
DynamicConfig();
|
||||||
|
~DynamicConfig();
|
||||||
|
SV* get(t_config_option_key opt_key);
|
||||||
|
%{
|
||||||
|
|
||||||
|
%}
|
||||||
|
};
|
@ -1,5 +1,7 @@
|
|||||||
std::vector<Points::size_type> T_STD_VECTOR_INT
|
std::vector<Points::size_type> T_STD_VECTOR_INT
|
||||||
|
t_config_option_key T_STD_STRING
|
||||||
|
|
||||||
|
DynamicConfig* O_OBJECT
|
||||||
ZTable* O_OBJECT
|
ZTable* O_OBJECT
|
||||||
TriangleMesh* O_OBJECT
|
TriangleMesh* O_OBJECT
|
||||||
Point* O_OBJECT
|
Point* O_OBJECT
|
||||||
|
@ -1,11 +1,13 @@
|
|||||||
%typemap{bool}{simple};
|
%typemap{bool}{simple};
|
||||||
%typemap{std::string};
|
%typemap{std::string};
|
||||||
|
%typemap{t_config_option_key};
|
||||||
%typemap{std::vector<unsigned int>*};
|
%typemap{std::vector<unsigned int>*};
|
||||||
%typemap{std::vector<double>};
|
%typemap{std::vector<double>};
|
||||||
%typemap{std::vector<double>*};
|
%typemap{std::vector<double>*};
|
||||||
%typemap{SV*};
|
%typemap{SV*};
|
||||||
%typemap{AV*};
|
%typemap{AV*};
|
||||||
%typemap{Point*};
|
%typemap{Point*};
|
||||||
|
%typemap{DynamicConfig*};
|
||||||
%typemap{ExPolygon*};
|
%typemap{ExPolygon*};
|
||||||
%typemap{ExPolygonCollection*};
|
%typemap{ExPolygonCollection*};
|
||||||
%typemap{Line*};
|
%typemap{Line*};
|
||||||
|
Loading…
Reference in New Issue
Block a user