summaryrefslogtreecommitdiffstats
path: root/share/extensions/text_sentencecase.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 16:29:01 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 16:29:01 +0000
commit35a96bde514a8897f6f0fcc41c5833bf63df2e2a (patch)
tree657d15a03cc46bd099fc2c6546a7a4ad43815d9f /share/extensions/text_sentencecase.py
parentInitial commit. (diff)
downloadinkscape-35a96bde514a8897f6f0fcc41c5833bf63df2e2a.tar.xz
inkscape-35a96bde514a8897f6f0fcc41c5833bf63df2e2a.zip
Adding upstream version 1.0.2.upstream/1.0.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'share/extensions/text_sentencecase.py')
-rwxr-xr-xshare/extensions/text_sentencecase.py35
1 files changed, 35 insertions, 0 deletions
diff --git a/share/extensions/text_sentencecase.py b/share/extensions/text_sentencecase.py
new file mode 100755
index 0000000..e63430d
--- /dev/null
+++ b/share/extensions/text_sentencecase.py
@@ -0,0 +1,35 @@
+#!/usr/bin/env python
+"""Convert to sentence case"""
+
+import inkex
+
+class SentenceCase(inkex.TextExtension):
+ """Convert text to sentence case"""
+ sentence_start = True
+ was_punctuation = False
+
+ def map_char(self, char):
+ """Turn the char into a sentence using class state"""
+ if char in '.!?':
+ self.was_punctuation = True
+ elif ((char.isspace() or self.newline) and self.was_punctuation) or self.newpar:
+ self.sentence_start = True
+ self.was_punctuation = False
+ elif char in '")':
+ pass
+ else:
+ self.was_punctuation = False
+
+ if not char.isspace():
+ self.newline = False
+ self.newpar = False
+
+ if self.sentence_start and char.isalpha():
+ self.sentence_start = False
+ return char.upper()
+ elif not self.sentence_start and char.isalpha():
+ return char.lower()
+ return char
+
+if __name__ == '__main__':
+ SentenceCase().run()