diff options
Diffstat (limited to 'Tools/idle/AutoIndent.py')
-rw-r--r-- | Tools/idle/AutoIndent.py | 142 |
1 files changed, 118 insertions, 24 deletions
diff --git a/Tools/idle/AutoIndent.py b/Tools/idle/AutoIndent.py index d800589..329f492 100644 --- a/Tools/idle/AutoIndent.py +++ b/Tools/idle/AutoIndent.py @@ -1,16 +1,81 @@ import string +from Tkinter import TclError + +###$ event <<newline-and-indent>> +###$ win <Key-Return> +###$ win <KP_Enter> +###$ unix <Key-Return> +###$ unix <KP_Enter> + +###$ event <<indent-region>> +###$ win <Control-bracketright> +###$ unix <Alt-bracketright> +###$ unix <Control-bracketright> + +###$ event <<dedent-region>> +###$ win <Control-bracketleft> +###$ unix <Alt-bracketleft> +###$ unix <Control-bracketleft> + +###$ event <<comment-region>> +###$ win <Alt-Key-3> +###$ unix <Alt-Key-3> + +###$ event <<uncomment-region>> +###$ win <Alt-Key-4> +###$ unix <Alt-Key-4> + +###$ event <<tabify-region>> +###$ win <Alt-Key-5> +###$ unix <Alt-Key-5> + +###$ event <<untabify-region>> +###$ win <Alt-Key-6> +###$ unix <Alt-Key-6> class AutoIndent: - def __init__(self, text, prefertabs=0, spaceindent=4*" "): - self.text = text - self.prefertabs = prefertabs - self.spaceindent = spaceindent - text.bind("<<newline-and-indent>>", self.autoindent) - text.bind("<<indent-region>>", self.indentregion) - text.bind("<<dedent-region>>", self.dedentregion) - text.bind("<<comment-region>>", self.commentregion) - text.bind("<<uncomment-region>>", self.uncommentregion) + menudefs = [ + ('edit', [ + None, + ('_Indent region', '<<indent-region>>'), + ('_Dedent region', '<<dedent-region>>'), + ('Comment _out region', '<<comment-region>>'), + ('U_ncomment region', '<<uncomment-region>>'), + ('Tabify region', '<<tabify-region>>'), + ('Untabify region', '<<untabify-region>>'), + ]), + ] + + windows_keydefs = { + '<<newline-and-indent>>': ['<Key-Return>', '<KP_Enter>'], + '<<indent-region>>': ['<Control-bracketright>'], + '<<dedent-region>>': ['<Control-bracketleft>'], + '<<comment-region>>': ['<Alt-Key-3>'], + '<<uncomment-region>>': ['<Alt-Key-4>'], + '<<tabify-region>>': ['<Alt-Key-5>'], + '<<untabify-region>>': ['<Alt-Key-6>'], + } + + unix_keydefs = { + '<<newline-and-indent>>': ['<Key-Return>', '<KP_Enter>'], + '<<indent-region>>': ['<Alt-bracketright>', + '<Meta-bracketright>', + '<Control-bracketright>'], + '<<dedent-region>>': ['<Alt-bracketleft>', + '<Meta-bracketleft>', + '<Control-bracketleft>'], + '<<comment-region>>': ['<Alt-Key-3>', '<Meta-Key-3>'], + '<<uncomment-region>>': ['<Alt-Key-4>', '<Meta-Key-4>'], + '<<tabify-region>>': ['<Alt-Key-5>', '<Meta-Key-5>'], + '<<untabify-region>>': ['<Alt-Key-6>', '<Meta-Key-6>'], + } + + prefertabs = 0 + spaceindent = 4*" " + + def __init__(self, editwin): + self.text = editwin.text def config(self, **options): for key, value in options.items(): @@ -21,8 +86,16 @@ class AutoIndent: else: raise KeyError, "bad option name: %s" % `key` - def autoindent(self, event): + def newline_and_indent_event(self, event): text = self.text + try: + first = text.index("sel.first") + last = text.index("sel.last") + except TclError: + first = last = None + if first and last: + text.delete(first, last) + text.mark_set("insert", first) line = text.get("insert linestart", "insert") i, n = 0, len(line) while i < n and line[i] in " \t": @@ -43,8 +116,10 @@ class AutoIndent: text.see("insert") return "break" - def indentregion(self, event): - head, tail, chars, lines = self.getregion() + auto_indent = newline_and_indent_event + + def indent_region_event(self, event): + head, tail, chars, lines = self.get_region() for pos in range(len(lines)): line = lines[pos] if line: @@ -53,11 +128,11 @@ class AutoIndent: i = i+1 line = line[:i] + " " + line[i:] lines[pos] = line - self.setregion(head, tail, chars, lines) + self.set_region(head, tail, chars, lines) return "break" - def dedentregion(self, event): - head, tail, chars, lines = self.getregion() + def dedent_region_event(self, event): + head, tail, chars, lines = self.get_region() for pos in range(len(lines)): line = lines[pos] if line: @@ -75,20 +150,20 @@ class AutoIndent: indent = indent[:-4] line = indent + line lines[pos] = line - self.setregion(head, tail, chars, lines) + self.set_region(head, tail, chars, lines) return "break" - def commentregion(self, event): - head, tail, chars, lines = self.getregion() + def comment_region_event(self, event): + head, tail, chars, lines = self.get_region() for pos in range(len(lines)): line = lines[pos] if not line: continue lines[pos] = '##' + line - self.setregion(head, tail, chars, lines) + self.set_region(head, tail, chars, lines) - def uncommentregion(self, event): - head, tail, chars, lines = self.getregion() + def uncomment_region_event(self, event): + head, tail, chars, lines = self.get_region() for pos in range(len(lines)): line = lines[pos] if not line: @@ -98,9 +173,19 @@ class AutoIndent: elif line[:1] == '#': line = line[1:] lines[pos] = line - self.setregion(head, tail, chars, lines) + self.set_region(head, tail, chars, lines) - def getregion(self): + def tabify_region_event(self, event): + head, tail, chars, lines = self.get_region() + lines = map(tabify, lines) + self.set_region(head, tail, chars, lines) + + def untabify_region_event(self, event): + head, tail, chars, lines = self.get_region() + lines = map(string.expandtabs, lines) + self.set_region(head, tail, chars, lines) + + def get_region(self): text = self.text head = text.index("sel.first linestart") tail = text.index("sel.last -1c lineend +1c") @@ -111,7 +196,7 @@ class AutoIndent: lines = string.split(chars, "\n") return head, tail, chars, lines - def setregion(self, head, tail, chars, lines): + def set_region(self, head, tail, chars, lines): text = self.text newchars = string.join(lines, "\n") if newchars == chars: @@ -122,3 +207,12 @@ class AutoIndent: text.delete(head, tail) text.insert(head, newchars) text.tag_add("sel", head, "insert") + +def tabify(line, tabsize=8): + spaces = tabsize * ' ' + for i in range(0, len(line), tabsize): + if line[i:i+tabsize] != spaces: + break + else: + i = len(line) + return '\t' * (i/tabsize) + line[i:] |