parent
210e00eb37
commit
0c751d5770
|
@ -516,8 +516,16 @@ class Application(object):
|
||||||
# highlighting
|
# highlighting
|
||||||
def add_highlighted_range(self, hr):
|
def add_highlighted_range(self, hr):
|
||||||
self.highlighted_ranges.append(hr)
|
self.highlighted_ranges.append(hr)
|
||||||
def clear_highlighted_ranges(self):
|
def clear_highlighted_ranges(self, name=None):
|
||||||
|
if name is None:
|
||||||
self.highlighted_ranges = []
|
self.highlighted_ranges = []
|
||||||
|
else:
|
||||||
|
i = 0
|
||||||
|
while i < len(self.highlighted_ranges):
|
||||||
|
if self.highlighted_ranges[i].name == name:
|
||||||
|
del self.highlighted_ranges[i]
|
||||||
|
else:
|
||||||
|
i += 1
|
||||||
|
|
||||||
def run_external(self, *args):
|
def run_external(self, *args):
|
||||||
curses.reset_shell_mode()
|
curses.reset_shell_mode()
|
||||||
|
|
|
@ -117,7 +117,7 @@ def _finish(m, w):
|
||||||
|
|
||||||
def _end(w):
|
def _end(w):
|
||||||
w.application.close_mini_buffer()
|
w.application.close_mini_buffer()
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
w.buffer.method.old_cursor = None
|
w.buffer.method.old_cursor = None
|
||||||
w.buffer.method.old_window = None
|
w.buffer.method.old_window = None
|
||||||
assert not w.application.mini_active
|
assert not w.application.mini_active
|
||||||
|
|
|
@ -28,7 +28,7 @@ class SearchNext(method.Method):
|
||||||
r = _make_regex(w, s)
|
r = _make_regex(w, s)
|
||||||
searchutil.find_next(r, w.buffer.method.old_window, move=True)
|
searchutil.find_next(r, w.buffer.method.old_window, move=True)
|
||||||
except searchutil.IllegalPatternError:
|
except searchutil.IllegalPatternError:
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
else:
|
else:
|
||||||
action = InsertSearchString(w.application.last_search)
|
action = InsertSearchString(w.application.last_search)
|
||||||
action.execute(w)
|
action.execute(w)
|
||||||
|
@ -45,7 +45,7 @@ class SearchPrevious(method.Method):
|
||||||
r = _make_regex(w, s)
|
r = _make_regex(w, s)
|
||||||
searchutil.find_previous(r, w2, move=True)
|
searchutil.find_previous(r, w2, move=True)
|
||||||
except searchutil.IllegalPatternError:
|
except searchutil.IllegalPatternError:
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
|
|
||||||
class EndSearch(method.Method):
|
class EndSearch(method.Method):
|
||||||
def execute(self, w, **vargs):
|
def execute(self, w, **vargs):
|
||||||
|
@ -74,7 +74,7 @@ def _post_delete(w):
|
||||||
old_w = w.buffer.method.old_window
|
old_w = w.buffer.method.old_window
|
||||||
old_w.goto(old_cursor)
|
old_w.goto(old_cursor)
|
||||||
if not w.buffer.make_string():
|
if not w.buffer.make_string():
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
return
|
return
|
||||||
s = w.buffer.make_string()
|
s = w.buffer.make_string()
|
||||||
w2 = w.buffer.method.old_window
|
w2 = w.buffer.method.old_window
|
||||||
|
@ -85,7 +85,7 @@ def _post_delete(w):
|
||||||
else:
|
else:
|
||||||
searchutil.find_previous(r, w2, move=False)
|
searchutil.find_previous(r, w2, move=False)
|
||||||
except searchutil.IllegalPatternError:
|
except searchutil.IllegalPatternError:
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
|
|
||||||
class InsertSearchString(method.Method):
|
class InsertSearchString(method.Method):
|
||||||
def __init__(self, s):
|
def __init__(self, s):
|
||||||
|
@ -97,7 +97,7 @@ class InsertSearchString(method.Method):
|
||||||
w.insert_string_at_cursor(self.string)
|
w.insert_string_at_cursor(self.string)
|
||||||
s = w.buffer.make_string()
|
s = w.buffer.make_string()
|
||||||
if not s:
|
if not s:
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
return
|
return
|
||||||
else:
|
else:
|
||||||
try:
|
try:
|
||||||
|
@ -108,11 +108,11 @@ class InsertSearchString(method.Method):
|
||||||
else:
|
else:
|
||||||
searchutil.find_previous(r, w2, move=False)
|
searchutil.find_previous(r, w2, move=False)
|
||||||
except searchutil.IllegalPatternError:
|
except searchutil.IllegalPatternError:
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
|
|
||||||
def _end(w):
|
def _end(w):
|
||||||
w.application.close_mini_buffer()
|
w.application.close_mini_buffer()
|
||||||
w.application.clear_highlighted_ranges()
|
w.application.clear_highlighted_ranges('search')
|
||||||
w.application.last_search = w.buffer.make_string()
|
w.application.last_search = w.buffer.make_string()
|
||||||
|
|
||||||
class Search(mode.Fundamental):
|
class Search(mode.Fundamental):
|
||||||
|
|
|
@ -74,7 +74,7 @@ def find(r, w, move=False, direction='next', start=None, end=None):
|
||||||
break
|
break
|
||||||
if ranges and not newc:
|
if ranges and not newc:
|
||||||
return None
|
return None
|
||||||
app.clear_highlighted_ranges()
|
app.clear_highlighted_ranges('search')
|
||||||
if newc:
|
if newc:
|
||||||
w.goto(newc[0])
|
w.goto(newc[0])
|
||||||
for (p1, p2, fg, bg, m) in ranges:
|
for (p1, p2, fg, bg, m) in ranges:
|
||||||
|
@ -82,7 +82,8 @@ def find(r, w, move=False, direction='next', start=None, end=None):
|
||||||
continue
|
continue
|
||||||
elif p2 > w.last:
|
elif p2 > w.last:
|
||||||
break
|
break
|
||||||
app.add_highlighted_range(HighlightRegion(w, p1, p2, fg, bg))
|
hr = HighlightRegion(w, p1, p2, fg, bg, match=m, name='search')
|
||||||
|
app.add_highlighted_range(hr)
|
||||||
return newc
|
return newc
|
||||||
|
|
||||||
def find_previous(r, w, move=False, start=None, end=None):
|
def find_previous(r, w, move=False, start=None, end=None):
|
||||||
|
|
Loading…
Reference in New Issue