Merge branch 'master' of https://github.com/gnome-terminator/terminator into fix-wrapcloseterm
This commit is contained in:
commit
b50de62fe6
|
@ -863,7 +863,7 @@ class PrefsEditor:
|
||||||
elif selected == 2:
|
elif selected == 2:
|
||||||
value = 'ascii-del'
|
value = 'ascii-del'
|
||||||
elif selected == 3:
|
elif selected == 3:
|
||||||
value == 'escape-sequence'
|
value = 'escape-sequence'
|
||||||
else:
|
else:
|
||||||
value = 'automatic'
|
value = 'automatic'
|
||||||
self.config['backspace_binding'] = value
|
self.config['backspace_binding'] = value
|
||||||
|
@ -1550,6 +1550,21 @@ class PrefsEditor:
|
||||||
|
|
||||||
def on_cellrenderer_accel_edited(self, liststore, path, key, mods, _code):
|
def on_cellrenderer_accel_edited(self, liststore, path, key, mods, _code):
|
||||||
"""Handle an edited keybinding"""
|
"""Handle an edited keybinding"""
|
||||||
|
if mods & Gdk.ModifierType.SHIFT_MASK:
|
||||||
|
key_with_shift = Gdk.Keymap.translate_keyboard_state(
|
||||||
|
self.keybindings.keymap,
|
||||||
|
hardware_keycode=_code,
|
||||||
|
state=Gdk.ModifierType.SHIFT_MASK,
|
||||||
|
group=0,
|
||||||
|
)
|
||||||
|
keyval_lower, keyval_upper = Gdk.keyval_convert_case(key)
|
||||||
|
|
||||||
|
# Remove the Shift modifier from `mods` if a new key binding doesn't
|
||||||
|
# contain a letter and its key value (`key`) can't be modified by a
|
||||||
|
# Shift key.
|
||||||
|
if key_with_shift.level != 0 and keyval_lower == keyval_upper:
|
||||||
|
mods = Gdk.ModifierType(mods & ~Gdk.ModifierType.SHIFT_MASK)
|
||||||
|
|
||||||
celliter = liststore.get_iter_from_string(path)
|
celliter = liststore.get_iter_from_string(path)
|
||||||
liststore.set(celliter, 2, key, 3, mods)
|
liststore.set(celliter, 2, key, 3, mods)
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,10 @@ from gi.repository import GLib, Vte
|
||||||
# the corresponding bits are defined here:
|
# the corresponding bits are defined here:
|
||||||
# https://vcs.pcre.org/pcre2/code/trunk/src/pcre2.h.in?view=markup
|
# https://vcs.pcre.org/pcre2/code/trunk/src/pcre2.h.in?view=markup
|
||||||
PCRE2_MULTILINE = 0x00000400
|
PCRE2_MULTILINE = 0x00000400
|
||||||
|
PCRE2_CASELESS = 0x00000008
|
||||||
|
|
||||||
|
GLIB_CASELESS = GLib.RegexCompileFlags.CASELESS
|
||||||
|
|
||||||
FLAGS_GLIB = (GLib.RegexCompileFlags.OPTIMIZE | GLib.RegexCompileFlags.MULTILINE)
|
FLAGS_GLIB = (GLib.RegexCompileFlags.OPTIMIZE | GLib.RegexCompileFlags.MULTILINE)
|
||||||
if hasattr(Vte, 'REGEX_FLAGS_DEFAULT'):
|
if hasattr(Vte, 'REGEX_FLAGS_DEFAULT'):
|
||||||
FLAGS_PCRE2 = (Vte.REGEX_FLAGS_DEFAULT | PCRE2_MULTILINE)
|
FLAGS_PCRE2 = (Vte.REGEX_FLAGS_DEFAULT | PCRE2_MULTILINE)
|
||||||
|
|
|
@ -37,6 +37,10 @@ class Searchbar(Gtk.HBox):
|
||||||
"""Class initialiser"""
|
"""Class initialiser"""
|
||||||
GObject.GObject.__init__(self)
|
GObject.GObject.__init__(self)
|
||||||
|
|
||||||
|
# default regex flags are not CASELESS
|
||||||
|
self.regex_flags_pcre2 = regex.FLAGS_PCRE2
|
||||||
|
self.regex_flags_glib = regex.FLAGS_GLIB
|
||||||
|
|
||||||
self.config = Config()
|
self.config = Config()
|
||||||
|
|
||||||
self.get_style_context().add_class("terminator-terminal-searchbar")
|
self.get_style_context().add_class("terminator-terminal-searchbar")
|
||||||
|
@ -66,21 +70,29 @@ class Searchbar(Gtk.HBox):
|
||||||
close.show_all()
|
close.show_all()
|
||||||
|
|
||||||
# Next Button
|
# Next Button
|
||||||
self.next = Gtk.Button(_('Next'))
|
self.next = Gtk.Button.new_with_label('Next')
|
||||||
self.next.show()
|
self.next.show()
|
||||||
self.next.set_sensitive(False)
|
self.next.set_sensitive(False)
|
||||||
self.next.connect('clicked', self.next_search)
|
self.next.connect('clicked', self.next_search)
|
||||||
|
|
||||||
# Previous Button
|
# Previous Button
|
||||||
self.prev = Gtk.Button(_('Prev'))
|
self.prev = Gtk.Button.new_with_label('Prev')
|
||||||
self.prev.show()
|
self.prev.show()
|
||||||
self.prev.set_sensitive(False)
|
self.prev.set_sensitive(False)
|
||||||
self.prev.connect('clicked', self.prev_search)
|
self.prev.connect('clicked', self.prev_search)
|
||||||
|
|
||||||
|
# Match Case checkbox
|
||||||
|
self.match_case = Gtk.CheckButton.new_with_label('Match Case')
|
||||||
|
self.match_case.show()
|
||||||
|
self.match_case.set_sensitive(True)
|
||||||
|
self.match_case.set_active(True)
|
||||||
|
self.match_case.connect('toggled', self.match_case_toggled)
|
||||||
|
|
||||||
# Wrap checkbox
|
# Wrap checkbox
|
||||||
self.wrap = Gtk.CheckButton(_('Wrap'))
|
self.wrap = Gtk.CheckButton.new_with_label('Wrap')
|
||||||
self.wrap.show()
|
self.wrap.show()
|
||||||
self.wrap.set_sensitive(True)
|
self.wrap.set_sensitive(True)
|
||||||
|
self.wrap.set_active(True)
|
||||||
self.wrap.connect('toggled', self.wrap_toggled)
|
self.wrap.connect('toggled', self.wrap_toggled)
|
||||||
|
|
||||||
self.pack_start(label, False, True, 0)
|
self.pack_start(label, False, True, 0)
|
||||||
|
@ -88,6 +100,7 @@ class Searchbar(Gtk.HBox):
|
||||||
self.pack_start(self.prev, False, False, 0)
|
self.pack_start(self.prev, False, False, 0)
|
||||||
self.pack_start(self.next, False, False, 0)
|
self.pack_start(self.next, False, False, 0)
|
||||||
self.pack_start(self.wrap, False, False, 0)
|
self.pack_start(self.wrap, False, False, 0)
|
||||||
|
self.pack_start(self.match_case, False, False, 0)
|
||||||
self.pack_end(close, False, False, 0)
|
self.pack_end(close, False, False, 0)
|
||||||
|
|
||||||
self.hide()
|
self.hide()
|
||||||
|
@ -100,11 +113,34 @@ class Searchbar(Gtk.HBox):
|
||||||
self.prev.set_sensitive(True)
|
self.prev.set_sensitive(True)
|
||||||
self.next.set_sensitive(True)
|
self.next.set_sensitive(True)
|
||||||
|
|
||||||
|
def match_case_toggled(self, toggled):
|
||||||
|
"""Handles Match Case checkbox toggles"""
|
||||||
|
|
||||||
|
toggled_state = toggled.get_active()
|
||||||
|
if not toggled_state:
|
||||||
|
# Add the CASELESS regex flags when the checkbox is not checked.
|
||||||
|
try:
|
||||||
|
self.regex_flags_pcre2 = (regex.FLAGS_PCRE2 | regex.PCRE2_CASELESS)
|
||||||
|
except TypeError:
|
||||||
|
# if PCRE2 support is not available
|
||||||
|
pass
|
||||||
|
|
||||||
|
# The code will fall back to use this GLib regex when PCRE2 is not available
|
||||||
|
self.regex_flags_glib = (regex.FLAGS_GLIB | regex.GLIB_CASELESS)
|
||||||
|
else:
|
||||||
|
# Default state of the check box is unchecked. CASELESS regex flags are not added.
|
||||||
|
self.regex_flags_pcre2 = regex.FLAGS_PCRE2
|
||||||
|
self.regex_flags_glib = regex.FLAGS_GLIB
|
||||||
|
|
||||||
|
self.do_search(self.entry) # Start a new search everytime the check box is toggled.
|
||||||
|
|
||||||
def get_vte(self):
|
def get_vte(self):
|
||||||
"""Find our parent widget"""
|
"""Find our parent widget"""
|
||||||
parent = self.get_parent()
|
parent = self.get_parent()
|
||||||
if parent:
|
if parent:
|
||||||
self.vte = parent.vte
|
self.vte = parent.vte
|
||||||
|
#turn on wrap by default
|
||||||
|
self.vte.search_set_wrap_around(True)
|
||||||
|
|
||||||
# pylint: disable-msg=W0613
|
# pylint: disable-msg=W0613
|
||||||
def search_keypress(self, widget, event):
|
def search_keypress(self, widget, event):
|
||||||
|
@ -132,13 +168,10 @@ class Searchbar(Gtk.HBox):
|
||||||
if searchtext == '':
|
if searchtext == '':
|
||||||
return
|
return
|
||||||
|
|
||||||
if searchtext != self.searchstring:
|
|
||||||
self.searchstring = searchtext
|
|
||||||
self.searchre = None
|
self.searchre = None
|
||||||
|
|
||||||
if regex.FLAGS_PCRE2:
|
if regex.FLAGS_PCRE2:
|
||||||
try:
|
try:
|
||||||
self.searchre = Vte.Regex.new_for_search(searchtext, len(searchtext), regex.FLAGS_PCRE2)
|
self.searchre = Vte.Regex.new_for_search(searchtext, len(searchtext), self.regex_flags_pcre2)
|
||||||
dbg('search RE: %s' % self.searchre)
|
dbg('search RE: %s' % self.searchre)
|
||||||
self.vte.search_set_regex(self.searchre, 0)
|
self.vte.search_set_regex(self.searchre, 0)
|
||||||
except GLib.Error:
|
except GLib.Error:
|
||||||
|
@ -147,7 +180,7 @@ class Searchbar(Gtk.HBox):
|
||||||
|
|
||||||
if not self.searchre:
|
if not self.searchre:
|
||||||
# fall back to old GLib regex
|
# fall back to old GLib regex
|
||||||
self.searchre = GLib.Regex(searchtext, regex.FLAGS_GLIB, 0)
|
self.searchre = GLib.Regex(searchtext, self.regex_flags_glib, 0)
|
||||||
dbg('search RE: %s' % self.searchre)
|
dbg('search RE: %s' % self.searchre)
|
||||||
self.vte.search_set_gregex(self.searchre, 0)
|
self.vte.search_set_gregex(self.searchre, 0)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue