mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-20 07:11:12 -06:00 
			
		
		
		
	ConfigWizard: Add reset option, fixes
Fix mock vendors
This commit is contained in:
		
							parent
							
								
									c884f3b213
								
							
						
					
					
						commit
						81c6ad3ab7
					
				
					 9 changed files with 102 additions and 78 deletions
				
			
		|  | @ -1,4 +1,4 @@ | ||||||
| # Print profiles for the Prusa Research printers. | # Print profiles for the BarBaz Research printers. | ||||||
| 
 | 
 | ||||||
| [vendor] | [vendor] | ||||||
| # Vendor name will be shown by the Config Wizard. | # Vendor name will be shown by the Config Wizard. | ||||||
|  | @ -735,11 +735,11 @@ first_layer_temperature = 195 | ||||||
| start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | ||||||
| temperature = 195 | temperature = 195 | ||||||
| 
 | 
 | ||||||
| [filament:Prusa ABS] | [filament:BarBaz ABS] | ||||||
| inherits = *ABS* | inherits = *ABS* | ||||||
| filament_notes = "List of materials tested with standart ABS print settings for MK2:\n\nEsun ABS\nFil-A-Gehr ABS\nHatchboxABS\nPlasty Mladeč ABS" | filament_notes = "List of materials tested with standart ABS print settings for MK2:\n\nEsun ABS\nFil-A-Gehr ABS\nHatchboxABS\nPlasty Mladeč ABS" | ||||||
| 
 | 
 | ||||||
| [filament:Prusa HIPS] | [filament:BarBaz HIPS] | ||||||
| inherits = *ABS* | inherits = *ABS* | ||||||
| bridge_fan_speed = 50 | bridge_fan_speed = 50 | ||||||
| cooling = 1 | cooling = 1 | ||||||
|  | @ -755,11 +755,11 @@ min_fan_speed = 20 | ||||||
| start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | ||||||
| temperature = 220 | temperature = 220 | ||||||
| 
 | 
 | ||||||
| [filament:Prusa PET] | [filament:BarBaz PET] | ||||||
| inherits = *PET* | inherits = *PET* | ||||||
| filament_notes = "List of manufacturers tested with standart PET print settings for MK2:\n\nE3D Edge\nFillamentum CPE GH100\nPlasty Mladeč PETG" | filament_notes = "List of manufacturers tested with standart PET print settings for MK2:\n\nE3D Edge\nFillamentum CPE GH100\nPlasty Mladeč PETG" | ||||||
| 
 | 
 | ||||||
| [filament:Prusa PLA] | [filament:BarBaz PLA] | ||||||
| inherits = *PLA* | inherits = *PLA* | ||||||
| filament_notes = "List of materials tested with standart PLA print settings for MK2:\n\nDas Filament\nEsun PLA\nEUMAKERS PLA\nFiberlogy HD-PLA\nFillamentum PLA\nFloreon3D\nHatchbox PLA\nPlasty Mladeč PLA\nPrimavalue PLA\nProto pasta Matte Fiber\nVerbatim PLA\nVerbatim BVOH" | filament_notes = "List of materials tested with standart PLA print settings for MK2:\n\nDas Filament\nEsun PLA\nEUMAKERS PLA\nFiberlogy HD-PLA\nFillamentum PLA\nFloreon3D\nHatchbox PLA\nPlasty Mladeč PLA\nPrimavalue PLA\nProto pasta Matte Fiber\nVerbatim PLA\nVerbatim BVOH" | ||||||
| 
 | 
 | ||||||
|  | @ -855,7 +855,7 @@ min_layer_height = 0.07 | ||||||
| nozzle_diameter = 0.4 | nozzle_diameter = 0.4 | ||||||
| octoprint_apikey =  | octoprint_apikey =  | ||||||
| octoprint_host =  | octoprint_host =  | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_BarBaz3D\nPRINTER_MODEL_MK2\n | ||||||
| printer_settings_id =  | printer_settings_id =  | ||||||
| retract_before_travel = 1 | retract_before_travel = 1 | ||||||
| retract_before_wipe = 0% | retract_before_wipe = 0% | ||||||
|  | @ -882,7 +882,7 @@ z_offset = 0 | ||||||
| printer_model = M2 | printer_model = M2 | ||||||
| printer_variant = 0.4 | printer_variant = 0.4 | ||||||
| default_print_profile = 0.15mm OPTIMAL | default_print_profile = 0.15mm OPTIMAL | ||||||
| default_filament_profile = Prusa PLA | default_filament_profile = BarBaz PLA | ||||||
| 
 | 
 | ||||||
