From 69f08a3e741abcd36ef65047677d0e6eb1ce6482 Mon Sep 17 00:00:00 2001 From: Michael Schwarz Date: Sat, 5 May 2018 14:19:26 +0200 Subject: Slight refactoring --- support/inkscape/inkscape.py | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) (limited to 'support/inkscape') diff --git a/support/inkscape/inkscape.py b/support/inkscape/inkscape.py index dee1542..3a25a15 100644 --- a/support/inkscape/inkscape.py +++ b/support/inkscape/inkscape.py @@ -80,23 +80,25 @@ class InkscapeCommandLine(object): target_index = self._layers.index(layer) - if self._current_layer_index < target_index: - for _ in range(target_index - self._current_layer_index): - self.apply_to_document( - 'LayerMoveToNext' if with_selection else 'LayerNext') - elif self._current_layer_index > target_index: - for _ in range(self._current_layer_index - target_index): - self.apply_to_document( - 'LayerMoveToPrev' if with_selection else 'LayerPrev') + if with_selection: + next_command = 'LayerMoveToNext' + previous_command = 'LayerMoveToPrev' else: - return + next_command = 'LayerNext' + previous_command = 'LayerPrev' + + while self._current_layer_index != target_index: + if self._current_layer_index < target_index: + self.apply_to_document(next_command) + self._current_layer_index += 1 + else: + self.apply_to_document(previous_command) + self._current_layer_index -= 1 if with_selection: # When using LayerMoveToNext and LayerMoveToPrev, inkscape does # not reliably select the next/previous layer. self._current_layer_index = None - else: - self._current_layer_index = target_index def duplicate_layer(self, layer): self.apply_to_layer(layer, 'LayerDuplicate') -- cgit