Profile.py 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. # Copyright (c) 2016 Ultimaker B.V.
  2. # Cura is released under the terms of the AGPLv3 or higher.
  3. import configparser #To read config files.
  4. import io #To write config files to strings as if they were files.
  5. import UM.VersionUpgrade
  6. ## Creates a new profile instance by parsing a serialised profile in version 1
  7. # of the file format.
  8. #
  9. # \param serialised The serialised form of a profile in version 1.
  10. # \return A profile instance, or None if the file format is incorrect.
  11. def importFrom(serialised):
  12. try:
  13. return Profile(serialised)
  14. except (configparser.Error, UM.VersionUpgrade.FormatException, UM.VersionUpgrade.InvalidVersionException):
  15. return None
  16. ## A representation of a profile used as intermediary form for conversion from
  17. # one format to the other.
  18. class Profile:
  19. ## Reads version 1 of the file format, storing it in memory.
  20. #
  21. # \param serialised A string with the contents of a machine instance file.
  22. def __init__(self, serialised):
  23. parser = configparser.ConfigParser(interpolation = None)
  24. parser.read_string(serialised)
  25. # Check correctness.
  26. if not parser.has_section("general"):
  27. raise UM.VersionUpgrade.FormatException("No \"general\" section.")
  28. if not parser.has_option("general", "version"):
  29. raise UM.VersionUpgrade.FormatException("No \"version\" in the \"general\" section.")
  30. if int(parser.get("general", "version")) != 1: # Hard-coded profile version here. If this number changes the entire function needs to change.
  31. raise UM.VersionUpgrade.InvalidVersionException("The version of this profile is wrong. It must be 1.")
  32. # Parse the general section.
  33. self._name = parser.get("general", "name")
  34. self._type = parser.get("general", "type", fallback = None)
  35. if "weight" in parser["general"]:
  36. self._weight = int(parser.get("general", "weight"))
  37. else:
  38. self._weight = None
  39. self._machine_type_id = parser.get("general", "machine_type", fallback = None)
  40. self._machine_variant_name = parser.get("general", "machine_variant", fallback = None)
  41. self._machine_instance_name = parser.get("general", "machine_instance", fallback = None)
  42. if "material" in parser["general"]:
  43. self._material_name = parser.get("general", "material")
  44. elif self._type == "material":
  45. self._material_name = parser.get("general", "name", fallback = None)
  46. else:
  47. self._material_name = None
  48. # Parse the settings.
  49. self._settings = {}
  50. if parser.has_section("settings"):
  51. for key, value in parser["settings"].items():
  52. self._settings[key] = value
  53. # Parse the defaults and the disabled defaults.
  54. self._changed_settings_defaults = {}
  55. if parser.has_section("defaults"):
  56. for key, value in parser["defaults"].items():
  57. self._changed_settings_defaults[key] = value
  58. self._disabled_settings_defaults = []
  59. if parser.has_section("disabled_defaults"):
  60. disabled_defaults_string = parser.get("disabled_defaults", "values")
  61. self._disabled_settings_defaults = [item for item in disabled_defaults_string.split(",") if item != ""] # Split by comma.
  62. ## Serialises this profile as file format version 2.
  63. #
  64. # \return A serialised form of this profile, serialised in version 2 of
  65. # the file format.
  66. def export(self):
  67. import VersionUpgrade21to22 # Import here to prevent circular dependencies.
  68. config = configparser.ConfigParser(interpolation = None)
  69. config.add_section("general")
  70. config.set("general", "version", "2") #Hard-coded profile version 2.
  71. config.set("general", "name", self._name)
  72. if self._type:
  73. config.set("general", "type", self._type)
  74. if self._weight:
  75. config.set("general", "weight", self._weight)
  76. if self._machine_type_id:
  77. translated_machine = VersionUpgrade21to22.VersionUpgrade21to22.VersionUpgrade21to22.translatePrinter(self._machine_type_id)
  78. config.set("general", "definition", translated_machine)
  79. else:
  80. config.set("general", "definition", "fdmprinter")
  81. if self._machine_variant_name:
  82. if self._machine_type_id:
  83. config.set("general", "variant", VersionUpgrade21to22.VersionUpgrade21to22.VersionUpgrade21to22.translateVariant(self._machine_variant_name, self._machine_type_id))
  84. else:
  85. config.set("general", "variant", self._machine_variant_name)
  86. if self._material_name and self._type != "material":
  87. config.set("general", "material", self._material_name)
  88. if self._settings:
  89. VersionUpgrade21to22.VersionUpgrade21to22.VersionUpgrade21to22.translateSettings(self._settings)
  90. config.add_section("values")
  91. for key, value in self._settings.items():
  92. config.set("values", key, str(value))
  93. if self._changed_settings_defaults:
  94. VersionUpgrade21to22.VersionUpgrade21to22.VersionUpgrade21to22.translateSettings(self._changed_settings_defaults)
  95. config.add_section("defaults")
  96. for key, value in self._changed_settings_defaults.items():
  97. config.set("defaults", key, str(value))
  98. if self._disabled_settings_defaults:
  99. disabled_settings_defaults = [VersionUpgrade21to22.VersionUpgrade21to22.VersionUpgrade21to22.translateSettingName(setting)
  100. for setting in self._disabled_settings_defaults]
  101. config.add_section("disabled_defaults")
  102. disabled_defaults_string = str(disabled_settings_defaults[0]) #Must be at least 1 item, otherwise we wouldn't enter this if statement.
  103. for item in disabled_settings_defaults[1:]:
  104. disabled_defaults_string += "," + str(item)
  105. output = io.StringIO()
  106. config.write(output)
  107. return output.getvalue()