parent.remove -> delete (#3600)

pull/3605/head
Kaalleen 2025-03-22 17:43:50 +01:00 zatwierdzone przez GitHub
rodzic ee14e4e28a
commit 40405edfe1
Nie znaleziono w bazie danych klucza dla tego podpisu
ID klucza GPG: B5690EEEBB952194
34 zmienionych plików z 61 dodań i 77 usunięć

Wyświetl plik

@ -181,7 +181,7 @@ class Clone(EmbroideryElement):
for clone in clones:
clone.replace_with(Clone(clone).resolve_clone()[0])
source_parent.remove(cloned_node)
cloned_node.delete()
# Add the cloned node to be a sibling of this node
parent.add(cloned_node)

Wyświetl plik

@ -163,7 +163,7 @@ class BatchLettering(InkstitchExtension):
index = parent.index(lettering_group)
if text_positioning_path is not None:
parent.insert(index, text_positioning_path)
parent.remove(lettering_group)
lettering_group.delete()
def generate_output_file(self, file_format, path, text, stitch_plan):
text = text.replace('\n', '')
@ -217,7 +217,7 @@ class BatchLettering(InkstitchExtension):
index = parent.index(text_positioning_path)
parent.insert(index, lettering_group)
TextAlongPath(self.svg, lettering_group, text_positioning_path, self.options.text_position)
parent.remove(text_positioning_path)
text_positioning_path.delete()
self.get_elements()
stitch_groups = self.elements_to_stitch_groups(self.elements)

Wyświetl plik

@ -159,4 +159,4 @@ class BreakApart(InkstitchExtension):
el.set('d', str(d))
el.set('transform', get_correction_transform(element.node))
parent.insert(index, el)
parent.remove(element.node)
element.node.delete()

Wyświetl plik

@ -73,8 +73,8 @@ class Cleanup(InkstitchExtension):
errormsg(_("{num_elements_removed} elements removed").format(num_elements_removed=num_elements_removed))
for element in self.elements_to_remove:
element.getparent().remove(element)
element.delete()
errormsg(_("{num_groups_removed} groups/layers removed").format(num_groups_removed=num_groups_removed))
for group in self.groups_to_remove:
group.getparent().remove(group)
group.delete()

Wyświetl plik

@ -68,7 +68,7 @@ class ConvertToSatin(InkstitchExtension):
joined_satin.node.set('transform', correction_transform)
parent.insert(index, joined_satin.node)
parent.remove(element.node)
element.node.delete()
def convert_path_to_satins(self, path, stroke_width, style_args, path_style, depth=0):
try:

Wyświetl plik

@ -49,7 +49,7 @@ class ConvertToStroke(InkstitchExtension):
)
parent.insert(parent.index(element.node), stroke_element)
if not self.options.keep_satin:
parent.remove(element.node)
element.node.delete()
def path_style(self, element):
color = element.get_style('stroke', '#000000')

Wyświetl plik

@ -33,10 +33,10 @@ class CutSatin(InkstitchExtension):
split_point = command.target_point
command_group = command.use.getparent()
if command_group is not None and command_group.get('id').startswith('command_group'):
command_group.getparent().remove(command_group)
command_group.delete()
else:
command.use.getparent().remove(command.use)
command.connector.getparent().remove(command.connector)
command.use.delete()
command.connector.delete()
new_satins = satin.split(split_point)
if None in new_satins:
@ -44,7 +44,7 @@ class CutSatin(InkstitchExtension):
transform = get_correction_transform(satin.node)
parent = satin.node.getparent()
index = parent.index(satin.node)
parent.remove(satin.node)
satin.node.delete()
for new_satin in new_satins:
new_satin.node.set('transform', transform)
parent.insert(index, new_satin.node)

Wyświetl plik

@ -183,8 +183,7 @@ class CutworkSegmentation(InkstitchExtension):
for element in self.elements:
if isinstance(element, Stroke):
parent = element.node.getparent()
parent.remove(element.node)
element.node.delete()
def path_style(self, element, color):
# set stroke color and make it a running stitch - they don't want to cut zigzags

Wyświetl plik