| [printer:*multimaterial*] | [printer:*multimaterial*] | ||||||
| inherits = *common* | inherits = *common* | ||||||
|  | @ -903,7 +903,7 @@ printer_model = M3 | ||||||
| [printer:*mm-single*] | [printer:*mm-single*] | ||||||
| inherits = *multimaterial* | inherits = *multimaterial* | ||||||
| end_gcode = G1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors\n\n | end_gcode = G1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors\n\n | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_BarBaz3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | ||||||
| start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT?\nM104 S[first_layer_temperature]\nM140 S[first_layer_bed_temperature]\nM109 S[first_layer_temperature]\nM190 S[first_layer_bed_temperature]\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100\nM92 E140\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\nG92 E0.0 | start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT?\nM104 S[first_layer_temperature]\nM140 S[first_layer_bed_temperature]\nM109 S[first_layer_temperature]\nM190 S[first_layer_bed_temperature]\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100\nM92 E140\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\nG92 E0.0 | ||||||
| 
 | 
 | ||||||
| [printer:*mm-multi*] | [printer:*mm-multi*] | ||||||
|  | @ -911,14 +911,14 @@ inherits = *multimaterial* | ||||||
| end_gcode = {if not has_wipe_tower}\n; Pull the filament into the cooling tubes.\nG1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\n{endif}\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors | end_gcode = {if not has_wipe_tower}\n; Pull the filament into the cooling tubes.\nG1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\n{endif}\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors | ||||||
| extruder_colour = #FFAA55;#5182DB;#4ECDD3;#FB7259 | extruder_colour = #FFAA55;#5182DB;#4ECDD3;#FB7259 | ||||||
| nozzle_diameter = 0.4,0.4,0.4,0.4 | nozzle_diameter = 0.4,0.4,0.4,0.4 | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_BarBaz3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | ||||||
| start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT[initial_tool]\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100 ; set max feedrate\nM92 E140 ; E-steps per filament milimeter\n{if not has_wipe_tower}\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\n{endif}\nG92 E0.0 | start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT[initial_tool]\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100 ; set max feedrate\nM92 E140 ; E-steps per filament milimeter\n{if not has_wipe_tower}\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\n{endif}\nG92 E0.0 | ||||||
| variable_layer_height = 0 | variable_layer_height = 0 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2] | [printer:BarBaz i3 MK2] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 0.25 nozzle] | [printer:BarBaz i3 MK2 0.25 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| max_layer_height = 0.1 | max_layer_height = 0.1 | ||||||
| min_layer_height = 0.05 | min_layer_height = 0.05 | ||||||
|  | @ -929,56 +929,56 @@ variable_layer_height = 0 | ||||||
| printer_variant = 0.25 | printer_variant = 0.25 | ||||||
| default_print_profile = 0.10mm DETAIL 0.25 nozzle | default_print_profile = 0.10mm DETAIL 0.25 nozzle | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 0.6 nozzle] | [printer:BarBaz i3 MK2 0.6 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| max_layer_height = 0.35 | max_layer_height = 0.35 | ||||||
| min_layer_height = 0.1 | min_layer_height = 0.1 | ||||||
| nozzle_diameter = 0.6 | nozzle_diameter = 0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MM Single Mode] | [printer:BarBaz i3 MK2 MM Single Mode] | ||||||
| inherits = *mm-single* | inherits = *mm-single* | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MM Single Mode 0.6 nozzle] | [printer:BarBaz i3 MK2 MM Single Mode 0.6 nozzle] | ||||||
| inherits = *mm-single* | inherits = *mm-single* | ||||||
| nozzle_diameter = 0.6 | nozzle_diameter = 0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MultiMaterial] | [printer:BarBaz i3 MK2 MultiMaterial] | ||||||
| inherits = *mm-multi* | inherits = *mm-multi* | ||||||
| nozzle_diameter = 0.4,0.4,0.4,0.4 | nozzle_diameter = 0.4,0.4,0.4,0.4 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MultiMaterial 0.6 nozzle] | [printer:BarBaz i3 MK2 MultiMaterial 0.6 nozzle] | ||||||
| inherits = *mm-multi* | inherits = *mm-multi* | ||||||
| nozzle_diameter = 0.6,0.6,0.6,0.6 | nozzle_diameter = 0.6,0.6,0.6,0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK3] | [printer:BarBaz i3 MK3] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_BarBaz3D\nPRINTER_MODEL_MK3\n | ||||||
| retract_lift_below = 209 | retract_lift_below = 209 | ||||||
| start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | ||||||
| printer_model = M1 | printer_model = M1 | ||||||
| default_print_profile = 0.15mm OPTIMAL MK3 | default_print_profile = 0.15mm OPTIMAL MK3 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK3 0.25 nozzle] | [printer:BarBaz i3 MK3 0.25 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| nozzle_diameter = 0.25 | nozzle_diameter = 0.25 | ||||||
| printer_variant = 0.25 | printer_variant = 0.25 | ||||||
| end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_BarBaz3D\nPRINTER_MODEL_MK3\n | ||||||
| retract_lift_below = 209 | retract_lift_below = 209 | ||||||
| start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | ||||||
| printer_model = M1 | printer_model = M1 | ||||||
| default_print_profile = 0.10mm DETAIL MK3 | default_print_profile = 0.10mm DETAIL MK3 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK3 0.6 nozzle] | [printer:BarBaz i3 MK3 0.6 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| nozzle_diameter = 0.6 | nozzle_diameter = 0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_BarBaz3D\nPRINTER_MODEL_MK3\n | ||||||
| retract_lift_below = 209 | retract_lift_below = 209 | ||||||
| start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | ||||||
| printer_model = M1 | printer_model = M1 | ||||||
|  |  | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| # Print profiles for the Prusa Research printers. | # Print profiles for the Foobar Research printers. | ||||||
| 
 | 
 | ||||||
| [vendor] | [vendor] | ||||||
| # Vendor name will be shown by the Config Wizard. | # Vendor name will be shown by the Config Wizard. | ||||||
|  | @ -735,11 +735,11 @@ first_layer_temperature = 195 | ||||||
| start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | ||||||
| temperature = 195 | temperature = 195 | ||||||
| 
 | 
 | ||||||
| [filament:Prusa ABS] | [filament:Foobar ABS] | ||||||
| inherits = *ABS* | inherits = *ABS* | ||||||
| filament_notes = "List of materials tested with standart ABS print settings for MK2:\n\nEsun ABS\nFil-A-Gehr ABS\nHatchboxABS\nPlasty Mladeč ABS" | filament_notes = "List of materials tested with standart ABS print settings for MK2:\n\nEsun ABS\nFil-A-Gehr ABS\nHatchboxABS\nPlasty Mladeč ABS" | ||||||
| 
 | 
 | ||||||
| [filament:Prusa HIPS] | [filament:Foobar HIPS] | ||||||
| inherits = *ABS* | inherits = *ABS* | ||||||
| bridge_fan_speed = 50 | bridge_fan_speed = 50 | ||||||
| cooling = 1 | cooling = 1 | ||||||
|  | @ -755,11 +755,11 @@ min_fan_speed = 20 | ||||||
| start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | start_filament_gcode = "M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}10{endif}; Filament gcode" | ||||||
| temperature = 220 | temperature = 220 | ||||||
| 
 | 
 | ||||||
| [filament:Prusa PET] | [filament:Foobar PET] | ||||||
| inherits = *PET* | inherits = *PET* | ||||||
| filament_notes = "List of manufacturers tested with standart PET print settings for MK2:\n\nE3D Edge\nFillamentum CPE GH100\nPlasty Mladeč PETG" | filament_notes = "List of manufacturers tested with standart PET print settings for MK2:\n\nE3D Edge\nFillamentum CPE GH100\nPlasty Mladeč PETG" | ||||||
| 
 | 
 | ||||||
| [filament:Prusa PLA] | [filament:Foobar PLA] | ||||||
| inherits = *PLA* | inherits = *PLA* | ||||||
| filament_notes = "List of materials tested with standart PLA print settings for MK2:\n\nDas Filament\nEsun PLA\nEUMAKERS PLA\nFiberlogy HD-PLA\nFillamentum PLA\nFloreon3D\nHatchbox PLA\nPlasty Mladeč PLA\nPrimavalue PLA\nProto pasta Matte Fiber\nVerbatim PLA\nVerbatim BVOH" | filament_notes = "List of materials tested with standart PLA print settings for MK2:\n\nDas Filament\nEsun PLA\nEUMAKERS PLA\nFiberlogy HD-PLA\nFillamentum PLA\nFloreon3D\nHatchbox PLA\nPlasty Mladeč PLA\nPrimavalue PLA\nProto pasta Matte Fiber\nVerbatim PLA\nVerbatim BVOH" | ||||||
| 
 | 
 | ||||||
|  | @ -855,7 +855,7 @@ min_layer_height = 0.07 | ||||||
| nozzle_diameter = 0.4 | nozzle_diameter = 0.4 | ||||||
| octoprint_apikey =  | octoprint_apikey =  | ||||||
| octoprint_host =  | octoprint_host =  | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_Foobar3D\nPRINTER_MODEL_MK2\n | ||||||
| printer_settings_id =  | printer_settings_id =  | ||||||
| retract_before_travel = 1 | retract_before_travel = 1 | ||||||
| retract_before_wipe = 0% | retract_before_wipe = 0% | ||||||
|  | @ -882,7 +882,7 @@ z_offset = 0 | ||||||
| printer_model = M2 | printer_model = M2 | ||||||
| printer_variant = 0.4 | printer_variant = 0.4 | ||||||
| default_print_profile = 0.15mm OPTIMAL | default_print_profile = 0.15mm OPTIMAL | ||||||
| default_filament_profile = Prusa PLA | default_filament_profile = Foobar PLA | ||||||
| 
 | 
 | ||||||
| [printer:*multimaterial*] | [printer:*multimaterial*] | ||||||
| inherits = *common* | inherits = *common* | ||||||
|  | @ -903,7 +903,7 @@ printer_model = M3 | ||||||
| [printer:*mm-single*] | [printer:*mm-single*] | ||||||
| inherits = *multimaterial* | inherits = *multimaterial* | ||||||
| end_gcode = G1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors\n\n | end_gcode = G1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors\n\n | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_Foobar3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | ||||||
| start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT?\nM104 S[first_layer_temperature]\nM140 S[first_layer_bed_temperature]\nM109 S[first_layer_temperature]\nM190 S[first_layer_bed_temperature]\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100\nM92 E140\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\nG92 E0.0 | start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT?\nM104 S[first_layer_temperature]\nM140 S[first_layer_bed_temperature]\nM109 S[first_layer_temperature]\nM190 S[first_layer_bed_temperature]\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100\nM92 E140\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\nG92 E0.0 | ||||||
| 
 | 
 | ||||||
| [printer:*mm-multi*] | [printer:*mm-multi*] | ||||||
|  | @ -911,14 +911,14 @@ inherits = *multimaterial* | ||||||
| end_gcode = {if not has_wipe_tower}\n; Pull the filament into the cooling tubes.\nG1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\n{endif}\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors | end_gcode = {if not has_wipe_tower}\n; Pull the filament into the cooling tubes.\nG1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7  \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3  \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\n{endif}\nM107 ; fan off\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0  ; home X axis\nM84     ; disable motors | ||||||
| extruder_colour = #FFAA55;#5182DB;#4ECDD3;#FB7259 | extruder_colour = #FFAA55;#5182DB;#4ECDD3;#FB7259 | ||||||
| nozzle_diameter = 0.4,0.4,0.4,0.4 | nozzle_diameter = 0.4,0.4,0.4,0.4 | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_Foobar3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN | ||||||
| start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT[initial_tool]\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100 ; set max feedrate\nM92 E140 ; E-steps per filament milimeter\n{if not has_wipe_tower}\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\n{endif}\nG92 E0.0 | start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT[initial_tool]\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100 ; set max feedrate\nM92 E140 ; E-steps per filament milimeter\n{if not has_wipe_tower}\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0  F1000.0\nG1 X160.0 E20.0  F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\n{endif}\nG92 E0.0 | ||||||
| variable_layer_height = 0 | variable_layer_height = 0 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2] | [printer:Foobar i3 MK2] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 0.25 nozzle] | [printer:Foobar i3 MK2 0.25 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| max_layer_height = 0.1 | max_layer_height = 0.1 | ||||||
| min_layer_height = 0.05 | min_layer_height = 0.05 | ||||||
|  | @ -929,56 +929,56 @@ variable_layer_height = 0 | ||||||
| printer_variant = 0.25 | printer_variant = 0.25 | ||||||
| default_print_profile = 0.10mm DETAIL 0.25 nozzle | default_print_profile = 0.10mm DETAIL 0.25 nozzle | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 0.6 nozzle] | [printer:Foobar i3 MK2 0.6 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| max_layer_height = 0.35 | max_layer_height = 0.35 | ||||||
| min_layer_height = 0.1 | min_layer_height = 0.1 | ||||||
| nozzle_diameter = 0.6 | nozzle_diameter = 0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MM Single Mode] | [printer:Foobar i3 MK2 MM Single Mode] | ||||||
| inherits = *mm-single* | inherits = *mm-single* | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MM Single Mode 0.6 nozzle] | [printer:Foobar i3 MK2 MM Single Mode 0.6 nozzle] | ||||||
| inherits = *mm-single* | inherits = *mm-single* | ||||||
| nozzle_diameter = 0.6 | nozzle_diameter = 0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MultiMaterial] | [printer:Foobar i3 MK2 MultiMaterial] | ||||||
| inherits = *mm-multi* | inherits = *mm-multi* | ||||||
| nozzle_diameter = 0.4,0.4,0.4,0.4 | nozzle_diameter = 0.4,0.4,0.4,0.4 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK2 MultiMaterial 0.6 nozzle] | [printer:Foobar i3 MK2 MultiMaterial 0.6 nozzle] | ||||||
| inherits = *mm-multi* | inherits = *mm-multi* | ||||||
| nozzle_diameter = 0.6,0.6,0.6,0.6 | nozzle_diameter = 0.6,0.6,0.6,0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK3] | [printer:Foobar i3 MK3] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_Foobar3D\nPRINTER_MODEL_MK3\n | ||||||
| retract_lift_below = 209 | retract_lift_below = 209 | ||||||
| start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | ||||||
| printer_model = M1 | printer_model = M1 | ||||||
| default_print_profile = 0.15mm OPTIMAL MK3 | default_print_profile = 0.15mm OPTIMAL MK3 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK3 0.25 nozzle] | [printer:Foobar i3 MK3 0.25 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| nozzle_diameter = 0.25 | nozzle_diameter = 0.25 | ||||||
| printer_variant = 0.25 | printer_variant = 0.25 | ||||||
| end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_Foobar3D\nPRINTER_MODEL_MK3\n | ||||||
| retract_lift_below = 209 | retract_lift_below = 209 | ||||||
| start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | ||||||
| printer_model = M1 | printer_model = M1 | ||||||
| default_print_profile = 0.10mm DETAIL MK3 | default_print_profile = 0.10mm DETAIL MK3 | ||||||
| 
 | 
 | ||||||
| [printer:Original Prusa i3 MK3 0.6 nozzle] | [printer:Foobar i3 MK3 0.6 nozzle] | ||||||
| inherits = *common* | inherits = *common* | ||||||
| nozzle_diameter = 0.6 | nozzle_diameter = 0.6 | ||||||
| printer_variant = 0.6 | printer_variant = 0.6 | ||||||
| end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\nG1 X0 Y200; home X axis\nM84 ; disable motors | ||||||
| printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n | printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_Foobar3D\nPRINTER_MODEL_MK3\n | ||||||
| retract_lift_below = 209 | retract_lift_below = 209 | ||||||
| start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | start_gcode = M115 U3.1.1-RC5 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83  ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0  F1000.0 ; intro line\nG1 X100.0 E12.5  F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif} | ||||||
| printer_model = M1 | printer_model = M1 | ||||||
|  |  | ||||||
|  | @ -17,7 +17,6 @@ | ||||||
| #include "GUI.hpp" | #include "GUI.hpp" | ||||||
| #include "slic3r/Utils/PresetUpdater.hpp" | #include "slic3r/Utils/PresetUpdater.hpp" | ||||||
| 
 | 
 | ||||||
