[gedit-plugins/gnome-2-32] Implemented align for multi edit
- From: Jesse van den Kieboom <jessevdk src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gedit-plugins/gnome-2-32] Implemented align for multi edit
- Date: Sun, 29 Aug 2010 22:54:38 +0000 (UTC)
commit dfb3b82a7c73c97651e252f5d8e40c8190d7dd79
Author: Jesse van den Kieboom <jesse icecrew nl>
Date: Sat May 1 15:12:59 2010 +0200
Implemented align for multi edit
plugins/multiedit/multiedit/documenthelper.py | 38 +++++++++++++++++++++----
1 files changed, 32 insertions(+), 6 deletions(-)
---
diff --git a/plugins/multiedit/multiedit/documenthelper.py b/plugins/multiedit/multiedit/documenthelper.py
index 9164be9..82ec9da 100644
--- a/plugins/multiedit/multiedit/documenthelper.py
+++ b/plugins/multiedit/multiedit/documenthelper.py
@@ -498,12 +498,27 @@ class DocumentHelper(Signals):
return iters
def do_smart_column_align(self, event):
- ret = self.smart_column_iters()
+ if not self._edit_points:
+ ret = self.smart_column_iters()
- if ret == True or ret == False:
- return ret
+ if ret == True or ret == False:
+ return ret
+ else:
+ iters = [self._buffer.get_iter_at_mark(x) for x in self._edit_points]
+ iters.append(self._buffer.get_iter_at_mark(self._buffer.get_insert()))
+
+ iters.sort(lambda a, b: a.compare(b))
+ ret = []
+ lastline = -1
+
+ for piter in iters:
+ line = piter.get_line()
+
+ if line != lastline:
+ ret.append(piter)
+
+ lastline = line
- selection = self._buffer.get_iter_at_mark(self._buffer.get_selection_bound())
lastline = self._buffer.get_iter_at_mark(self._buffer.get_insert()).get_line()
# Get max visual offset
@@ -532,6 +547,8 @@ class DocumentHelper(Signals):
self.block_signal(self._buffer, 'mark-set')
self.block_signal(self._buffer, 'insert-text')
+ self._buffer.begin_user_action()
+
for i in range(len(marks)):
# Align with spaces on the left such that 'mark' is at maxoffset
num = maxoffset - offsets[i]
@@ -545,6 +562,11 @@ class DocumentHelper(Signals):
else:
self._buffer.place_cursor(piter)
+ for mark in marks:
+ self._buffer.delete_mark(mark)
+
+ self._buffer.end_user_action()
+
self.unblock_signal(self._buffer, 'mark-set')
self.unblock_signal(self._buffer, 'insert-text')
@@ -556,7 +578,6 @@ class DocumentHelper(Signals):
if ret == True or ret == False:
return ret
- selection = self._buffer.get_iter_at_mark(self._buffer.get_selection_bound())
lastline = self._buffer.get_iter_at_mark(self._buffer.get_insert()).get_line()
# Remove previous edit points
@@ -1167,7 +1188,7 @@ class DocumentHelper(Signals):
if x < geom[0] or x > geom[0] + geom[2] or y < geom[1] or y > geom[1] + geom[3]:
return False
- table = gtk.Table(10, 2)
+ table = gtk.Table(12, 2)
table.set_row_spacings(3)
table.set_col_spacings(12)
@@ -1187,14 +1208,19 @@ class DocumentHelper(Signals):
table.attach(self.make_label('<Ctrl>+E', False), 0, 1, 7, 8, gtk.SHRINK | gtk.FILL, gtk.SHRINK | gtk.FILL)
table.attach(self.make_label('<Ctrl><Home>', False), 0, 1, 8, 9, gtk.SHRINK | gtk.FILL, gtk.SHRINK | gtk.FILL)
table.attach(self.make_label('<Ctrl><End>', False), 0, 1, 9, 10, gtk.SHRINK | gtk.FILL, gtk.SHRINK | gtk.FILL)
+ table.attach(self.make_label('<Ctrl><Shift><Enter>', False), 0, 1, 10, 11, gtk.SHRINK | gtk.FILL, gtk.SHRINK | gtk.FILL)
+ table.attach(self.make_label('<Ctrl><Alt><Shift><Enter>', False), 0, 1, 10, 11, gtk.SHRINK | gtk.FILL, gtk.SHRINK | gtk.FILL)
table.attach(self.make_label(_('Enter column edit mode using selection')), 1, 2, 1, 2)
table.attach(self.make_label(_('Enter <b>smart</b> column edit mode using selection')), 1, 2, 2, 3)
table.attach(self.make_label(_('<b>Smart</b> column align mode using selection')), 1, 2, 3, 4)
table.attach(self.make_label(_('<b>Smart</b> column align mode with additional space using selection')), 1, 2, 4, 5)
+
table.attach(self.make_label(_('Toggle edit point')), 1, 2, 7, 8)
table.attach(self.make_label(_('Add edit point at beginning of line/selection')), 1, 2, 8, 9)
table.attach(self.make_label(_('Add edit point at end of line/selection')), 1, 2, 9, 10)
+ table.attach(self.make_label(_('Align edit points')), 1, 2, 10, 11)
+ table.attach(self.make_label(_('Align edit points with additional space')), 1, 2, 11, 12)
table.show_all()
tooltip.set_custom(table)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]