diff options
| author | capellancitizen <thecapellancitizen@gmail.com> | 2024-04-12 16:01:17 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-04-12 16:01:17 -0400 |
| commit | 7e756b8971cc3b85a0beec3e674c4c1d9284e4b2 (patch) | |
| tree | 5cbb1effd63000805afa912c9fea6173fc12e330 /lib/extensions/unlink_clone.py | |
| parent | dd85f23bdb78d53d4b704d18b4a6eceaea8335bd (diff) | |
Additional Clone functionality (#2834)
- Recursive Clones now pick up inkstitch:angle etc. from clones they clone
- Style now properly propogates to clones
- Unlink Clone tool (which applies angle changes, etc.)
- Minor refactoring
Diffstat (limited to 'lib/extensions/unlink_clone.py')
| -rw-r--r-- | lib/extensions/unlink_clone.py | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/lib/extensions/unlink_clone.py b/lib/extensions/unlink_clone.py new file mode 100644 index 00000000..e361da14 --- /dev/null +++ b/lib/extensions/unlink_clone.py @@ -0,0 +1,40 @@ +# Authors: see git history +# +# Copyright (c) 2010 Authors +# Licensed under the GNU GPL version 3.0 or later. See the file LICENSE for details. + +from inkex import Boolean, errormsg, BaseElement + +from ..elements import Clone +from ..i18n import _ +from .base import InkstitchExtension + +from typing import List, Tuple + + +class UnlinkClone(InkstitchExtension): + def __init__(self, *args, **kwargs): + InkstitchExtension.__init__(self, *args, **kwargs) + self.arg_parser.add_argument("-r", "--recursive", dest="recursive", type=Boolean, default=True) + + def effect(self): + recursive: bool = self.options.recursive + + if not self.get_elements(): + return + + if not self.svg.selection: + errormsg(_("Please select one or more clones to unlink.")) + return + + # Two passes here: One to resolve all clones, and then another to replace those clones with their resolved versions. + # This way we don't accidentally remove a node that another clone refers to. + clones_resolved: List[Tuple[BaseElement, BaseElement]] = [] + for element in self.elements: + if isinstance(element, Clone): + resolved = element.resolve_clone(recursive=recursive) + clones_resolved.append((element.node, resolved)) + + for (clone, resolved) in clones_resolved: + clone.getparent().remove(clone) + resolved.set_id(clone.get_id()) |
