summaryrefslogtreecommitdiff
path: root/surf.c
diff options
context:
space:
mode:
authorTroels Henriksen <athas@sigkill.dk>2012-05-31 11:46:24 +0200
committerTroels Henriksen <athas@sigkill.dk>2012-05-31 11:46:24 +0200
commit3083ef4031aaf48926497397295b0db639a6a9c1 (patch)
treefcb32c2546910c24ed27fd2f19037ec1326ea1db /surf.c
parentcf75bf2777560d4ded7083517f0c72395052f1f0 (diff)
downloadsurf-3083ef4031aaf48926497397295b0db639a6a9c1.tar.gz
surf-3083ef4031aaf48926497397295b0db639a6a9c1.tar.bz2
surf-3083ef4031aaf48926497397295b0db639a6a9c1.zip
Keybindings for scrolling left and right; code by stanio.
Diffstat (limited to 'surf.c')
-rw-r--r--surf.c38
1 files changed, 28 insertions, 10 deletions
diff --git a/surf.c b/surf.c
index 27cc4e9..9a621e6 100644
--- a/surf.c
+++ b/surf.c
@@ -96,7 +96,9 @@ static GdkFilterReturn processx(GdkXEvent *xevent, GdkEvent *event, gpointer d);
static void progresschange(WebKitWebView *view, GParamSpec *pspec, Client *c);
static void reload(Client *c, const Arg *arg);
static void resize(GtkWidget *w, GtkAllocation *a, Client *c);
-static void scroll(Client *c, const Arg *arg);
+static void scroll_h(Client *c, const Arg *arg);
+static void scroll_v(Client *c, const Arg *arg);
+static void scroll(GtkAdjustment *a, const Arg *arg);
static void setatom(Client *c, int a, const char *v);
static void setcookie(SoupCookie *c);
static void setup(void);
@@ -662,16 +664,32 @@ resize(GtkWidget *w, GtkAllocation *a, Client *c) {
}
void
-scroll(Client *c, const Arg *arg) {
- gdouble v;
- GtkAdjustment *a;
+scroll_h(Client *c, const Arg *arg) {
+ scroll(gtk_scrolled_window_get_hadjustment(GTK_SCROLLED_WINDOW(c->scroll)), arg);
+}
+
+void
+scroll_v(Client *c, const Arg *arg) {
+ scroll(gtk_scrolled_window_get_vadjustment(GTK_SCROLLED_WINDOW(c->scroll)), arg);
+}
+
+void
+scroll(GtkAdjustment *a, const Arg *arg) {
+ gdouble v;
- a = gtk_scrolled_window_get_vadjustment(GTK_SCROLLED_WINDOW(c->scroll));
- v = gtk_adjustment_get_value(a);
- v += gtk_adjustment_get_step_increment(a) * arg->i;
- v = MAX(v, 0.0);
- v = MIN(v, gtk_adjustment_get_upper(a) - gtk_adjustment_get_page_size(a));
- gtk_adjustment_set_value(a, v);
+ v = gtk_adjustment_get_value(a);
+ switch (arg->i){
+ case +10000:
+ case -10000:
+ v += gtk_adjustment_get_page_increment(a) * (arg->i / 10000); break;
+ case +20000:
+ case -20000:
+ default:
+ v += gtk_adjustment_get_step_increment(a) * arg->i;
+ }
+ v = MAX(v, 0.0);
+ v = MIN(v, gtk_adjustment_get_upper(a) - gtk_adjustment_get_page_size(a));
+ gtk_adjustment_set_value(a, v);
}
void