@ -31,7 +31,7 @@ class DisplayStackingOrder(InkstitchExtension):
# remove layer if empty
if len(layer) == 0:
self.svg.remove(layer)
layer.delete()
def insert_stacking_num(self, layer, num, position):
text = inkex.TextElement(attrib={
@ -49,7 +49,7 @@ class DisplayStackingOrder(InkstitchExtension):
# Remove the existing layer
if layer is not None:
layer.getparent().remove(layer)
layer.delete()
layer = inkex.Group(attrib={
'id': '__inkstitch_stacking_order__',

Wyświetl plik

@ -135,7 +135,7 @@ class FillToSatin(InkstitchExtension):
for element in self.elements:
if not self.options.keep_originals or element.name == "Stroke":
try:
element.node.getparent().remove(element.node)
element.node.delete()
except AttributeError:
pass

Wyświetl plik

@ -87,12 +87,12 @@ class FillToStroke(InkstitchExtension):
# do not use a group in case there is only one line
if len(lines) <= 1:
parent.remove(centerline_group)
centerline_group.delete()
centerline_group = parent
# clean up
if not self.options.keep_original:
parent.remove(element.node)
element.node.delete()
# insert new elements
self._insert_elements(lines, centerline_group, index, element_id, element_label, transform, style)
@ -262,7 +262,7 @@ class FillToStroke(InkstitchExtension):
# it is possible, that we get one element twice (if it has both, a fill and a stroke)
# this means that we already removed it from the svg and we can ignore the error.
try:
cut_line.getparent().remove(cut_line)
cut_line.delete()
except AttributeError:
pass

Wyświetl plik

@ -98,7 +98,7 @@ class GradientBlocks(InkstitchExtension):
block.set('inkstitch:fill_underlay_row_spacing_mm', end_row_spacing)
color_block_group.append(block)
parent.remove(element.node)
element.node.delete()
def _element_to_path(self, shape):
coords = list(shape.exterior.coords)

Wyświetl plik

@ -124,7 +124,7 @@ class JumpToStroke(InkstitchExtension):
block_ids.append(subpath_id)
parent.insert(index, subpath_element)
elements.append(Stroke(subpath_element))
parent.remove(node)
node.delete()
else:
elements.append(element)
self.elements = elements
@ -172,10 +172,10 @@ class JumpToStroke(InkstitchExtension):
if merged:
# remove last element (since it is merged)
last_parent = last_element.node.getparent()
last_parent.remove(last_element.node)
last_element.node.delete()
# remove parent group if empty
if len(last_parent) == 0:
last_parent.getparent().remove(last_parent)
last_parent.delete()
return
if merged:

Wyświetl plik

@ -97,7 +97,7 @@ class TextAlongPath:
except IndexError:
pass
for glyph in text_group.iterchildren():
text_group.remove(glyph)
glyph.delete()
rendered_text = font.render_text(
self.settings.text,
text_group,

Wyświetl plik

@ -40,4 +40,4 @@ class LetteringEditJson(InkstitchExtension):
frame.Show()
app.MainLoop()
self.svg.remove(layer)
layer.delete()

Wyświetl plik

@ -24,4 +24,4 @@ class LetteringFontSample(InkstitchExtension):
app = LetteringFontSampleApp(layer=layer)
app.MainLoop()
if len(layer) == 0:
self.svg.remove(layer)
layer.delete()

Wyświetl plik

@ -32,7 +32,7 @@ class LetteringRemoveKerning(InkstitchExtension):
kerning = svg.xpath(xpath, namespaces=NSS)
if kerning:
kerning = kerning[0]
kerning.getparent().remove(kerning)
kerning.delete()
fontfile.seek(0)
fontfile.write(etree.tostring(svg).decode('utf-8'))
fontfile.truncate()

Wyświetl plik

@ -58,4 +58,4 @@ class PaletteSplitText(InkstitchExtension):
y -= height
parent.insert(0, element)
parent.remove(text)
text.delete()

Wyświetl plik

@ -356,7 +356,7 @@ class Print(InkstitchExtension):
# just bulk up the SVG.
for layer in layers_and_groups:
if layer is not stitch_plan_layer:
svg.remove(layer)
layer.delete()
overview_svg = etree.tostring(svg).decode('utf-8')
color_block_groups = stitch_plan_layer.getchildren()

Wyświetl plik

@ -68,7 +68,7 @@ class Redwork(InkstitchExtension):
# remove input elements
if not self.options.keep_originals:
for element in elements:
element.node.getparent().remove(element.node)
element.node.delete()
def _ensure_starting_point(self, multi_line_string, starting_point):
# returns a MultiLineString whose first LineString starts close to starting_point
@ -97,7 +97,7 @@ class Redwork(InkstitchExtension):
if command:
# remove command symbol
command_group = command.connector.getparent()
command_group.getparent().remove(command_group)
command_group.delete()
# return the first occurence directly
return command.target_point

Wyświetl plik

@ -48,7 +48,7 @@ class RemoveEmbroiderySettings(InkstitchExtension):
xpath = ".//svg:g[starts-with(@id,'command_group')]"
groups = find_elements(self.svg, xpath)
for group in groups:
group.getparent().remove(group)
group.delete()
# remove standalone commands and ungrouped object commands
standalone_commands = ".//svg:use[starts-with(@xlink:href, '#inkstitch_')]|.//svg:path[starts-with(@id, 'command_connector')]"
@ -66,7 +66,7 @@ class RemoveEmbroiderySettings(InkstitchExtension):
connectors = find_elements(self.svg, xpath)
for connector in connectors:
group = connector.getparent()
group.getparent().remove(group)
group.delete()
# remove standalone commands and ungrouped object commands
standalone_commands = ".//svg:use[starts-with(@xlink:href, '#inkstitch_{command}')]"
@ -84,14 +84,14 @@ class RemoveEmbroiderySettings(InkstitchExtension):
group = element.getparent()
if group.getparent() is not None:
if group.get_id().startswith("command_group"):
group.getparent().remove(group)
group.delete()
else:
group.remove(element)
element.delete()
continue
for command in find_commands(element):
if del_option in ('all', command.command):
group = command.connector.getparent()
group.getparent().remove(group)
group.delete()
def remove_commands(self):
if self.svg.selection:
@ -110,7 +110,7 @@ class RemoveEmbroiderySettings(InkstitchExtension):
self.remove_element(element)
def remove_element(self, element):
element.getparent().remove(element)
element.delete()
def remove_inkstitch_attributes(self, elements):
param_to_remove = self.options.del_params

Wyświetl plik

@ -10,28 +10,19 @@ from .base import InkstitchExtension
class Reorder(InkstitchExtension):
# Remove selected objects from the document and re-add them in the order they
# were selected.
# Re-stack elements in the order they were selected.
def effect(self):
objects = self.svg.selection
if not objects:
if len(objects) < 2:
errormsg(_("Please select at least two elements to reorder."))
return
for obj in objects:
if not obj == objects.first():
obj.getparent().remove(obj)
insert_parent = objects[0].getparent()
insert_pos = insert_parent.index(objects[0])
insert_pos = insert_parent.index(objects[0]) + 1
insert_parent.remove(objects[0])
insert_parent[insert_pos:insert_pos] = objects
insert_parent[insert_pos:insert_pos] = list(objects)[1:]
if __name__ == '__main__':
e = Reorder()
e.run()
Reorder().run()

Wyświetl plik

@ -20,7 +20,7 @@ def reset_stitch_plan(svg, delete_stitch_plan=True):
display_method = layer.get(INKSTITCH_ATTRIBS['layer_visibility'], 'unchanged')
invisible_layers = layer.get(INKSTITCH_ATTRIBS['invisible_layers'], '').split(",")
if delete_stitch_plan:
layer.getparent().remove(layer)
layer.delete()
if display_method == "unchanged":
return

Wyświetl plik

@ -156,7 +156,7 @@ class StrokeToLpeSatin(InkstitchExtension):
old_effect_element.set('pattern', pattern_path)
old_effect_element.set('copytype', copy_type)
else:
old_effect_element.getparent().remove(old_effect_element)
old_effect_element.delete()
# update path effect link
current_effects[inkstitch_effect_position] = lpe.get_id(as_url=1)

Wyświetl plik

@ -46,8 +46,7 @@ class Troubleshoot(InkstitchExtension):
self.add_descriptions(problem_types)
self.remove_empty_layers()
else:
svg = self.document.getroot()
svg.remove(self.troubleshoot_layer)
self.troubleshoot_layer.delete()
message = _("All selected shapes are valid! ")
message += "\n\n"
@ -120,7 +119,7 @@ class Troubleshoot(InkstitchExtension):
# Remove the old layer - they may have used tranfsorms
# or moved it into an other group (which could lead to more transforms)
# We don't want to deal with it.
layer.getparent().remove(layer)
layer.delete()
layer = inkex.Group(attrib={
'id': '__validation_layer__',
@ -251,4 +250,4 @@ class Troubleshoot(InkstitchExtension):
def remove_empty_layers(self):
for layer in self.troubleshoot_layer.iterchildren(SVG_GROUP_TAG):
if len(layer) == 0:
self.troubleshoot_layer.remove(layer)
layer.delete()

Wyświetl plik

@ -91,7 +91,7 @@ class MultiColorSatinPanel(wx.Panel):
self.update_satin_elements()
if not self.colorize_panel.keep_original.GetValue():
for element in self.elements:
element.node.getparent().remove(element.node)
element.node.delete()
self.close()
def render_stitch_plan(self):
@ -124,7 +124,7 @@ class MultiColorSatinPanel(wx.Panel):
def update_satin_elements(self):
# empty old groups
for group in self.output_groups:
group.getparent().remove(group)
group.delete()
self.output_groups = []
overflow_left = self.colorize_panel.overflow_left.GetValue()

Wyświetl plik

@ -172,7 +172,7 @@ class GenerateSwatchesFrame(wx.Frame):
self._set_param(new_element, param, param_value)
param_value += step
# remove old element
element.getparent().remove(element)
element.delete()
def _set_param(self, element, param, value):
element.set(f'inkstitch:{ param }', value)

Wyświetl plik

@ -251,7 +251,7 @@ class Font(object):
continue
# remove destination_group if it is empty
if not bounding_box:
destination_group.remove(letter_group)
letter_group.delete()
continue
line_width = bounding_box.width

Wyświetl plik

@ -624,7 +624,7 @@ def add_trims(elements, trim_indices):
just_trimmed = False
for i, element in enumerate(elements):
if just_trimmed and isinstance(element, Stroke):
element.node.getparent().remove(element.node)
element.node.delete()
continue
if i in trim_indices:

Wyświetl plik

@ -246,17 +246,12 @@ def remove_original_elements(elements, commands_only=False):
for command in element.commands:
command_group = command.use.getparent()
if command_group is not None and command_group.get('id').startswith('command_group'):
remove_from_parent(command_group)
command_group.delete()
else:
remove_from_parent(command.connector)
remove_from_parent(command.use)
command.connector.delete()
command.use.delete()
if not commands_only:
remove_from_parent(element.node)
def remove_from_parent(node):
if node.getparent() is not None:
node.getparent().remove(node)
element.node.delete()
def create_new_group(parent, insert_index, label, correction_transform=True):

Wyświetl plik

@ -223,7 +223,7 @@ def color_block_to_paths(color_block, svg, destination, visual_commands, line_wi
def render_stitch_plan(svg, stitch_plan, realistic=False, visual_commands=True, render_jumps=True, line_width=0.4) -> inkex.Group:
layer_or_image = svg.findone(".//*[@id='__inkstitch_stitch_plan__']")
if layer_or_image is not None:
layer_or_image.getparent().remove(layer_or_image)
layer_or_image.delete()
layer = inkex.Group(attrib={
'id': '__inkstitch_stitch_plan__',

Wyświetl plik

@ -20,6 +20,6 @@ def prepare_tartan_fill_element(element: BaseElement) -> None:
outer_group = parent_group.getparent()
assert outer_group is not None, f"Tartan element {element.get_id()} should have a parent group"
outer_group.insert(outer_group.index(parent_group), element)
outer_group.remove(parent_group)
parent_group.delete()
# make sure the element is invisible
element.style['display'] = 'inline'

Wyświetl plik

@ -70,7 +70,7 @@ class TartanSvgGroup:
# remove everything but the tartan outline
for child in parent_group.iterchildren():
if child != outline:
parent_group.remove(child)
child.delete()
group = cast(Group, parent_group)
else:
group = Group()

Wyświetl plik

@ -240,13 +240,13 @@ def reposition_legacy_command(command):
# instead of calculating the transform for the new position, we take the easy route and remove
# the old commands and set new ones
add_commands(Stroke(element), [command_name], InkstitchPoint(*target_point))
command_group.getparent().remove(command_group)
command_group.delete()
def _rename_command(document, symbol, old_name, new_name):
symbol_id = symbol.get_id()
if symbol_id.startswith(old_name):
symbol.getparent().remove(symbol)
symbol.delete()
ensure_symbol(document, new_name)
_update_command(document, symbol_id, new_name)