mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-06 22:47:29 -06:00
Move prefix length out of for loop
It is cached so it only needs to be computed once. Contributes to issue CURA-34.
This commit is contained in:
parent
cfa4382052
commit
6908f2c011
2 changed files with 7 additions and 5 deletions
|
@ -30,6 +30,7 @@ class GCodeProfileReader(ProfileReader):
|
|||
# None \endcode is returned.
|
||||
def read(self, file_name):
|
||||
prefix = ";SETTING_" + str(version) + " "
|
||||
prefix_length = len(prefix)
|
||||
|
||||
#Loading all settings from the file. They are all at the end, but Python has no reverse seek any more since Python3. TODO: Consider moving settings to the start?
|
||||
serialised = "" #Will be filled with the serialised profile.
|
||||
|
@ -37,7 +38,7 @@ class GCodeProfileReader(ProfileReader):
|
|||
with open(file_name) as f:
|
||||
for line in f:
|
||||
if line.startswith(prefix):
|
||||
serialised += line[len(prefix):-1] #Remove the prefix and the newline from the line, and add it to the rest.
|
||||
serialised += line[prefix_length : -1] #Remove the prefix and the newline from the line, and add it to the rest.
|
||||
except IOError as e:
|
||||
Logger.log("e", "Unable to open file %s for reading: %s", file_name, str(e))
|
||||
return None
|
||||
|
|
|
@ -44,6 +44,7 @@ class GCodeWriter(MeshWriter):
|
|||
# \return A serialised string of the profile.
|
||||
def _serialiseProfile(self, profile):
|
||||
prefix = ";SETTING_" + str(version) + " " #The prefix to put before each line.
|
||||
prefix_length = len(prefix)
|
||||
|
||||
serialised = profile.serialise()
|
||||
|
||||
|
@ -60,8 +61,8 @@ class GCodeWriter(MeshWriter):
|
|||
|
||||
#Introduce line breaks so that each comment is no longer than 80 characters. Prepend each line with the prefix.
|
||||
result = ""
|
||||
for pos in range(0, len(serialised), 80 - len(prefix)): #Lines have 80 characters, so the payload of each line is 80 - prefix.
|
||||
result += prefix + serialised[pos : pos + 80 - len(prefix)] + "\n"
|
||||
for pos in range(0, len(serialised), 80 - prefix_length): #Lines have 80 characters, so the payload of each line is 80 - prefix.
|
||||
result += prefix + serialised[pos : pos + 80 - prefix_length] + "\n"
|
||||
serialised = result
|
||||
|
||||
return serialised
|
Loading…
Add table
Add a link
Reference in a new issue