summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorhut <hut@lavabit.com>2009-12-29 19:45:18 +0100
committerhut <hut@lavabit.com>2009-12-29 19:45:18 +0100
commitb4cb1f7d98ad6a98207c630ac2ee20b753621cd3 (patch)
treeadb1aa83e7411fcaa5d86e889a5a43863f417131
parentacde88ad401904abab55bfc259cb74c6d5e661a6 (diff)
downloadranger-b4cb1f7d98ad6a98207c630ac2ee20b753621cd3.tar.gz
fixed mouse events in pager
-rw-r--r--ranger/gui/ui.py9
-rw-r--r--ranger/gui/widgets/filelistcontainer.py9
-rw-r--r--ranger/gui/widgets/pager.py8
3 files changed, 18 insertions, 8 deletions
diff --git a/ranger/gui/ui.py b/ranger/gui/ui.py
index 91964eb1..254b7eab 100644
--- a/ranger/gui/ui.py
+++ b/ranger/gui/ui.py
@@ -95,14 +95,7 @@ class UI(DisplayableContainer):
 #		log('{0:0>28b} ({0})'.format(event.bstate))
 #		log('y: {0}  x: {1}'.format(event.y, event.x))
 
-		if DisplayableContainer.click(self, event):
-			return
-
-		n = event.ctrl() and 1 or 3
-		if event.pressed(4):
-			self.fm.scroll(relative = -n)
-		elif event.pressed(2) or event.key_invalid():
-			self.fm.scroll(relative = n)
+		DisplayableContainer.click(self, event)
 
 	def handle_key(self, key):
 		"""Handles key input"""
diff --git a/ranger/gui/widgets/filelistcontainer.py b/ranger/gui/widgets/filelistcontainer.py
index 7b52a641..b5ef4190 100644
--- a/ranger/gui/widgets/filelistcontainer.py
+++ b/ranger/gui/widgets/filelistcontainer.py
@@ -74,6 +74,15 @@ class FileListContainer(Widget, DisplayableContainer):
 
 			left += wid
 	
+	def click(self, event):
+		n = event.ctrl() and 1 or 3
+		if event.pressed(4):
+			self.fm.scroll(relative = -n)
+		elif event.pressed(2) or event.key_invalid():
+			self.fm.scroll(relative = n)
+		else:
+			DisplayableContainer.click(self, event)
+	
 	def open_pager(self):
 		self.pager.activate(True)
 		self.pager.open()
diff --git a/ranger/gui/widgets/pager.py b/ranger/gui/widgets/pager.py
index 7b55027c..c149f89a 100644
--- a/ranger/gui/widgets/pager.py
+++ b/ranger/gui/widgets/pager.py
@@ -101,6 +101,14 @@ class Pager(Widget):
 		self.source = source
 		return True
 
+	def click(self, event):
+		n = event.ctrl() and 1 or 3
+		if event.pressed(4):
+			self.move(relative = -n)
+		elif event.pressed(2) or event.key_invalid():
+			self.move(relative = n)
+		return True
+
 	def _get_line(self, n, attempt_to_read=True):
 		try:
 			return self.lines[n]
ass="w"> int transformed_until; recipe() :transformed_until(-1) {} :(before "End Types") typedef void (*transform_fn)(recipe_ordinal); :(before "End Globals") vector<transform_fn> Transform; :(code) void transform_all() { //? cerr << "AAA transform_all\n"; //? 2 for (long long int t = 0; t < SIZE(Transform); ++t) { for (map<recipe_ordinal, recipe>::iterator p = Recipe.begin(); p != Recipe.end(); ++p) { recipe& r = p->second; if (r.steps.empty()) continue; if (r.transformed_until != t-1) continue; (*Transform.at(t))(/*recipe_ordinal*/p->first); r.transformed_until = t; } } parse_int_reagents(); // do this after all other transforms have run } void parse_int_reagents() { //? cout << "parse_int_reagents\n"; //? 1 for (map<recipe_ordinal, recipe>::iterator p = Recipe.begin(); p != Recipe.end(); ++p) { recipe& r = p->second; if (r.steps.empty()) continue; for (long long int index = 0; index < SIZE(r.steps); ++index) { instruction& inst = r.steps.at(index); for (long long int i = 0; i < SIZE(inst.ingredients); ++i) { populate_value(inst.ingredients.at(i)); } for (long long int i = 0; i < SIZE(inst.products); ++i) { populate_value(inst.products.at(i)); } } } } void populate_value(reagent& r) { if (r.initialized) return; // End Reagent-parsing Exceptions if (!is_integer(r.name)) return; r.set_value(to_integer(r.name)); }