mirror of
https://github.com/python/cpython.git
synced 2025-07-21 02:05:20 +00:00

svn+ssh://pythondev@svn.python.org/python/branches/p3yk ................ r56454 | kurt.kaiser | 2007-07-18 22:26:14 -0700 (Wed, 18 Jul 2007) | 2 lines Make relative imports explicit for py3k ................ r56455 | kurt.kaiser | 2007-07-18 23:12:15 -0700 (Wed, 18 Jul 2007) | 2 lines Was modifying dict during iteration. ................ r56457 | guido.van.rossum | 2007-07-19 07:33:19 -0700 (Thu, 19 Jul 2007) | 2 lines Fix failing test. ................ r56466 | guido.van.rossum | 2007-07-19 20:58:16 -0700 (Thu, 19 Jul 2007) | 35 lines Merged revisions 56413-56465 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r56439 | georg.brandl | 2007-07-17 23:37:55 -0700 (Tue, 17 Jul 2007) | 2 lines Use "Unix" as platform name, not "UNIX". ........ r56441 | guido.van.rossum | 2007-07-18 10:19:14 -0700 (Wed, 18 Jul 2007) | 3 lines SF patch# 1755885 by Kurt Kaiser: show location of Unicode escape errors. (Slightly tweaked for style and refcounts.) ........ r56444 | kurt.kaiser | 2007-07-18 12:58:42 -0700 (Wed, 18 Jul 2007) | 2 lines Fix failing unicode test caused by change to ast.c at r56441 ........ r56451 | georg.brandl | 2007-07-18 15:36:53 -0700 (Wed, 18 Jul 2007) | 2 lines Add description for wave.setcomptype() values ........ r56456 | walter.doerwald | 2007-07-19 06:04:38 -0700 (Thu, 19 Jul 2007) | 3 lines Document that codecs.lookup() returns a CodecInfo object. (fixes SF bug #1754453). ........ r56463 | facundo.batista | 2007-07-19 16:57:38 -0700 (Thu, 19 Jul 2007) | 6 lines Added a select.select call in the test server loop to make sure the socket is ready to be read from before attempting a read (this prevents an error 10035 on some Windows platforms). [GSoC - Alan McIntyre] ........ ................
68 lines
2 KiB
Python
68 lines
2 KiB
Python
from Tkinter import *
|
|
|
|
from . import SearchEngine
|
|
from .SearchDialogBase import SearchDialogBase
|
|
|
|
def _setup(text):
|
|
root = text._root()
|
|
engine = SearchEngine.get(root)
|
|
if not hasattr(engine, "_searchdialog"):
|
|
engine._searchdialog = SearchDialog(root, engine)
|
|
return engine._searchdialog
|
|
|
|
def find(text):
|
|
pat = text.get("sel.first", "sel.last")
|
|
return _setup(text).open(text,pat)
|
|
|
|
def find_again(text):
|
|
return _setup(text).find_again(text)
|
|
|
|
def find_selection(text):
|
|
return _setup(text).find_selection(text)
|
|
|
|
class SearchDialog(SearchDialogBase):
|
|
|
|
def create_widgets(self):
|
|
f = SearchDialogBase.create_widgets(self)
|
|
self.make_button("Find", self.default_command, 1)
|
|
|
|
def default_command(self, event=None):
|
|
if not self.engine.getprog():
|
|
return
|
|
if self.find_again(self.text):
|
|
self.close()
|
|
|
|
def find_again(self, text):
|
|
if not self.engine.getpat():
|
|
self.open(text)
|
|
return False
|
|
if not self.engine.getprog():
|
|
return False
|
|
res = self.engine.search_text(text)
|
|
if res:
|
|
line, m = res
|
|
i, j = m.span()
|
|
first = "%d.%d" % (line, i)
|
|
last = "%d.%d" % (line, j)
|
|
try:
|
|
selfirst = text.index("sel.first")
|
|
sellast = text.index("sel.last")
|
|
if selfirst == first and sellast == last:
|
|
text.bell()
|
|
return False
|
|
except TclError:
|
|
pass
|
|
text.tag_remove("sel", "1.0", "end")
|
|
text.tag_add("sel", first, last)
|
|
text.mark_set("insert", self.engine.isback() and first or last)
|
|
text.see("insert")
|
|
return True
|
|
else:
|
|
text.bell()
|
|
return False
|
|
|
|
def find_selection(self, text):
|
|
pat = text.get("sel.first", "sel.last")
|
|
if pat:
|
|
self.engine.setcookedpat(pat)
|
|
return self.find_again(text)
|