summaryrefslogtreecommitdiff
path: root/sys/src/libdraw/eenter.c
diff options
context:
space:
mode:
authorcinap_lenrek <cinap_lenrek@gmx.de>2012-07-22 16:32:59 +0200
committercinap_lenrek <cinap_lenrek@gmx.de>2012-07-22 16:32:59 +0200
commitf3b08dd655446276be6426506a1fd84d13defbad (patch)
treea656f4f810b66f3619348c4593f191ee0e7e579a /sys/src/libdraw/eenter.c
parentaae765a161228a70ffe60fb9f62b17c44a66f14b (diff)
libdraw: enter/eenter, set and restore clip rect
Diffstat (limited to 'sys/src/libdraw/eenter.c')
-rw-r--r--sys/src/libdraw/eenter.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/sys/src/libdraw/eenter.c b/sys/src/libdraw/eenter.c
index d1434eacc..bd02d063d 100644
--- a/sys/src/libdraw/eenter.c
+++ b/sys/src/libdraw/eenter.c
@@ -10,7 +10,7 @@ eenter(char *ask, char *buf, int len, Mouse *m)
int done, down, tick, n, h, w, l, i;
Image *b, *save, *backcol, *bordcol;
Point p, o, t;
- Rectangle r;
+ Rectangle r, sc;
Event ev;
Rune k;
@@ -23,6 +23,9 @@ eenter(char *ask, char *buf, int len, Mouse *m)
while(ecankbd())
ekbd();
+ sc = screen->clipr;
+ replclipr(screen, 0, screen->r);
+
if(m) o = m->xy;
if(buf && len > 0)
@@ -186,6 +189,8 @@ eenter(char *ask, char *buf, int len, Mouse *m)
save = nil;
}
+ replclipr(screen, 0, sc);
+
freeimage(backcol);
freeimage(bordcol);
flushimage(display, 1);