summaryrefslogtreecommitdiffstats
path: root/Lib/idlelib/ReplaceDialog.py
diff options
context:
space:
mode:
authorSteven M. Gava <elguavas@python.net>2001-07-12 06:54:16 (GMT)
committerSteven M. Gava <elguavas@python.net>2001-07-12 06:54:16 (GMT)
commite9880c81b92a4bc72c541e8d89e1872b4816baa4 (patch)
treea4f67f96504bcdb6c20aa4f8c7f4cf92fa982bc3 /Lib/idlelib/ReplaceDialog.py
parent42f6c64816b87411dd7c20467963487456442248 (diff)
downloadcpython-e9880c81b92a4bc72c541e8d89e1872b4816baa4.zip
cpython-e9880c81b92a4bc72c541e8d89e1872b4816baa4.tar.gz
cpython-e9880c81b92a4bc72c541e8d89e1872b4816baa4.tar.bz2
py-cvs merge, python 1.5.2 compatability
Diffstat (limited to 'Lib/idlelib/ReplaceDialog.py')
-rw-r--r--Lib/idlelib/ReplaceDialog.py20
1 files changed, 18 insertions, 2 deletions
diff --git a/Lib/idlelib/ReplaceDialog.py b/Lib/idlelib/ReplaceDialog.py
index e29d4d6..83462f9 100644
--- a/Lib/idlelib/ReplaceDialog.py
+++ b/Lib/idlelib/ReplaceDialog.py
@@ -90,7 +90,7 @@ class ReplaceDialog(SearchDialogBase):
line, m = res
chars = text.get("%d.0" % line, "%d.0" % (line+1))
orig = m.group()
- new = re.pcre_expand(m, repl)
+ new = self._expand(m, repl)
i, j = m.span()
first = "%d.%d" % (line, i)
last = "%d.%d" % (line, j)
@@ -142,7 +142,7 @@ class ReplaceDialog(SearchDialogBase):
m = prog.match(chars, col)
if not prog:
return 0
- new = re.pcre_expand(m, self.replvar.get())
+ new = self._expand(m, self.replvar.get())
text.mark_set("insert", first)
text.undo_block_start()
if m.group():
@@ -154,6 +154,22 @@ class ReplaceDialog(SearchDialogBase):
self.ok = 0
return 1
+ 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.
+ # The solution here is designed to be backwards compatible
+ # with previous Python versions, e.g. 1.5.2.
+ # XXX This dynamic test should be done only once.
+ if getattr(re, "engine", "pre") == "pre":
+ return re.pcre_expand(m, template)
+ else: # sre
+ # XXX This import should be avoidable...
+ import sre_parse
+ # 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)