Get rid of _expand() altogether - the match object supports m.expand().

This commit is contained in:
Guido van Rossum 2002-07-24 19:13:08 +00:00
parent 403e351dfc
commit f8c8cf8a9d
1 changed files with 2 additions and 11 deletions

View File

@ -6,7 +6,6 @@
import tkMessageBox
import SearchEngine
from SearchDialogBase import SearchDialogBase
import sre_parse
def replace(text):
root = text._root()
@ -91,7 +90,7 @@ def replace_all(self, event=None):
line, m = res
chars = text.get("%d.0" % line, "%d.0" % (line+1))
orig = m.group()
new = self._expand(m, repl)
new = m.expand(repl)
i, j = m.span()
first = "%d.%d" % (line, i)
last = "%d.%d" % (line, j)
@ -143,7 +142,7 @@ def do_replace(self):
m = prog.match(chars, col)
if not prog:
return False
new = self._expand(m, self.replvar.get())
new = m.expand(self.replvar.get())
text.mark_set("insert", first)
text.undo_block_start()
if m.group():
@ -155,14 +154,6 @@ def do_replace(self):
self.ok = 0
return True
def _expand(self, m, template):
# XXX This code depends on internals of the regular expression
# engine! There's no standard API to do a substitution when you
# have already found the match. One should be added.
# XXX This parses the template over and over...
ptemplate = sre_parse.parse_template(template, m.re)
return sre_parse.expand_template(ptemplate, m)
def show_hit(self, first, last):
text = self.text
text.mark_set("insert", first)