| // TODO: Wizard vs Assistant
 |  | ||||||
| 
 | 
 | ||||||
| namespace Slic3r { | namespace Slic3r { | ||||||
| namespace GUI { | namespace GUI { | ||||||
|  | @ -205,9 +204,18 @@ void ConfigWizardPage::enable_next(bool enable) { parent->p->enable_next(enable) | ||||||
| PageWelcome::PageWelcome(ConfigWizard *parent) : | PageWelcome::PageWelcome(ConfigWizard *parent) : | ||||||
| 	ConfigWizardPage(parent, wxString::Format(_(L("Welcome to the Slic3r %s")), ConfigWizard::name()), _(L("Welcome"))), | 	ConfigWizardPage(parent, wxString::Format(_(L("Welcome to the Slic3r %s")), ConfigWizard::name()), _(L("Welcome"))), | ||||||
| 	printer_picker(nullptr), | 	printer_picker(nullptr), | ||||||
| 	others_buttons(new wxPanel(parent)) | 	others_buttons(new wxPanel(parent)), | ||||||
|  | 	cbox_reset(new wxCheckBox(this, wxID_ANY, _(L("Remove user profiles - install from scratch (a snapshot will be taken beforehand)")))) | ||||||
| { | { | ||||||
| 	append_text(_(L("Hello, welcome to Slic3r Prusa Edition! TODO: This text."))); | 	if (wizard_p()->flag_startup && wizard_p()->flag_empty_datadir) { | ||||||
|  | 		wxString::Format(_(L("Run %s")), ConfigWizard::name()); | ||||||
|  | 		append_text(wxString::Format( | ||||||
|  | 			_(L("Hello, welcome to Slic3r Prusa Edition! This %s helps you with the initial configuration; just a few settings and you will be ready to print.")), | ||||||
|  | 			ConfigWizard::name()) | ||||||
|  | 		); | ||||||
|  | 	} else { | ||||||
|  | 		append(cbox_reset); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	const auto &vendors = wizard_p()->vendors; | 	const auto &vendors = wizard_p()->vendors; | ||||||
| 	const auto vendor_prusa = vendors.find("PrusaResearch"); | 	const auto vendor_prusa = vendors.find("PrusaResearch"); | ||||||
|  | @ -720,14 +728,22 @@ void ConfigWizard::priv::apply_config(AppConfig *app_config, PresetBundle *prese | ||||||
| 			// This vendor needs to be installed
 | 			// This vendor needs to be installed
 | ||||||
| 			install_bundles.emplace_back(vendor_rsrc.second); | 			install_bundles.emplace_back(vendor_rsrc.second); | ||||||
| 		} | 		} | ||||||
|  | 
 | ||||||
|  | 		// If the datadir was empty don't take a snapshot (it would just be an empty snapshot)
 | ||||||
|  | 		const bool snapshot = !flag_empty_datadir || page_welcome->reset_user_profile(); | ||||||
| 		if (install_bundles.size() > 0) { | 		if (install_bundles.size() > 0) { | ||||||
| 			updater->install_bundles_rsrc(std::move(install_bundles)); | 			// Install bundles from resources.
 | ||||||
|  | 			updater->install_bundles_rsrc(std::move(install_bundles), snapshot); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if (page_welcome->reset_user_profile()) { | ||||||
|  | 			preset_bundle->reset(true); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		app_config->set_vendors(appconfig_vendors); | 		app_config->set_vendors(appconfig_vendors); | ||||||
| 		app_config->set("version_check", page_update->version_check ? "1" : "0"); | 		app_config->set("version_check", page_update->version_check ? "1" : "0"); | ||||||
| 		app_config->set("preset_update", page_update->preset_update ? "1" : "0"); | 		app_config->set("preset_update", page_update->preset_update ? "1" : "0"); | ||||||
| 		if (fresh_start) | 		if (flag_startup) | ||||||
| 			app_config->reset_selections(); | 			app_config->reset_selections(); | ||||||
| 		// ^ TODO: replace with appropriate printer selection
 | 		// ^ TODO: replace with appropriate printer selection
 | ||||||
| 		preset_bundle->load_presets(*app_config); | 		preset_bundle->load_presets(*app_config); | ||||||
|  | @ -743,11 +759,13 @@ void ConfigWizard::priv::apply_config(AppConfig *app_config, PresetBundle *prese | ||||||
| 
 | 
 | ||||||
| // Public
 | // Public
 | ||||||
| 
 | 
 | ||||||
| ConfigWizard::ConfigWizard(wxWindow *parent, bool fresh_start) : | ConfigWizard::ConfigWizard(wxWindow *parent, bool startup, bool empty_datadir) : | ||||||
| 	wxDialog(parent, wxID_ANY, name(), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER), | 	wxDialog(parent, wxID_ANY, name(), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER), | ||||||
| 	p(new priv(this)) | 	p(new priv(this)) | ||||||
| { | { | ||||||
| 	p->fresh_start = fresh_start; | 	p->flag_startup = startup; | ||||||
|  | 	p->flag_empty_datadir = empty_datadir; | ||||||
|  | 
 | ||||||
| 	p->load_vendors(); | 	p->load_vendors(); | ||||||
| 	p->custom_config.reset(DynamicPrintConfig::new_from_defaults_keys({ | 	p->custom_config.reset(DynamicPrintConfig::new_from_defaults_keys({ | ||||||
| 		"gcode_flavor", "bed_shape", "nozzle_diameter", "filament_diameter", "temperature", "bed_temperature", | 		"gcode_flavor", "bed_shape", "nozzle_diameter", "filament_diameter", "temperature", "bed_temperature", | ||||||
|  |  | ||||||
|  | @ -16,7 +16,7 @@ namespace GUI { | ||||||
| class ConfigWizard: public wxDialog | class ConfigWizard: public wxDialog | ||||||
| { | { | ||||||
| public: | public: | ||||||
| 	ConfigWizard(wxWindow *parent, bool fresh_start); | 	ConfigWizard(wxWindow *parent, bool startup, bool empty_datadir); | ||||||
| 	ConfigWizard(ConfigWizard &&) = delete; | 	ConfigWizard(ConfigWizard &&) = delete; | ||||||
| 	ConfigWizard(const ConfigWizard &) = delete; | 	ConfigWizard(const ConfigWizard &) = delete; | ||||||
| 	ConfigWizard &operator=(ConfigWizard &&) = delete; | 	ConfigWizard &operator=(ConfigWizard &&) = delete; | ||||||
|  |  | ||||||
|  | @ -100,12 +100,14 @@ struct PageWelcome: ConfigWizardPage | ||||||
| { | { | ||||||
| 	PrinterPicker *printer_picker; | 	PrinterPicker *printer_picker; | ||||||
| 	wxPanel *others_buttons; | 	wxPanel *others_buttons; | ||||||
|  | 	wxCheckBox *cbox_reset; | ||||||
| 
 | 
 | ||||||
| 	PageWelcome(ConfigWizard *parent); | 	PageWelcome(ConfigWizard *parent); | ||||||
| 
 | 
 | ||||||
| 	virtual wxPanel* extra_buttons() { return others_buttons; } | 	virtual wxPanel* extra_buttons() { return others_buttons; } | ||||||
| 	virtual void on_page_set(); | 	virtual void on_page_set(); | ||||||
| 
 | 
 | ||||||
|  | 	bool reset_user_profile() const { return cbox_reset->GetValue(); } | ||||||
| 	void on_variant_checked(); | 	void on_variant_checked(); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -188,9 +190,10 @@ private: | ||||||
| struct ConfigWizard::priv | struct ConfigWizard::priv | ||||||
| { | { | ||||||
| 	ConfigWizard *q; | 	ConfigWizard *q; | ||||||
| 	bool fresh_start; | 	bool flag_startup; | ||||||
| 	AppConfig appconfig_vendors;    // TODO: use order-preserving container
 | 	bool flag_empty_datadir; | ||||||
| 	std::unordered_map<std::string, VendorProfile> vendors;   // TODO: just set?
 | 	AppConfig appconfig_vendors; | ||||||
|  | 	std::unordered_map<std::string, VendorProfile> vendors; | ||||||
| 	std::unordered_map<std::string, std::string> vendors_rsrc; | 	std::unordered_map<std::string, std::string> vendors_rsrc; | ||||||
| 	std::unique_ptr<DynamicPrintConfig> custom_config; | 	std::unique_ptr<DynamicPrintConfig> custom_config; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -390,7 +390,7 @@ void add_config_menu(wxMenuBar *menu, int event_preferences_changed, int event_l | ||||||
| 	local_menu->Bind(wxEVT_MENU, [config_id_base, event_language_change, event_preferences_changed](wxEvent &event){ | 	local_menu->Bind(wxEVT_MENU, [config_id_base, event_language_change, event_preferences_changed](wxEvent &event){ | ||||||
| 		switch (event.GetId() - config_id_base) { | 		switch (event.GetId() - config_id_base) { | ||||||
| 		case ConfigMenuWizard: | 		case ConfigMenuWizard: | ||||||
|             config_wizard(0); |             config_wizard(false, false); | ||||||
|             break; |             break; | ||||||
| 		case ConfigMenuTakeSnapshot: | 		case ConfigMenuTakeSnapshot: | ||||||
| 			// Take a configuration snapshot.
 | 			// Take a configuration snapshot.
 | ||||||
|  | @ -465,33 +465,35 @@ bool check_unsaved_changes() | ||||||
| void config_wizard_startup(bool app_config_exists) | void config_wizard_startup(bool app_config_exists) | ||||||
| { | { | ||||||
| 	if (! app_config_exists || g_PresetBundle->has_defauls_only()) { | 	if (! app_config_exists || g_PresetBundle->has_defauls_only()) { | ||||||
| 		config_wizard(true); | 		config_wizard(true, true); | ||||||
| 	} else if (g_AppConfig->legacy_datadir()) { | 	} else if (g_AppConfig->legacy_datadir()) { | ||||||
| 		// Looks like user has legacy pre-vendorbundle data directory,
 | 		// Looks like user has legacy pre-vendorbundle data directory,
 | ||||||
| 		// explain what this is and run the wizard
 | 		// explain what this is and run the wizard
 | ||||||
| 
 | 
 | ||||||
| 		const auto msg = _(L("Configuration update")); | 		const auto msg = _(L("Configuration update")); | ||||||
| 		const auto ext_msg = _(L( | 		const auto ext_msg = wxString::Format( | ||||||
| 			"Slic3r PE now uses an updated configuration structure.\n\n" | 			_(L( | ||||||
|  | 				"Slic3r PE now uses an updated configuration structure.\n\n" | ||||||
| 
 | 
 | ||||||
| 			"So called 'System presets' have been introduced, which hold the built-in default settings for various " | 				"So called 'System presets' have been introduced, which hold the built-in default settings for various " | ||||||
| 			"printers. These System presets cannot be modified, instead, users now may create their" | 				"printers. These System presets cannot be modified, instead, users now may create their" | ||||||
| 			"own presets inheriting settings from one of the System presets.\n" | 				"own presets inheriting settings from one of the System presets.\n" | ||||||
| 			"An inheriting preset may either inherit a particular value from its parent or override it with a customized value.\n\n" | 				"An inheriting preset may either inherit a particular value from its parent or override it with a customized value.\n\n" | ||||||
| 
 | 
 | ||||||
| 			// TODO: Assistant vs Wizard
 | 				"Please proceed with the %s that follows to set up the new presets " | ||||||
| 			"Please proceed with the Configuration wizard that follows to set up the new presets " | 				"and to choose whether to enable automatic preset updates." | ||||||
| 			"and to choose whether to enable automatic preset updates." | 			)), | ||||||
| 		)); | 			ConfigWizard::name() | ||||||
|  | 		); | ||||||
| 		wxMessageDialog dlg(NULL, msg, _(L("Configuration update")), wxOK|wxCENTRE); | 		wxMessageDialog dlg(NULL, msg, _(L("Configuration update")), wxOK|wxCENTRE); | ||||||
| 		dlg.SetExtendedMessage(ext_msg); | 		dlg.SetExtendedMessage(ext_msg); | ||||||
| 		const auto res = dlg.ShowModal(); | 		const auto res = dlg.ShowModal(); | ||||||
| 
 | 
 | ||||||
| 		config_wizard(true); | 		config_wizard(true, false); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void config_wizard(bool fresh_start)   // TODO: fresh_start useful ?
 | void config_wizard(bool startup, bool empty_datadir) | ||||||
| { | { | ||||||
| 	if (g_wxMainFrame == nullptr) | 	if (g_wxMainFrame == nullptr) | ||||||
| 		throw std::runtime_error("Main frame not set"); | 		throw std::runtime_error("Main frame not set"); | ||||||
|  | @ -500,8 +502,7 @@ void config_wizard(bool fresh_start)   // TODO: fresh_start useful ? | ||||||
|     if (! check_unsaved_changes()) |     if (! check_unsaved_changes()) | ||||||
|     	return; |     	return; | ||||||
| 
 | 
 | ||||||
| 	// TODO: Offer "reset user profile" ???
 | 	ConfigWizard wizard(g_wxMainFrame, startup, empty_datadir); | ||||||
| 	ConfigWizard wizard(g_wxMainFrame, fresh_start); |  | ||||||
| 	wizard.run(g_PresetBundle, g_PresetUpdater); | 	wizard.run(g_PresetBundle, g_PresetUpdater); | ||||||
| 
 | 
 | ||||||
|     // Load the currently selected preset into the GUI, update the preset selection box.
 |     // Load the currently selected preset into the GUI, update the preset selection box.
 | ||||||
|  |  | ||||||
|  | @ -97,7 +97,7 @@ extern bool check_unsaved_changes(); | ||||||
| extern void config_wizard_startup(bool app_config_exists); | extern void config_wizard_startup(bool app_config_exists); | ||||||
| 
 | 
 | ||||||
| // Opens the configuration wizard, returns true if wizard is finished & accepted.
 | // Opens the configuration wizard, returns true if wizard is finished & accepted.
 | ||||||
| extern void config_wizard(bool fresh_start); | extern void config_wizard(bool startup, bool empty_datadir); | ||||||
| 
 | 
 | ||||||
| // Create "Preferences" dialog after selecting menu "Preferences" in Perl part
 | // Create "Preferences" dialog after selecting menu "Preferences" in Perl part
 | ||||||
| extern void open_preferences_dialog(int event_preferences); | extern void open_preferences_dialog(int event_preferences); | ||||||
|  |  | ||||||
|  | @ -155,7 +155,7 @@ struct PresetUpdater::priv | ||||||
| 
 | 
 | ||||||
| 	void check_install_indices() const; | 	void check_install_indices() const; | ||||||
| 	Updates config_update() const; | 	Updates config_update() const; | ||||||
| 	void perform_updates(Updates &&updates) const; | 	void perform_updates(Updates &&updates, bool snapshot = true) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| PresetUpdater::priv::priv(int version_online_event) : | PresetUpdater::priv::priv(int version_online_event) : | ||||||
|  | @ -348,9 +348,11 @@ Updates PresetUpdater::priv::config_update() const | ||||||
| 	return updates; | 	return updates; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PresetUpdater::priv::perform_updates(Updates &&updates) const | void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) const | ||||||
| { | { | ||||||
| 	SnapshotDB::singleton().take_snapshot(*GUI::get_app_config(), Snapshot::SNAPSHOT_UPGRADE); | 	if (snapshot) { | ||||||
|  | 		SnapshotDB::singleton().take_snapshot(*GUI::get_app_config(), Snapshot::SNAPSHOT_UPGRADE); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	for (const auto &update : updates) { | 	for (const auto &update : updates) { | ||||||
| 		fs::copy_file(update.source, update.target, fs::copy_option::overwrite_if_exists); | 		fs::copy_file(update.source, update.target, fs::copy_option::overwrite_if_exists); | ||||||
|  | @ -458,7 +460,7 @@ void PresetUpdater::config_update() const | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PresetUpdater::install_bundles_rsrc(std::vector<std::string> &&bundles) | void PresetUpdater::install_bundles_rsrc(std::vector<std::string> &&bundles, bool snapshot) | ||||||
| { | { | ||||||
| 	Updates updates; | 	Updates updates; | ||||||
| 
 | 
 | ||||||
|  | @ -468,7 +470,7 @@ void PresetUpdater::install_bundles_rsrc(std::vector<std::string> &&bundles) | ||||||
| 		updates.emplace_back(std::move(path_in_rsrc), std::move(path_in_vendors)); | 		updates.emplace_back(std::move(path_in_rsrc), std::move(path_in_vendors)); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	p->perform_updates(std::move(updates)); | 	p->perform_updates(std::move(updates), snapshot); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,7 +23,7 @@ public: | ||||||
| 	void sync(PresetBundle *preset_bundle); | 	void sync(PresetBundle *preset_bundle); | ||||||
| 	void slic3r_update_notify(); | 	void slic3r_update_notify(); | ||||||
| 	void config_update() const; | 	void config_update() const; | ||||||
| 	void install_bundles_rsrc(std::vector<std::string> &&bundles); | 	void install_bundles_rsrc(std::vector<std::string> &&bundles, bool snapshot = true); | ||||||
| private: | private: | ||||||
| 	struct priv; | 	struct priv; | ||||||
| 	std::unique_ptr<priv> p; | 	std::unique_ptr<priv> p; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Kral
						Vojtech Kral