mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 05:01:05 +08:00 
			
		
		
		
	Incomplete work for adapting the application to the new XS-based Config
This commit is contained in:
		
							parent
							
								
									e0c0a42a8b
								
							
						
					
					
						commit
						9836e963a5
					
				| @ -1151,35 +1151,22 @@ END | |||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | $Options = print_config_def(); | ||||||
|  | 
 | ||||||
| # generate accessors | # generate accessors | ||||||
| if (eval "use Class::XSAccessor; 1") { | { | ||||||
|     Class::XSAccessor->import( |  | ||||||
|         getters => { map { $_ => $_ } keys %$Options }, |  | ||||||
|     ); |  | ||||||
| } else { |  | ||||||
|     no strict 'refs'; |     no strict 'refs'; | ||||||
|     for my $opt_key (keys %$Options) { |     for my $opt_key (keys %$Options) { | ||||||
|         *{$opt_key} = sub { $_[0]{$opt_key} }; |         *{$opt_key} = sub { $_[0]->get($opt_key) }; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub new { |  | ||||||
|     my $class = shift; |  | ||||||
|     my %args = @_; |  | ||||||
|      |  | ||||||
|     my $self = bless {}, $class; |  | ||||||
|     $self->apply(%args); |  | ||||||
|     return $self; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sub new_from_defaults { | sub new_from_defaults { | ||||||
|     my $class = shift; |     my $class = shift; | ||||||
|      |      | ||||||
|     return $class->new( |     my $self = $class->new; | ||||||
|         map { $_ => $Options->{$_}{default} } |     $self->apply_static(Slic3r::Config::Print->new); | ||||||
|             grep !$Options->{$_}{shortcut}, |     return $self; | ||||||
|             (@_ ? @_ : keys %$Options) |  | ||||||
|     ); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub new_from_cli { | sub new_from_cli { | ||||||
| @ -1201,10 +1188,14 @@ sub new_from_cli { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     $args{$_} = $Options->{$_}{deserialize}->($args{$_}) |     my $self = $class->new; | ||||||
|         for grep exists $args{$_}, qw(print_center bed_size duplicate_grid extruder_offset retract_layer_change wipe); |     foreach my $opt_key (keys %args) { | ||||||
|      |         if ($opt_key =~ /^(?:print_center|bed_size|duplicate_grid|extruder_offset|retract_layer_change|wipe)$/) { | ||||||
|     return $class->new(%args); |             $self->set_deserialize($opt_key, $args{$opt_key}); | ||||||
|  |         } else { | ||||||
|  |             $self->set($opt_key, $args{$opt_key}); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub merge { | sub merge { | ||||||
| @ -1220,21 +1211,15 @@ sub load { | |||||||
|      |      | ||||||
|     my $ini = __PACKAGE__->read_ini($file); |     my $ini = __PACKAGE__->read_ini($file); | ||||||
|     my $config = __PACKAGE__->new; |     my $config = __PACKAGE__->new; | ||||||
|     $config->set($_, $ini->{_}{$_}, 1) for keys %{$ini->{_}}; |     $config->set_deserialize(handle_legacy($_, $ini->{_}{$_})) for keys %{$ini->{_}}; | ||||||
|     return $config; |     return $config; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub apply { |  | ||||||
|     my $self = shift; |  | ||||||
|     my %args = @_ == 1 ? %{$_[0]} : @_; # accept a single Config object too |  | ||||||
|      |  | ||||||
|     $self->set($_, $args{$_}) for keys %args; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sub clone { | sub clone { | ||||||
|     my $self = shift; |     my $self = shift; | ||||||
|     my $new = __PACKAGE__->new(%$self); |      | ||||||
|     $new->{$_} = [@{$new->{$_}}] for grep { ref $new->{$_} eq 'ARRAY' } keys %$new; |     my $new = __PACKAGE__->new; | ||||||
|  |     $new->apply($self); | ||||||
|     return $new; |     return $new; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1242,23 +1227,14 @@ sub get_value { | |||||||
|     my $self = shift; |     my $self = shift; | ||||||
|     my ($opt_key) = @_; |     my ($opt_key) = @_; | ||||||
|      |      | ||||||
|     no strict 'refs'; |     return $Options->{$opt_key}{ratio_over} | ||||||
|     my $value = $self->get($opt_key); |         ? $self->get_abs_value($opt_key) | ||||||
|     $value = $self->get_value($Options->{$opt_key}{ratio_over}) * $1/100 |         : $self->get($opt_key); | ||||||
|         if $Options->{$opt_key}{ratio_over} && $value =~ /^(\d+(?:\.\d+)?)%$/; |  | ||||||
|     return $value; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub get { | sub handle_legacy { | ||||||
|     my $self = shift; |     my $self = shift; | ||||||
|     my ($opt_key) = @_; |     my ($opt_key, $value) = @_; | ||||||
|      |  | ||||||
|     return $self->{$opt_key}; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sub set { |  | ||||||
|     my $self = shift; |  | ||||||
|     my ($opt_key, $value, $deserialize) = @_; |  | ||||||
|      |      | ||||||
|     # handle legacy options |     # handle legacy options | ||||||
|     return if first { $_ eq $opt_key } @Ignore; |     return if first { $_ eq $opt_key } @Ignore; | ||||||
| @ -1294,41 +1270,20 @@ sub set { | |||||||
|         $opt_key = $keys[0]; |         $opt_key = $keys[0]; | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     # clone arrayrefs |     return ($opt_key, $value); | ||||||
|     $value = [@$value] if ref $value eq 'ARRAY'; |  | ||||||
|      |  | ||||||
|     # deserialize if requested |  | ||||||
|     $value = $Options->{$opt_key}{deserialize}->($value) |  | ||||||
|         if $deserialize && $Options->{$opt_key}{deserialize}; |  | ||||||
|      |  | ||||||
|     $self->{$opt_key} = $value; |  | ||||||
|      |  | ||||||
|     if ($Options->{$opt_key}{shortcut}) { |  | ||||||
|         $self->set($_, $value, $deserialize) for @{$Options->{$opt_key}{shortcut}}; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub set_ifndef { | sub set_ifndef { | ||||||
|     my $self = shift; |     my $self = shift; | ||||||
|     my ($opt_key, $value, $deserialize) = @_; |     my ($opt_key, $value, $deserialize) = @_; | ||||||
|      |      | ||||||
|     $self->set($opt_key, $value, $deserialize) |     if (!$self->has($opt_key)) { | ||||||
|         if !defined $self->get($opt_key); |         if ($deserialize) { | ||||||
| } |             $self->set_deserialize($opt_key, $value); | ||||||
| 
 |         } else { | ||||||
| sub has { |             $self->set($opt_key, $value); | ||||||
|     my $self = shift; |         } | ||||||
|     my ($opt_key) = @_; |     } | ||||||
|     return exists $self->{$opt_key}; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sub serialize { |  | ||||||
|     my $self = shift; |  | ||||||
|     my ($opt_key) = @_; |  | ||||||
|      |  | ||||||
|     my $value = $self->get($opt_key); |  | ||||||
|     $value = $Options->{$opt_key}{serialize}->($value) if $Options->{$opt_key}{serialize}; |  | ||||||
|     return $value; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub save { | sub save { | ||||||
| @ -1336,9 +1291,8 @@ sub save { | |||||||
|     my ($file) = @_; |     my ($file) = @_; | ||||||
|      |      | ||||||
|     my $ini = { _ => {} }; |     my $ini = { _ => {} }; | ||||||
|     foreach my $opt_key (sort keys %$self) { |     foreach my $opt_key (sort @{$self->get_keys}) { | ||||||
|         next if $Options->{$opt_key}{shortcut}; |         next if $Options->{$opt_key}{shortcut}; | ||||||
|         next if $Options->{$opt_key}{gui_only}; |  | ||||||
|         $ini->{_}{$opt_key} = $self->serialize($opt_key); |         $ini->{_}{$opt_key} = $self->serialize($opt_key); | ||||||
|     } |     } | ||||||
|     __PACKAGE__->write_ini($file, $ini); |     __PACKAGE__->write_ini($file, $ini); | ||||||
| @ -1348,7 +1302,6 @@ sub setenv { | |||||||
|     my $self = shift; |     my $self = shift; | ||||||
|      |      | ||||||
|     foreach my $opt_key (sort keys %$Options) { |     foreach my $opt_key (sort keys %$Options) { | ||||||
|         next if $Options->{$opt_key}{gui_only}; |  | ||||||
|         $ENV{"SLIC3R_" . uc $opt_key} = $self->serialize($opt_key); |         $ENV{"SLIC3R_" . uc $opt_key} = $self->serialize($opt_key); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -151,8 +151,8 @@ if (@ARGV) {  # slicing from command line | |||||||
| sub usage { | sub usage { | ||||||
|     my ($exit_code) = @_; |     my ($exit_code) = @_; | ||||||
|      |      | ||||||
|     my $config = Slic3r::Config->new_from_defaults; |     my $config = Slic3r::Config->new_from_defaults->as_hash; | ||||||
|      |     use Devel::Peek; Dump($config->{layer_height});exit; | ||||||
|     my $j = ''; |     my $j = ''; | ||||||
|     if ($Slic3r::have_threads) { |     if ($Slic3r::have_threads) { | ||||||
|         $j = <<"EOF"; |         $j = <<"EOF"; | ||||||
|  | |||||||
| @ -2,6 +2,11 @@ | |||||||
| 
 | 
 | ||||||
| namespace Slic3r { | namespace Slic3r { | ||||||
| 
 | 
 | ||||||
|  | bool | ||||||
|  | ConfigBase::has(const t_config_option_key opt_key) { | ||||||
|  |     return (this->option(opt_key, false) != NULL); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void | void | ||||||
| ConfigBase::apply(ConfigBase &other, bool ignore_nonexistent) { | ConfigBase::apply(ConfigBase &other, bool ignore_nonexistent) { | ||||||
|     // get list of option keys to apply
 |     // get list of option keys to apply
 | ||||||
| @ -10,7 +15,7 @@ ConfigBase::apply(ConfigBase &other, bool ignore_nonexistent) { | |||||||
|      |      | ||||||
|     // loop through options and apply them
 |     // loop through options and apply them
 | ||||||
|     for (t_config_option_keys::const_iterator it = opt_keys.begin(); it != opt_keys.end(); ++it) { |     for (t_config_option_keys::const_iterator it = opt_keys.begin(); it != opt_keys.end(); ++it) { | ||||||
|         ConfigOption* my_opt = this->option(*it); |         ConfigOption* my_opt = this->option(*it, true); | ||||||
|         if (my_opt == NULL) { |         if (my_opt == NULL) { | ||||||
|             if (ignore_nonexistent == false) throw "Attempt to apply non-existent option"; |             if (ignore_nonexistent == false) throw "Attempt to apply non-existent option"; | ||||||
|             continue; |             continue; | ||||||
| @ -57,6 +62,19 @@ ConfigBase::get_abs_value(const t_config_option_key opt_key) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #ifdef SLIC3RXS | #ifdef SLIC3RXS | ||||||
|  | SV* | ||||||
|  | ConfigBase::as_hash() { | ||||||
|  |     HV* hv = newHV(); | ||||||
|  |      | ||||||
|  |     t_config_option_keys opt_keys; | ||||||
|  |     this->keys(&opt_keys); | ||||||
|  |      | ||||||
|  |     for (t_config_option_keys::const_iterator it = opt_keys.begin(); it != opt_keys.end(); ++it) | ||||||
|  |         (void)hv_store( hv, it->c_str(), it->length(), this->get(*it), 0 ); | ||||||
|  |      | ||||||
|  |     return newRV_noinc((SV*)hv); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| SV* | SV* | ||||||
| ConfigBase::get(t_config_option_key opt_key) { | ConfigBase::get(t_config_option_key opt_key) { | ||||||
|     ConfigOption* opt = this->option(opt_key); |     ConfigOption* opt = this->option(opt_key); | ||||||
| @ -212,11 +230,6 @@ DynamicConfig::keys(t_config_option_keys *keys) { | |||||||
|         keys->push_back(it->first); |         keys->push_back(it->first); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool |  | ||||||
| DynamicConfig::has(const t_config_option_key opt_key) const { |  | ||||||
|     return (this->options.count(opt_key) != 0); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void | void | ||||||
| StaticConfig::keys(t_config_option_keys *keys) { | StaticConfig::keys(t_config_option_keys *keys) { | ||||||
|     for (t_optiondef_map::const_iterator it = this->def->begin(); it != this->def->end(); ++it) { |     for (t_optiondef_map::const_iterator it = this->def->begin(); it != this->def->end(); ++it) { | ||||||
|  | |||||||
| @ -327,21 +327,39 @@ class ConfigOptionDef | |||||||
|     public: |     public: | ||||||
|     ConfigOptionType type; |     ConfigOptionType type; | ||||||
|     std::string label; |     std::string label; | ||||||
|  |     std::string category; | ||||||
|     std::string tooltip; |     std::string tooltip; | ||||||
|     std::string ratio_over; |     std::string sidetext; | ||||||
|  |     std::string cli; | ||||||
|  |     std::string scope; | ||||||
|  |     t_config_option_key ratio_over; | ||||||
|  |     bool multiline; | ||||||
|  |     bool full_label; | ||||||
|  |     bool full_width; | ||||||
|  |     bool readonly; | ||||||
|  |     int height; | ||||||
|  |     int width; | ||||||
|  |     int min; | ||||||
|  |     int max; | ||||||
|  |     std::vector<t_config_option_key> aliases; | ||||||
|  |     std::vector<t_config_option_key> shortcut; | ||||||
|  |     std::vector<std::string> enum_values; | ||||||
|  |     std::vector<std::string> enum_labels; | ||||||
|     t_config_enum_values enum_keys_map; |     t_config_enum_values enum_keys_map; | ||||||
|  |      | ||||||
|  |     ConfigOptionDef() : multiline(false), full_label(false), full_width(false), readonly(false), | ||||||
|  |                         height(0), width(0), min(0), max(0) {}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| typedef std::map<t_config_option_key,ConfigOptionDef> t_optiondef_map; | typedef std::map<t_config_option_key,ConfigOptionDef> t_optiondef_map; | ||||||
| 
 | 
 | ||||||
| ConfigOptionDef* get_config_option_def(const t_config_option_key opt_key); |  | ||||||
| 
 |  | ||||||
| class ConfigBase | class ConfigBase | ||||||
| { | { | ||||||
|     public: |     public: | ||||||
|     t_optiondef_map* def; |     t_optiondef_map* def; | ||||||
|      |      | ||||||
|     ConfigBase() : def(NULL) {}; |     ConfigBase() : def(NULL) {}; | ||||||
|  |     bool has(const t_config_option_key opt_key); | ||||||
|     virtual ConfigOption* option(const t_config_option_key opt_key, bool create = false) = 0; |     virtual ConfigOption* option(const t_config_option_key opt_key, bool create = false) = 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(ConfigBase &other, bool ignore_nonexistent = false); | ||||||
| @ -350,6 +368,7 @@ class ConfigBase | |||||||
|     float get_abs_value(const t_config_option_key opt_key); |     float get_abs_value(const t_config_option_key opt_key); | ||||||
|      |      | ||||||
|     #ifdef SLIC3RXS |     #ifdef SLIC3RXS | ||||||
|  |     SV* as_hash(); | ||||||
|     SV* get(t_config_option_key opt_key); |     SV* get(t_config_option_key opt_key); | ||||||
|     void set(t_config_option_key opt_key, SV* value); |     void set(t_config_option_key opt_key, SV* value); | ||||||
|     #endif |     #endif | ||||||
| @ -358,11 +377,10 @@ class ConfigBase | |||||||
| class DynamicConfig : public ConfigBase | class DynamicConfig : public ConfigBase | ||||||
| { | { | ||||||
|     public: |     public: | ||||||
|     DynamicConfig(){}; |     DynamicConfig() {}; | ||||||
|     ~DynamicConfig(); |     ~DynamicConfig(); | ||||||
|     ConfigOption* option(const t_config_option_key opt_key, bool create = false); |     ConfigOption* option(const t_config_option_key opt_key, bool create = false); | ||||||
|     void keys(t_config_option_keys *keys); |     void keys(t_config_option_keys *keys); | ||||||
|     bool has(const t_config_option_key opt_key) const; |  | ||||||
|      |      | ||||||
|     private: |     private: | ||||||
|     DynamicConfig(const DynamicConfig& other);              // we disable this by making it private and unimplemented
 |     DynamicConfig(const DynamicConfig& other);              // we disable this by making it private and unimplemented
 | ||||||
|  | |||||||
| @ -57,7 +57,6 @@ class PrintConfig : public StaticConfig | |||||||
|     }; |     }; | ||||||
|      |      | ||||||
|     ConfigOption* option(const t_config_option_key opt_key, bool create = false) { |     ConfigOption* option(const t_config_option_key opt_key, bool create = false) { | ||||||
|         assert(!create);  // can't create options in StaticConfig
 |  | ||||||
|         if (opt_key == "layer_height")              return &this->layer_height; |         if (opt_key == "layer_height")              return &this->layer_height; | ||||||
|         if (opt_key == "first_layer_height")        return &this->first_layer_height; |         if (opt_key == "first_layer_height")        return &this->first_layer_height; | ||||||
|         if (opt_key == "perimeters")                return &this->perimeters; |         if (opt_key == "perimeters")                return &this->perimeters; | ||||||
| @ -70,6 +69,7 @@ class PrintConfig : public StaticConfig | |||||||
|         if (opt_key == "nozzle_diameter")           return &this->nozzle_diameter; |         if (opt_key == "nozzle_diameter")           return &this->nozzle_diameter; | ||||||
|         if (opt_key == "temperature")               return &this->temperature; |         if (opt_key == "temperature")               return &this->temperature; | ||||||
|         if (opt_key == "wipe")                      return &this->wipe; |         if (opt_key == "wipe")                      return &this->wipe; | ||||||
|  |         if (create) throw "Attempt to create non-existing option in StaticConfig object"; | ||||||
|         return NULL; |         return NULL; | ||||||
|     }; |     }; | ||||||
|      |      | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ use strict; | |||||||
| use warnings; | use warnings; | ||||||
| 
 | 
 | ||||||
| use Slic3r::XS; | use Slic3r::XS; | ||||||
| use Test::More tests => 67; | use Test::More tests => 70; | ||||||
| 
 | 
 | ||||||
| foreach my $config (Slic3r::Config->new, Slic3r::Config::Print->new) { | foreach my $config (Slic3r::Config->new, Slic3r::Config::Print->new) { | ||||||
|     $config->set('layer_height', 0.3); |     $config->set('layer_height', 0.3); | ||||||
| @ -73,6 +73,8 @@ foreach my $config (Slic3r::Config->new, Slic3r::Config::Print->new) { | |||||||
|     is $config->serialize('wipe'), '1,0', 'serialize bools'; |     is $config->serialize('wipe'), '1,0', 'serialize bools'; | ||||||
|     $config->set_deserialize('wipe', '0,1,1'); |     $config->set_deserialize('wipe', '0,1,1'); | ||||||
|     is_deeply $config->get('wipe'), [0,1,1], 'deserialize bools'; |     is_deeply $config->get('wipe'), [0,1,1], 'deserialize bools'; | ||||||
|  |      | ||||||
|  |     is_deeply [ sort @{$config->get_keys} ], [ sort keys %{$config->as_hash} ], 'get_keys and as_hash'; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| { | { | ||||||
| @ -81,7 +83,14 @@ foreach my $config (Slic3r::Config->new, Slic3r::Config::Print->new) { | |||||||
|      |      | ||||||
|     my $config2 = Slic3r::Config::Print->new; |     my $config2 = Slic3r::Config::Print->new; | ||||||
|     $config2->apply_dynamic($config); |     $config2->apply_dynamic($config); | ||||||
|     is $config2->get('perimeters'), 2, 'apply (dynamic -> static)'; |     is $config2->get('perimeters'), 2, 'apply_dynamic'; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | { | ||||||
|  |     my $config = Slic3r::Config::Print->new; | ||||||
|  |     my $config2 = Slic3r::Config->new; | ||||||
|  |     $config2->apply_static($config); | ||||||
|  |     is $config2->get('perimeters'), Slic3r::Config::print_config_def()->{perimeters}{default}, 'apply_static and print_config_def'; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| __END__ | __END__ | ||||||
|  | |||||||
| @ -8,11 +8,19 @@ | |||||||
| %name{Slic3r::Config} class DynamicPrintConfig { | %name{Slic3r::Config} class DynamicPrintConfig { | ||||||
|     DynamicPrintConfig(); |     DynamicPrintConfig(); | ||||||
|     ~DynamicPrintConfig(); |     ~DynamicPrintConfig(); | ||||||
|  |     bool has(t_config_option_key opt_key); | ||||||
|  |     SV* as_hash(); | ||||||
|     SV* get(t_config_option_key opt_key); |     SV* get(t_config_option_key opt_key); | ||||||
|     void set(t_config_option_key opt_key, SV* value); |     void set(t_config_option_key opt_key, SV* value); | ||||||
|     void set_deserialize(t_config_option_key opt_key, std::string str); |     void set_deserialize(t_config_option_key opt_key, std::string str); | ||||||
|     std::string serialize(t_config_option_key opt_key); |     std::string serialize(t_config_option_key opt_key); | ||||||
|     float get_abs_value(t_config_option_key opt_key); |     float get_abs_value(t_config_option_key opt_key); | ||||||
|  |     void apply(DynamicPrintConfig* other) | ||||||
|  |         %code{% THIS->apply(*other, true); %}; | ||||||
|  |     void apply_static(PrintConfig* other) | ||||||
|  |         %code{% THIS->apply(*other, true); %}; | ||||||
|  |     std::vector<std::string> get_keys() | ||||||
|  |         %code{% THIS->keys(&RETVAL); %}; | ||||||
| %{ | %{ | ||||||
| 
 | 
 | ||||||
| %} | %} | ||||||
| @ -21,14 +29,114 @@ | |||||||
| %name{Slic3r::Config::Print} class PrintConfig { | %name{Slic3r::Config::Print} class PrintConfig { | ||||||
|     PrintConfig(); |     PrintConfig(); | ||||||
|     ~PrintConfig(); |     ~PrintConfig(); | ||||||
|  |     bool has(t_config_option_key opt_key); | ||||||
|  |     SV* as_hash(); | ||||||
|     SV* get(t_config_option_key opt_key); |     SV* get(t_config_option_key opt_key); | ||||||
|     void set(t_config_option_key opt_key, SV* value); |     void set(t_config_option_key opt_key, SV* value); | ||||||
|     void set_deserialize(t_config_option_key opt_key, std::string str); |     void set_deserialize(t_config_option_key opt_key, std::string str); | ||||||
|     std::string serialize(t_config_option_key opt_key); |     std::string serialize(t_config_option_key opt_key); | ||||||
|     float get_abs_value(t_config_option_key opt_key); |     float get_abs_value(t_config_option_key opt_key); | ||||||
|     void apply_dynamic(DynamicPrintConfig* other, bool ignore_nonexistent = false) |     void apply_dynamic(DynamicPrintConfig* other) | ||||||
|         %code{% THIS->apply(*other, ignore_nonexistent); %}; |         %code{% THIS->apply(*other, true); %}; | ||||||
|  |     std::vector<std::string> get_keys() | ||||||
|  |         %code{% THIS->keys(&RETVAL); %}; | ||||||
| %{ | %{ | ||||||
| 
 | 
 | ||||||
| %} | %} | ||||||
| }; | }; | ||||||
|  | 
 | ||||||
|  | %package{Slic3r::Config}; | ||||||
|  | 
 | ||||||
|  | %{ | ||||||
|  | PROTOTYPES: DISABLE | ||||||
|  | 
 | ||||||
|  | SV* | ||||||
|  | print_config_def() | ||||||
|  |     CODE: | ||||||
|  |         PrintConfig config; | ||||||
|  |         t_optiondef_map* def = config.def; | ||||||
|  |          | ||||||
|  |         HV* options_hv = newHV(); | ||||||
|  |         for (t_optiondef_map::iterator oit = def->begin(); oit != def->end(); ++oit) { | ||||||
|  |             HV* hv = newHV(); | ||||||
|  |              | ||||||
|  |             t_config_option_key opt_key = oit->first; | ||||||
|  |             ConfigOptionDef* optdef     = &oit->second; | ||||||
|  |              | ||||||
|  |             const char* opt_type; | ||||||
|  |             if (optdef->type == coFloat || optdef->type == coFloats || optdef->type == coFloatOrPercent) { | ||||||
|  |                 opt_type = "f"; | ||||||
|  |             } else if (optdef->type == coInt || optdef->type == coInts) { | ||||||
|  |                 opt_type = "i"; | ||||||
|  |             } else if (optdef->type == coString) { | ||||||
|  |                 opt_type = "s"; | ||||||
|  |             } else if (optdef->type == coPoint || optdef->type == coPoints) { | ||||||
|  |                 opt_type = "point"; | ||||||
|  |             } else if (optdef->type == coBool || optdef->type == coBools) { | ||||||
|  |                 opt_type = "bool"; | ||||||
|  |             } else if (optdef->type == coEnum) { | ||||||
|  |                 opt_type = "select"; | ||||||
|  |             } else { | ||||||
|  |                 throw "Unknown option type"; | ||||||
|  |             } | ||||||
|  |             (void)hv_stores( hv, "type",        newSVpv(opt_type, 0) ); | ||||||
|  |             (void)hv_stores( hv, "label",       newSVpvn(optdef->label.c_str(), optdef->label.length()) ); | ||||||
|  |             (void)hv_stores( hv, "category",    newSVpvn(optdef->category.c_str(), optdef->category.length()) ); | ||||||
|  |             (void)hv_stores( hv, "tooltip",     newSVpvn(optdef->tooltip.c_str(), optdef->tooltip.length()) ); | ||||||
|  |             (void)hv_stores( hv, "sidetext",    newSVpvn(optdef->sidetext.c_str(), optdef->sidetext.length()) ); | ||||||
|  |             (void)hv_stores( hv, "cli",         newSVpvn(optdef->cli.c_str(), optdef->cli.length()) ); | ||||||
|  |             (void)hv_stores( hv, "scope",       newSVpvn(optdef->scope.c_str(), optdef->scope.length()) ); | ||||||
|  |             (void)hv_stores( hv, "ratio_over",  newSVpvn(optdef->ratio_over.c_str(), optdef->ratio_over.length()) ); | ||||||
|  |             (void)hv_stores( hv, "multiline",   newSViv(optdef->multiline ? 1 : 0) ); | ||||||
|  |             (void)hv_stores( hv, "full_label",  newSViv(optdef->full_label ? 1 : 0) ); | ||||||
|  |             (void)hv_stores( hv, "full_width",  newSViv(optdef->full_width ? 1 : 0) ); | ||||||
|  |             (void)hv_stores( hv, "readonly",    newSViv(optdef->readonly ? 1 : 0) ); | ||||||
|  |             (void)hv_stores( hv, "height",      newSViv(optdef->height) ); | ||||||
|  |             (void)hv_stores( hv, "width",       newSViv(optdef->width) ); | ||||||
|  |             (void)hv_stores( hv, "min",         newSViv(optdef->min) ); | ||||||
|  |             (void)hv_stores( hv, "max",         newSViv(optdef->max) ); | ||||||
|  |              | ||||||
|  |             // aliases | ||||||
|  |             { | ||||||
|  |                 AV* av = newAV(); | ||||||
|  |                 av_fill(av, optdef->aliases.size()-1); | ||||||
|  |                 for (std::vector<t_config_option_key>::iterator it = optdef->aliases.begin(); it != optdef->aliases.end(); ++it) | ||||||
|  |                     av_store(av, it - optdef->aliases.begin(), newSVpvn(it->c_str(), it->length())); | ||||||
|  |                 (void)hv_stores( hv, "aliases", newRV_noinc((SV*)av) ); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             // shortcut | ||||||
|  |             { | ||||||
|  |                 AV* av = newAV(); | ||||||
|  |                 av_fill(av, optdef->shortcut.size()-1); | ||||||
|  |                 for (std::vector<t_config_option_key>::iterator it = optdef->shortcut.begin(); it != optdef->shortcut.end(); ++it) | ||||||
|  |                     av_store(av, it - optdef->shortcut.begin(), newSVpvn(it->c_str(), it->length())); | ||||||
|  |                 (void)hv_stores( hv, "shortcut", newRV_noinc((SV*)av) ); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             // enum_values | ||||||
|  |             { | ||||||
|  |                 AV* av = newAV(); | ||||||
|  |                 av_fill(av, optdef->enum_values.size()-1); | ||||||
|  |                 for (std::vector<std::string>::iterator it = optdef->enum_values.begin(); it != optdef->enum_values.end(); ++it) | ||||||
|  |                     av_store(av, it - optdef->enum_values.begin(), newSVpvn(it->c_str(), it->length())); | ||||||
|  |                 (void)hv_stores( hv, "enum_values", newRV_noinc((SV*)av) ); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             // enum_labels | ||||||
|  |             { | ||||||
|  |                 AV* av = newAV(); | ||||||
|  |                 av_fill(av, optdef->enum_labels.size()-1); | ||||||
|  |                 for (std::vector<std::string>::iterator it = optdef->enum_labels.begin(); it != optdef->enum_labels.end(); ++it) | ||||||
|  |                     av_store(av, it - optdef->enum_labels.begin(), newSVpvn(it->c_str(), it->length())); | ||||||
|  |                 (void)hv_stores( hv, "enum_labels", newRV_noinc((SV*)av) ); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             (void)hv_stores( hv, "default", config.get(opt_key) ); | ||||||
|  |             (void)hv_store( options_hv, opt_key.c_str(), opt_key.length(), newRV_noinc((SV*)hv), 0 ); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         RETVAL = newRV_noinc((SV*)options_hv); | ||||||
|  |     OUTPUT: | ||||||
|  |         RETVAL | ||||||
|  | %} | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ | |||||||
| %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{std::vector<std::string>}; | ||||||
| %typemap{SV*}; | %typemap{SV*}; | ||||||
| %typemap{AV*}; | %typemap{AV*}; | ||||||
| %typemap{Point*}; | %typemap{Point*}; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Alessandro Ranellucci
						Alessandro Ranellucci