Subject: pkg/14407: patch of -rightbar support of kterm
To: None <gnats-bugs@gnats.netbsd.org>
From: OGATA <ogata@isp.qix.org>
List: netbsd-bugs
Date: 10/31/2001 03:23:58
>Number:         14407
>Category:       pkg
>Synopsis:       patch of -rightbar support of kterm
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    pkg-manager
>State:          open
>Class:          change-request
>Submitter-Id:   net
>Arrival-Date:   Tue Oct 30 10:26:00 PST 2001
>Closed-Date:
>Last-Modified:
>Originator:     OGATA Hiroshi
>Release:        NetBSD 1.5.2
>Organization:
>Environment:

System: NetBSD Leia2 1.5.2 NetBSD 1.5.2 (GENERIC_SCSI3-Leia2-1.5.2XCAST6) #0: Thu Oct 25 17:43:23 JST 2001 ogata@Kodiaka:/export/XCAST6/syssrc-xcast0.0.2/sys/arch/sparc/compile/GENERIC_SCSI3-Leia2-1.5.2XCAST6 sparc


>Description:

    pkgsrc of kterm will support patch of -rightbar.
    I was reported tech-pkg-ja ML(Japanese).
    http://www.jp.netbsd.org/ja/JP/ml/tech-pkg-ja/200110/msg00027.html
    Patch of kterm was made by shimizu-san that reported at FreeBSD-users-jp
    ML(Japanese).
    http://home.jp.FreeBSD.ORG/cgi-bin/showmail/FreeBSD-users-jp/64149
    Try example of 'env KTERM_USE_RIGHTBAR=YES make'
    I was tested it on SPARC, and it was no problem.

>How-To-Repeat:

>Fix:
diff -u -r -N kterm.org/Makefile kterm/Makefile
--- kterm.org/Makefile	Thu Aug 23 13:26:55 2001
+++ kterm/Makefile	Sun Oct 21 17:38:14 2001
@@ -38,5 +38,11 @@
 	@${PATCH} ${PATCH_ARGS} < ${FILESDIR}/patch-xaw3d
 .endif
 
+.if defined(KTERM_USE_RIGHTBAR) && ${KTERM_USE_RIGHTBAR} == "YES"
+post-patch:
+	@${ECHO_MSG}  "===>  Applying rightbar patch"
+	@${PATCH} ${PATCH_ARGS} < ${FILESDIR}/patch-rightbar
+.endif
+
 .include "../../mk/xaw.buildlink.mk"
 .include "../../mk/bsd.pkg.mk"
diff -u -r -N kterm.org/files/patch-rightbar kterm/files/patch-rightbar
--- kterm.org/files/patch-rightbar	Thu Jan  1 09:00:00 1970
+++ kterm/files/patch-rightbar	Sun Oct 21 17:30:06 2001
@@ -0,0 +1,534 @@
+--- Imakefile.org	Fri Jul 12 14:01:04 1996
++++ Imakefile	Sun Sep  9 05:04:36 2001
+@@ -32,7 +32,7 @@
+ 		  -DOSMINORVERSION=$(OSMINORVERSION)
+    MISC_DEFINES = /* -DALLOWLOGFILEEXEC */ 
+     XKB_DEFINES = XkbClientDefines
+-        DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE
++        DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE -DSCROLLBAR_RIGHT 
+ 
+ #ifdef KTERM_XIM
+         XIMSRCS = xim.c
+--- button.c.org	Tue Jul  2 14:01:46 1996
++++ button.c	Sun Sep  9 05:03:27 2001
+@@ -849,7 +849,7 @@
+ 		row = firstValidRow;
+ 	else if(row > lastValidRow)
+ 		row = lastValidRow;
+-	col = (x - screen->border - screen->scrollbar) / FontWidth(screen);
++	col = (x - OriginX(screen)) / FontWidth(screen);
+ 	if(col < 0)
+ 		col = 0;
+ 	else if(col > screen->max_col+1) {
+@@ -1817,8 +1817,7 @@
+ 
+ 	row = (event->y - screen->border) 
+ 	 / FontHeight(screen);
+-	col = (event->x - screen->border - screen->scrollbar)
+-	 / FontWidth(screen);
++	col = (event->x - OriginX(screen)) / FontWidth(screen);
+ 	(void) strcpy(line, "\033[M");
+ 	if (screen->send_mouse_pos == 1) {
+ 		line[3] = ' ' + button;
+--- charproc.c.org	Fri Jul 12 14:01:36 1996
++++ charproc.c	Sun Sep  9 05:03:27 2001
+@@ -167,6 +167,9 @@
+ #define XtNnMarginBell "nMarginBell"
+ #define XtNresizeGravity "resizeGravity"
+ #define XtNreverseWrap "reverseWrap"
++#ifdef SCROLLBAR_RIGHT
++#define XtNrightScrollBar "rightScrollBar"
++#endif
+ #define XtNautoWrap "autoWrap"
+ #define XtNsaveLines "saveLines"
+ #define XtNscrollBar "scrollBar"
+@@ -227,6 +230,9 @@
+ #define XtCColumn "Column"
+ #define XtCResizeGravity "ResizeGravity"
+ #define XtCReverseWrap "ReverseWrap"
++#ifdef SCROLLBAR_RIGHT
++#define XtCRightScrollBar "RightScrollBar"
++#endif
+ #define XtCAutoWrap "AutoWrap"
+ #define XtCSaveLines "SaveLines"
+ #define XtCScrollBar "ScrollBar"
+@@ -660,6 +666,11 @@
+ {XtNscrollBar, XtCScrollBar, XtRBoolean, sizeof(Boolean),
+ 	XtOffsetOf(XtermWidgetRec, misc.scrollbar),
+ 	XtRBoolean, (XtPointer) &defaultFALSE},
++#ifdef SCROLLBAR_RIGHT
++{XtNrightScrollBar, XtCRightScrollBar, XtRBoolean, sizeof(Boolean),
++	XtOffsetOf(XtermWidgetRec, misc.useRight),
++	XtRBoolean, (XtPointer) &defaultFALSE},
++#endif
+ {XtNscrollTtyOutput,XtCScrollCond, XtRBoolean, sizeof(Boolean),
+ 	XtOffsetOf(XtermWidgetRec, screen.scrollttyoutput),
+ 	XtRBoolean, (XtPointer) &defaultTRUE},
+@@ -2539,8 +2550,7 @@
+ 					status = XtMakeResizeRequest (
+ 					    (Widget) termw, 
+ 					    (Dimension) FontWidth(screen) * j
+-					        + 2*screen->border
+-						+ screen->scrollbar,
++					        + 2*screen->border + Scrollbar(screen),
+ 					    (Dimension) FontHeight(screen)
+ 						* (screen->max_row + 1)
+ #ifdef STATUSLINE
+@@ -2780,8 +2790,7 @@
+ 					status = XtMakeResizeRequest (
+ 					    (Widget) termw,
+ 					    (Dimension) FontWidth(screen) * j 
+-						+ 2*screen->border
+-						+ screen->scrollbar,
++						+ 2*screen->border + Scrollbar(screen),
+ 					    (Dimension) FontHeight(screen)
+ 						* (screen->max_row + 1)
+ 						+ 2*screen->border,
+@@ -3033,7 +3042,7 @@
+ 			XClearArea(
+ 			    screen->display,
+ 			    TextWindow(screen),
+-			    (int) screen->border + screen->scrollbar,
++			    (int) OriginX(screen),
+ 			    (int) top * FontHeight(screen) + screen->border,
+ 			    (unsigned) Width(screen),
+ 			    (unsigned) (screen->max_row - top + 1)
+@@ -4147,7 +4156,7 @@
+ 			XtMakeResizeRequest(
+ 			    (Widget) term,
+ 			    (Dimension) 80*FontWidth(screen)
+-				+ 2 * screen->border + screen->scrollbar,
++				+ 2 * screen->border + Scrollbar(screen),
+ #ifdef STATUSLINE
+ 			    (Dimension) screen->statusheight +
+ #endif /* STATUSLINE */
+@@ -4207,8 +4216,7 @@
+ 	screen->statusheight = FontHeight(screen) + 2;
+ 	DoResizeScreen(term);
+ 	if (screen->scrollWidget)
+-		ResizeScrollBar(screen->scrollWidget, -1, -1,
+-		  Height(screen) + screen->border * 2 + screen->statusheight);
++		ResizeScrollBar(screen);
+ }
+ 
+ HideStatus()
+@@ -4259,7 +4267,7 @@
+ # endif /* !KTERM */
+ 	XFillRectangle(screen->display, TextWindow(screen),
+ 		screen->reversestatus ? screen->normalGC : screen->reverseGC,
+-		screen->border - 1 + screen->scrollbar,
++		screen->border - 1 + Scrollbar(screen),
+ 		Height(screen) + screen->border * 2 + 1,
+ 		Width(screen),
+ 		screen->statusheight - 2);
+@@ -4273,7 +4281,7 @@
+ # endif /* KTERM */
+ 	XDrawRectangle(screen->display, TextWindow(screen),
+ 		       screen->normalGC,
+-		       screen->scrollbar,
++		       ScrollbarX(screen),
+ 		       Height(screen) + screen->border * 2,
+ 		       Width(screen) + screen->border * 2 - 1,
+ 		       screen->statusheight - 1);
+--- input.c.org	Fri Jul 12 14:01:36 1996
++++ input.c	Sun Sep  9 05:03:27 2001
+@@ -37,7 +37,7 @@
+ 
+ static char *kypd_num = " XXXXXXXX\tXXX\rXXXxxxxXXXXXXXXXXXXXXXXXXXXX*+,-./0123456789XXX=";
+ static char *kypd_apl = " ABCDEFGHIJKLMNOPQRSTUVWXYZ??????abcdefghijklmnopqrstuvwxyzXXX";
+-static char *cur = "DACB";
++static char *cur = "HDACB  FE";
+ 
+ static int funcvalue(), sunfuncvalue();
+ extern Boolean sunFunctionKeys;
+@@ -129,10 +129,10 @@
+        		if (keyboard->flags & CURSOR_APL) {
+ 			reply.a_type = SS3;
+ 			unparseseq(&reply, pty);
+-			unparseputc(cur[keysym-XK_Left], pty);
++			unparseputc(cur[keysym-XK_Home], pty);
+ 		} else {
+ 			reply.a_type = CSI;
+-			reply.a_final = cur[keysym-XK_Left];
++			reply.a_final = cur[keysym-XK_Home];
+ 			unparseseq(&reply, pty);
+ 		}
+ 		key = TRUE;
+--- kinput2.c.org	Fri Jul 12 14:01:42 1996
++++ kinput2.c	Sun Sep  9 05:03:27 2001
+@@ -284,7 +284,7 @@
+     TScreen *screen = &term->screen;
+     static XRectangle area;
+ 
+-    area.x = screen->border + screen->scrollbar;
++    area.x = OriginX(screen);
+     area.y = screen->border;
+     area.width = Width(screen);
+     area.height = Height(screen);
+--- kterm.h.org	Fri Jul 12 14:01:37 1996
++++ kterm.h	Sun Sep  9 05:03:27 2001
+@@ -36,6 +36,6 @@
+ #define KTERM_KINPUT2	/* Kinput2 protocol */
+ #define KTERM_COLOR	/* color sequence */
+ #define KTERM_NOTEK	/* disables Tektronix emulation */
+-#undef  KTERM_XAW3D	/* Xaw3d -DARROW_SCROLLBAR support */
++#define KTERM_XAW3D	/* Xaw3d -DARROW_SCROLLBAR support */
+ 
+ #endif /* !_KTERM_H_ */
+--- main.c.org	Fri Jul 12 14:01:38 1996
++++ main.c	Sun Sep  9 05:03:27 2001
+@@ -745,6 +745,10 @@
+ {"+s",		"*multiScroll",	XrmoptionNoArg,		(caddr_t) "off"},
+ {"-sb",		"*scrollBar",	XrmoptionNoArg,		(caddr_t) "on"},
+ {"+sb",		"*scrollBar",	XrmoptionNoArg,		(caddr_t) "off"},
++#ifdef SCROLLBAR_RIGHT
++{"-leftbar",    "*rightScrollBar", XrmoptionNoArg,  (caddr_t) "off"},
++{"-rightbar",   "*rightScrollBar", XrmoptionNoArg,  (caddr_t) "on"},
++#endif
+ {"-sf",		"*sunFunctionKeys", XrmoptionNoArg,	(caddr_t) "on"},
+ {"+sf",		"*sunFunctionKeys", XrmoptionNoArg,	(caddr_t) "off"},
+ {"-si",		"*scrollTtyOutput",	XrmoptionNoArg,		(caddr_t) "off"},
+@@ -859,6 +863,10 @@
+ { "-/+rw",                 "turn on/off reverse wraparound" },
+ { "-/+s",                  "turn on/off multiscroll" },
+ { "-/+sb",                 "turn on/off scrollbar" },
++#ifdef SCROLLBAR_RIGHT
++{ "-rightbar",             "force scrollbar right (default left)" },
++{ "-leftbar",              "force scrollbar left" },
++#endif
+ { "-/+sf",                 "turn on/off Sun Function Key escape codes" },
+ { "-/+si",                 "turn on/off scroll-on-tty-output inhibit" },
+ { "-/+sk",                 "turn on/off scroll-on-keypress" },
+--- ptyx.h.org	Tue Jul  2 14:01:53 1996
++++ ptyx.h	Sun Sep  9 05:03:27 2001
+@@ -546,6 +546,9 @@
+     Boolean tekInhibit;
+ #endif /* !KTERM_NOTEK */
+     Boolean scrollbar;
++#ifdef SCROLLBAR_RIGHT
++	Boolean useRight;
++#endif
+     Boolean titeInhibit;
+ #ifndef KTERM_NOTEK
+     Boolean tekSmall;	/* start tek window in small size */
+@@ -708,8 +711,17 @@
+ #define TekScale(screen)	(screen->fullTwin.tekscale)
+ #endif /* !KTERM_NOTEK */
+ 
+-#define CursorX(screen,col) ((col) * FontWidth(screen) + screen->border \
+-			+ screen->scrollbar)
++#define Scrollbar(screen)	((screen)->scrollbar)
++
++#ifdef SCROLLBAR_RIGHT
++#define ScrollbarX(screen)	((term->misc.useRight)?0:Scrollbar(screen))
++#define OriginX(screen)	(ScrollbarX(screen) + screen->border)
++#else
++#define ScrollbarX(screen)	(Scrollbar(screen))
++#define OriginX(screen)	(Scrollbar(screen) + screen->border)
++#endif
++
++#define CursorX(screen,col) ((col) * FontWidth(screen) + OriginX(screen))
+ #ifdef STATUSLINE
+ #define CursorY(screen,row) ((row)>screen->max_row \
+ 	? (row) * FontHeight(screen) + screen->border * 2 + 1 \
+--- screen.c.org	Sun Jun 23 17:00:26 1996
++++ screen.c	Sun Sep  9 05:03:27 2001
+@@ -601,7 +601,7 @@
+ 		left = CursorX(screen, leftcol);
+ 		width = ncols * FontWidth(screen);
+ 		if (leftcol == 0) {
+-		    left = screen->scrollbar;
++		    left = ScrollbarX(screen);
+ 		    width += screen->border;
+ 		}
+ 		if (leftcol + ncols - 1 >= screen->max_col)
+@@ -869,7 +869,7 @@
+ 	rows = (height + FontHeight(screen) / 2 - border) /
+ #endif /* !STATUSLINE */
+ 	 FontHeight(screen);
+-	cols = (width + FontWidth(screen) / 2 - border - screen->scrollbar) /
++	cols = (width + FontWidth(screen) / 2 - border - Scrollbar(screen)) /
+ 	 FontWidth(screen);
+ 	if (rows < 1) rows = 1;
+ 	if (cols < 1) cols = 1;
+@@ -879,7 +879,7 @@
+ 		/* bit_gravity != ForgetGravity */
+ 		if (rows > screen->max_row + 1) {
+ 		    XClearArea (screen->display, tw, 
+-				screen->scrollbar,
++				ScrollbarX(screen),
+ 				(screen->max_row + 1) * FontHeight(screen) +
+ 				screen->border * 2,
+ 				(screen->max_col + 1) * FontHeight(screen) +
+@@ -888,7 +888,7 @@
+ 				True);
+ 		} else if (rows < screen->max_row + 1) {
+ 		    XClearArea (screen->display, tw, 
+-				screen->scrollbar,
++				ScrollbarX(screen),
+ 				rows * FontHeight(screen) +
+ 				screen->border * 2,
+ 				cols * FontWidth(screen) + screen->border * 2,
+@@ -964,13 +964,16 @@
+ #else /* !STATUSLINE */
+ 		screen->fullVwin.height = height - border;
+ #endif /* !STATUSLINE */
+-		screen->fullVwin.width = width - border - screen->scrollbar;
++		screen->fullVwin.width = width - border - Scrollbar(screen);
+ 
+ 	} else if(FullHeight(screen) == height && FullWidth(screen) == width)
+ 	 	return(0);	/* nothing has changed at all */
+ 
++	screen->fullVwin.fullheight = height;
++	screen->fullVwin.fullwidth = width;
++
+ 	if(screen->scrollWidget)
+-		ResizeScrollBar(screen->scrollWidget, -1, -1, height);
++		ResizeScrollBar(screen);
+ 	
+ 	screen->fullVwin.fullheight = height;
+ 	screen->fullVwin.fullwidth = width;
+--- scrollbar.c.org	Fri Jul 12 14:01:39 1996
++++ scrollbar.c	Sun Sep  9 05:06:08 2001
+@@ -205,13 +205,6 @@
+ 	return (scrollWidget);
+ }
+ 
+-static void RealizeScrollBar (sbw, screen)
+-    Widget sbw;
+-    TScreen *screen;
+-{
+-    XtRealizeWidget (sbw);
+-}
+-
+ 
+ ScrollBarReverseVideo(scrollWidget)
+ 	register Widget scrollWidget;
+@@ -255,14 +248,28 @@
+ 	
+ }
+ 
+-ResizeScrollBar(scrollWidget, x, y, height)
+-	register Widget scrollWidget;
+-	int x, y;
+-	unsigned height;
++void
++ResizeScrollBar(TScreen *screen)
+ {
+-	XtConfigureWidget(scrollWidget, x, y, scrollWidget->core.width,
+-	    height, scrollWidget->core.border_width);
+-	ScrollBarDrawThumb(scrollWidget);
++	XtConfigureWidget(
++		screen->scrollWidget,
++#ifdef SCROLLBAR_RIGHT
++			(term->misc.useRight)
++			? (screen->fullVwin.fullwidth -
++			   screen->scrollWidget->core.width -
++			   screen->scrollWidget->core.border_width)
++			: -1,
++#else
++		-1,
++#endif
++		-1,
++		screen->scrollWidget->core.width,
++#ifdef STATUSLINE
++		screen->statusheight +
++#endif /* STATUSLINE */
++		screen->fullVwin.height + screen->border * 2,
++		screen->scrollWidget->core.border_width);
++	ScrollBarDrawThumb(screen->scrollWidget);
+ }
+ 
+ WindowScroll(screen, top)
+@@ -297,7 +304,7 @@
+ 		scrolltop = lines;
+ 		refreshtop = scrollheight;
+ 	}
+-	x = screen->scrollbar +	screen->border;
++ 	x = OriginX(screen);
+ 	scrolling_copy_area(screen, scrolltop, scrollheight, -i);
+ 	screen->topline = top;
+ 
+@@ -385,17 +392,28 @@
+ #endif /* !KTERM */
+ 	}
+ 
+-	ResizeScrollBar (screen->scrollWidget, -1, -1, 
+-#ifdef STATUSLINE
+-			 screen->statusheight +
+-#endif /* STATUSLINE */
+-			 Height (screen) + border);
+-	RealizeScrollBar (screen->scrollWidget, screen);
++	ResizeScrollBar (screen);
++	XtRealizeWidget (screen->scrollWidget);
+ 	screen->scrollbar = screen->scrollWidget->core.width +
+ 	     screen->scrollWidget->core.border_width;
+ 
+ 	ScrollBarDrawThumb(screen->scrollWidget);
+ 	DoResizeScreen (xw);
++
++#ifdef SCROLLBAR_RIGHT
++	/*
++	 * Adjust the scrollbar position if we're asked to turn on scrollbars
++	 * for the first time after the xterm is already running.  That makes
++	 * the window grow after we've initially configured the scrollbar's
++	 * position.  (There must be a better way).
++	 */
++	if (term->misc.useRight
++	 && screen->fullVwin.fullwidth < term->core.width)
++		XtVaSetValues(screen->scrollWidget, XtNx,
++		screen->fullVwin.fullwidth - screen->scrollWidget->core.border_width,
++        NULL);
++#endif
++
+ 	XtMapWidget(screen->scrollWidget);
+ 	update_scrollbar ();
+ 	if (screen->buf) {
+--- util.c.org	Tue Jul  2 14:01:53 1996
++++ util.c	Sun Sep  9 05:07:49 2001
+@@ -116,7 +116,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -240,7 +240,7 @@
+ 		XClearArea (
+ 		   screen->display,
+ 		   TextWindow(screen),
+-		   (int) screen->border + screen->scrollbar,
++		   (int) OriginX(screen),
+ 		   (int) refreshtop * FontHeight(screen) + screen->border,
+ 		   (unsigned) Width(screen),
+ 		   (unsigned) refreshheight * FontHeight(screen),
+@@ -320,7 +320,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -381,7 +381,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -458,7 +458,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -570,7 +570,7 @@
+ 		     screen->normalGC :
+ #endif /* STATUSLINE */
+ 		     screen->reverseGC,
+-		     screen->border + screen->scrollbar
++		     OriginX(screen)
+ 		       + Width(screen) - n*FontWidth(screen),
+ 		     CursorY (screen, screen->cur_row), n * FontWidth(screen),
+ 		     FontHeight(screen));
+@@ -599,8 +599,8 @@
+ 			height = screen->max_row;
+ 		if((height -= top) > 0)
+ 			XClearArea(screen->display, TextWindow(screen),
+-			 screen->border + screen->scrollbar, top *
+-			 FontHeight(screen) + screen->border,
++			 OriginX(screen),
++             top * FontHeight(screen) + screen->border,
+ 			 Width(screen), height * FontHeight(screen), FALSE);
+ 
+ 		if(screen->cur_row - screen->topline <= screen->max_row)
+@@ -623,8 +623,8 @@
+ 			FlushScroll(screen);
+ 		if(++top <= screen->max_row)
+ 			XClearArea(screen->display, TextWindow(screen),
+-			 screen->border + screen->scrollbar, top *
+-			 FontHeight(screen) + screen->border,
++			 OriginX(screen),
++             top * FontHeight(screen) + screen->border,
+ 			 Width(screen), (screen->max_row - top + 1) *
+ 			 FontHeight(screen), FALSE);
+ 	}
+@@ -713,7 +713,7 @@
+ 		     screen->normalGC :
+ #endif /* STATUSLINE */
+ 		     screen->reverseGC,
+-		     screen->border + screen->scrollbar,
++		     OriginX(screen),
+ 		      CursorY (screen, screen->cur_row),
+ 		     (screen->cur_col + 1) * FontWidth(screen),
+ 		     FontHeight(screen));
+@@ -764,7 +764,7 @@
+ 		     screen->normalGC :
+ #endif /* STATUSLINE */
+ 		     screen->reverseGC,
+-		     screen->border + screen->scrollbar,
++		     OriginX(screen),
+ 		      CursorY (screen, screen->cur_row),
+ 		     Width(screen), FontHeight(screen));
+ 	    }
+@@ -796,7 +796,7 @@
+ 			XClearWindow(screen->display, TextWindow(screen));
+ 		else
+ 			XClearArea(screen->display, TextWindow(screen),
+-			 screen->border + screen->scrollbar, 
++			 OriginX(screen),
+ 			 top * FontHeight(screen) + screen->border,	
+ 		 	 Width(screen), (screen->max_row - top + 1) *
+ 			 FontHeight(screen), FALSE);
+@@ -913,7 +913,7 @@
+     int amount;			/* number of lines to move up (neg=down) */
+ {
+     if(nlines > 0) {
+-	int src_x = screen->border + screen->scrollbar;
++ 	int src_x = OriginX(screen);
+ 	int src_y = firstline * FontHeight(screen) + screen->border;
+ 
+ 	copy_area(screen, src_x, src_y,
+@@ -1001,15 +1001,13 @@
+ 	if(toprow > screen->max_row + 1)
+ 		toprow = screen->max_row + 1;
+ #endif /* STATUSLINE */
+-	leftcol = (rect_x - screen->border - screen->scrollbar)
+-	    / FontWidth(screen);
++	leftcol = (rect_x - OriginX(screen)) / FontWidth(screen);
+ 	if(leftcol < 0)
+ 		leftcol = 0;
+ 	nrows = (rect_y + rect_height - 1 - screen->border) / 
+-		FontHeight(screen) - toprow + 1;
+-	ncols =
+-	 (rect_x + rect_width - 1 - screen->border - screen->scrollbar) /
+-			FontWidth(screen) - leftcol + 1;
++    	FontHeight(screen) - toprow + 1;
++	ncols = (rect_x + rect_width - 1 - OriginX(screen)) /
++		FontWidth(screen) - leftcol + 1;
+ 	toprow -= screen->scrolls;
+ 	if (toprow < 0) {
+ 		nrows += toprow;
+--- xim.c.org	Fri Jul 12 14:01:43 1996
++++ xim.c	Sun Sep  9 05:03:27 2001
+@@ -149,9 +149,9 @@
+ TScreen *screen;
+ XRectangle *rect_p;
+ {
+-	rect_p->x = screen->scrollbar;
++	rect_p->x = ScrollbarX(screen);
+ 	rect_p->y = 0;
+-	rect_p->width  = FullWidth(screen)  - screen->scrollbar;
++	rect_p->width  = FullWidth(screen)  - Scrollbar(screen);
+ 	rect_p->height = FullHeight(screen);
+ }
+ 
diff -u -r -N kterm.org/files/patch-rightbar.orig kterm/files/patch-rightbar.orig
--- kterm.org/files/patch-rightbar.orig	Thu Jan  1 09:00:00 1970
+++ kterm/files/patch-rightbar.orig	Sun Oct 21 17:03:18 2001
@@ -0,0 +1,545 @@
+--- Imakefile.org	Fri Jul 12 14:01:04 1996
++++ Imakefile	Sun Sep  9 05:04:36 2001
+@@ -32,7 +32,7 @@
+ 		  -DOSMINORVERSION=$(OSMINORVERSION)
+    MISC_DEFINES = /* -DALLOWLOGFILEEXEC */ 
+     XKB_DEFINES = XkbClientDefines
+-        DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE
++        DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE -DSCROLLBAR_RIGHT 
+ 
+ #ifdef KTERM_XIM
+         XIMSRCS = xim.c
+--- Makefile.org	Sun Sep  9 05:03:19 2001
++++ Makefile	Sun Sep  9 05:05:04 2001
+@@ -663,7 +663,7 @@
+ 
+    MISC_DEFINES =
+     XKB_DEFINES =
+-        DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE
++        DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE -DSCROLLBAR_RIGHT
+ 
+         XIMSRCS = xim.c
+         XIMOBJS = xim.o
+--- button.c.org	Tue Jul  2 14:01:46 1996
++++ button.c	Sun Sep  9 05:03:27 2001
+@@ -849,7 +849,7 @@
+ 		row = firstValidRow;
+ 	else if(row > lastValidRow)
+ 		row = lastValidRow;
+-	col = (x - screen->border - screen->scrollbar) / FontWidth(screen);
++	col = (x - OriginX(screen)) / FontWidth(screen);
+ 	if(col < 0)
+ 		col = 0;
+ 	else if(col > screen->max_col+1) {
+@@ -1817,8 +1817,7 @@
+ 
+ 	row = (event->y - screen->border) 
+ 	 / FontHeight(screen);
+-	col = (event->x - screen->border - screen->scrollbar)
+-	 / FontWidth(screen);
++	col = (event->x - OriginX(screen)) / FontWidth(screen);
+ 	(void) strcpy(line, "\033[M");
+ 	if (screen->send_mouse_pos == 1) {
+ 		line[3] = ' ' + button;
+--- charproc.c.org	Fri Jul 12 14:01:36 1996
++++ charproc.c	Sun Sep  9 05:03:27 2001
+@@ -167,6 +167,9 @@
+ #define XtNnMarginBell "nMarginBell"
+ #define XtNresizeGravity "resizeGravity"
+ #define XtNreverseWrap "reverseWrap"
++#ifdef SCROLLBAR_RIGHT
++#define XtNrightScrollBar "rightScrollBar"
++#endif
+ #define XtNautoWrap "autoWrap"
+ #define XtNsaveLines "saveLines"
+ #define XtNscrollBar "scrollBar"
+@@ -227,6 +230,9 @@
+ #define XtCColumn "Column"
+ #define XtCResizeGravity "ResizeGravity"
+ #define XtCReverseWrap "ReverseWrap"
++#ifdef SCROLLBAR_RIGHT
++#define XtCRightScrollBar "RightScrollBar"
++#endif
+ #define XtCAutoWrap "AutoWrap"
+ #define XtCSaveLines "SaveLines"
+ #define XtCScrollBar "ScrollBar"
+@@ -660,6 +666,11 @@
+ {XtNscrollBar, XtCScrollBar, XtRBoolean, sizeof(Boolean),
+ 	XtOffsetOf(XtermWidgetRec, misc.scrollbar),
+ 	XtRBoolean, (XtPointer) &defaultFALSE},
++#ifdef SCROLLBAR_RIGHT
++{XtNrightScrollBar, XtCRightScrollBar, XtRBoolean, sizeof(Boolean),
++	XtOffsetOf(XtermWidgetRec, misc.useRight),
++	XtRBoolean, (XtPointer) &defaultFALSE},
++#endif
+ {XtNscrollTtyOutput,XtCScrollCond, XtRBoolean, sizeof(Boolean),
+ 	XtOffsetOf(XtermWidgetRec, screen.scrollttyoutput),
+ 	XtRBoolean, (XtPointer) &defaultTRUE},
+@@ -2539,8 +2550,7 @@
+ 					status = XtMakeResizeRequest (
+ 					    (Widget) termw, 
+ 					    (Dimension) FontWidth(screen) * j
+-					        + 2*screen->border
+-						+ screen->scrollbar,
++					        + 2*screen->border + Scrollbar(screen),
+ 					    (Dimension) FontHeight(screen)
+ 						* (screen->max_row + 1)
+ #ifdef STATUSLINE
+@@ -2780,8 +2790,7 @@
+ 					status = XtMakeResizeRequest (
+ 					    (Widget) termw,
+ 					    (Dimension) FontWidth(screen) * j 
+-						+ 2*screen->border
+-						+ screen->scrollbar,
++						+ 2*screen->border + Scrollbar(screen),
+ 					    (Dimension) FontHeight(screen)
+ 						* (screen->max_row + 1)
+ 						+ 2*screen->border,
+@@ -3033,7 +3042,7 @@
+ 			XClearArea(
+ 			    screen->display,
+ 			    TextWindow(screen),
+-			    (int) screen->border + screen->scrollbar,
++			    (int) OriginX(screen),
+ 			    (int) top * FontHeight(screen) + screen->border,
+ 			    (unsigned) Width(screen),
+ 			    (unsigned) (screen->max_row - top + 1)
+@@ -4147,7 +4156,7 @@
+ 			XtMakeResizeRequest(
+ 			    (Widget) term,
+ 			    (Dimension) 80*FontWidth(screen)
+-				+ 2 * screen->border + screen->scrollbar,
++				+ 2 * screen->border + Scrollbar(screen),
+ #ifdef STATUSLINE
+ 			    (Dimension) screen->statusheight +
+ #endif /* STATUSLINE */
+@@ -4207,8 +4216,7 @@
+ 	screen->statusheight = FontHeight(screen) + 2;
+ 	DoResizeScreen(term);
+ 	if (screen->scrollWidget)
+-		ResizeScrollBar(screen->scrollWidget, -1, -1,
+-		  Height(screen) + screen->border * 2 + screen->statusheight);
++		ResizeScrollBar(screen);
+ }
+ 
+ HideStatus()
+@@ -4259,7 +4267,7 @@
+ # endif /* !KTERM */
+ 	XFillRectangle(screen->display, TextWindow(screen),
+ 		screen->reversestatus ? screen->normalGC : screen->reverseGC,
+-		screen->border - 1 + screen->scrollbar,
++		screen->border - 1 + Scrollbar(screen),
+ 		Height(screen) + screen->border * 2 + 1,
+ 		Width(screen),
+ 		screen->statusheight - 2);
+@@ -4273,7 +4281,7 @@
+ # endif /* KTERM */
+ 	XDrawRectangle(screen->display, TextWindow(screen),
+ 		       screen->normalGC,
+-		       screen->scrollbar,
++		       ScrollbarX(screen),
+ 		       Height(screen) + screen->border * 2,
+ 		       Width(screen) + screen->border * 2 - 1,
+ 		       screen->statusheight - 1);
+--- input.c.org	Fri Jul 12 14:01:36 1996
++++ input.c	Sun Sep  9 05:03:27 2001
+@@ -37,7 +37,7 @@
+ 
+ static char *kypd_num = " XXXXXXXX\tXXX\rXXXxxxxXXXXXXXXXXXXXXXXXXXXX*+,-./0123456789XXX=";
+ static char *kypd_apl = " ABCDEFGHIJKLMNOPQRSTUVWXYZ??????abcdefghijklmnopqrstuvwxyzXXX";
+-static char *cur = "DACB";
++static char *cur = "HDACB  FE";
+ 
+ static int funcvalue(), sunfuncvalue();
+ extern Boolean sunFunctionKeys;
+@@ -129,10 +129,10 @@
+        		if (keyboard->flags & CURSOR_APL) {
+ 			reply.a_type = SS3;
+ 			unparseseq(&reply, pty);
+-			unparseputc(cur[keysym-XK_Left], pty);
++			unparseputc(cur[keysym-XK_Home], pty);
+ 		} else {
+ 			reply.a_type = CSI;
+-			reply.a_final = cur[keysym-XK_Left];
++			reply.a_final = cur[keysym-XK_Home];
+ 			unparseseq(&reply, pty);
+ 		}
+ 		key = TRUE;
+--- kinput2.c.org	Fri Jul 12 14:01:42 1996
++++ kinput2.c	Sun Sep  9 05:03:27 2001
+@@ -284,7 +284,7 @@
+     TScreen *screen = &term->screen;
+     static XRectangle area;
+ 
+-    area.x = screen->border + screen->scrollbar;
++    area.x = OriginX(screen);
+     area.y = screen->border;
+     area.width = Width(screen);
+     area.height = Height(screen);
+--- kterm.h.org	Fri Jul 12 14:01:37 1996
++++ kterm.h	Sun Sep  9 05:03:27 2001
+@@ -36,6 +36,6 @@
+ #define KTERM_KINPUT2	/* Kinput2 protocol */
+ #define KTERM_COLOR	/* color sequence */
+ #define KTERM_NOTEK	/* disables Tektronix emulation */
+-#undef  KTERM_XAW3D	/* Xaw3d -DARROW_SCROLLBAR support */
++#define KTERM_XAW3D	/* Xaw3d -DARROW_SCROLLBAR support */
+ 
+ #endif /* !_KTERM_H_ */
+--- main.c.org	Fri Jul 12 14:01:38 1996
++++ main.c	Sun Sep  9 05:03:27 2001
+@@ -745,6 +745,10 @@
+ {"+s",		"*multiScroll",	XrmoptionNoArg,		(caddr_t) "off"},
+ {"-sb",		"*scrollBar",	XrmoptionNoArg,		(caddr_t) "on"},
+ {"+sb",		"*scrollBar",	XrmoptionNoArg,		(caddr_t) "off"},
++#ifdef SCROLLBAR_RIGHT
++{"-leftbar",    "*rightScrollBar", XrmoptionNoArg,  (caddr_t) "off"},
++{"-rightbar",   "*rightScrollBar", XrmoptionNoArg,  (caddr_t) "on"},
++#endif
+ {"-sf",		"*sunFunctionKeys", XrmoptionNoArg,	(caddr_t) "on"},
+ {"+sf",		"*sunFunctionKeys", XrmoptionNoArg,	(caddr_t) "off"},
+ {"-si",		"*scrollTtyOutput",	XrmoptionNoArg,		(caddr_t) "off"},
+@@ -859,6 +863,10 @@
+ { "-/+rw",                 "turn on/off reverse wraparound" },
+ { "-/+s",                  "turn on/off multiscroll" },
+ { "-/+sb",                 "turn on/off scrollbar" },
++#ifdef SCROLLBAR_RIGHT
++{ "-rightbar",             "force scrollbar right (default left)" },
++{ "-leftbar",              "force scrollbar left" },
++#endif
+ { "-/+sf",                 "turn on/off Sun Function Key escape codes" },
+ { "-/+si",                 "turn on/off scroll-on-tty-output inhibit" },
+ { "-/+sk",                 "turn on/off scroll-on-keypress" },
+--- ptyx.h.org	Tue Jul  2 14:01:53 1996
++++ ptyx.h	Sun Sep  9 05:03:27 2001
+@@ -546,6 +546,9 @@
+     Boolean tekInhibit;
+ #endif /* !KTERM_NOTEK */
+     Boolean scrollbar;
++#ifdef SCROLLBAR_RIGHT
++	Boolean useRight;
++#endif
+     Boolean titeInhibit;
+ #ifndef KTERM_NOTEK
+     Boolean tekSmall;	/* start tek window in small size */
+@@ -708,8 +711,17 @@
+ #define TekScale(screen)	(screen->fullTwin.tekscale)
+ #endif /* !KTERM_NOTEK */
+ 
+-#define CursorX(screen,col) ((col) * FontWidth(screen) + screen->border \
+-			+ screen->scrollbar)
++#define Scrollbar(screen)	((screen)->scrollbar)
++
++#ifdef SCROLLBAR_RIGHT
++#define ScrollbarX(screen)	((term->misc.useRight)?0:Scrollbar(screen))
++#define OriginX(screen)	(ScrollbarX(screen) + screen->border)
++#else
++#define ScrollbarX(screen)	(Scrollbar(screen))
++#define OriginX(screen)	(Scrollbar(screen) + screen->border)
++#endif
++
++#define CursorX(screen,col) ((col) * FontWidth(screen) + OriginX(screen))
+ #ifdef STATUSLINE
+ #define CursorY(screen,row) ((row)>screen->max_row \
+ 	? (row) * FontHeight(screen) + screen->border * 2 + 1 \
+--- screen.c.org	Sun Jun 23 17:00:26 1996
++++ screen.c	Sun Sep  9 05:03:27 2001
+@@ -601,7 +601,7 @@
+ 		left = CursorX(screen, leftcol);
+ 		width = ncols * FontWidth(screen);
+ 		if (leftcol == 0) {
+-		    left = screen->scrollbar;
++		    left = ScrollbarX(screen);
+ 		    width += screen->border;
+ 		}
+ 		if (leftcol + ncols - 1 >= screen->max_col)
+@@ -869,7 +869,7 @@
+ 	rows = (height + FontHeight(screen) / 2 - border) /
+ #endif /* !STATUSLINE */
+ 	 FontHeight(screen);
+-	cols = (width + FontWidth(screen) / 2 - border - screen->scrollbar) /
++	cols = (width + FontWidth(screen) / 2 - border - Scrollbar(screen)) /
+ 	 FontWidth(screen);
+ 	if (rows < 1) rows = 1;
+ 	if (cols < 1) cols = 1;
+@@ -879,7 +879,7 @@
+ 		/* bit_gravity != ForgetGravity */
+ 		if (rows > screen->max_row + 1) {
+ 		    XClearArea (screen->display, tw, 
+-				screen->scrollbar,
++				ScrollbarX(screen),
+ 				(screen->max_row + 1) * FontHeight(screen) +
+ 				screen->border * 2,
+ 				(screen->max_col + 1) * FontHeight(screen) +
+@@ -888,7 +888,7 @@
+ 				True);
+ 		} else if (rows < screen->max_row + 1) {
+ 		    XClearArea (screen->display, tw, 
+-				screen->scrollbar,
++				ScrollbarX(screen),
+ 				rows * FontHeight(screen) +
+ 				screen->border * 2,
+ 				cols * FontWidth(screen) + screen->border * 2,
+@@ -964,13 +964,16 @@
+ #else /* !STATUSLINE */
+ 		screen->fullVwin.height = height - border;
+ #endif /* !STATUSLINE */
+-		screen->fullVwin.width = width - border - screen->scrollbar;
++		screen->fullVwin.width = width - border - Scrollbar(screen);
+ 
+ 	} else if(FullHeight(screen) == height && FullWidth(screen) == width)
+ 	 	return(0);	/* nothing has changed at all */
+ 
++	screen->fullVwin.fullheight = height;
++	screen->fullVwin.fullwidth = width;
++
+ 	if(screen->scrollWidget)
+-		ResizeScrollBar(screen->scrollWidget, -1, -1, height);
++		ResizeScrollBar(screen);
+ 	
+ 	screen->fullVwin.fullheight = height;
+ 	screen->fullVwin.fullwidth = width;
+--- scrollbar.c.org	Fri Jul 12 14:01:39 1996
++++ scrollbar.c	Sun Sep  9 05:06:08 2001
+@@ -205,13 +205,6 @@
+ 	return (scrollWidget);
+ }
+ 
+-static void RealizeScrollBar (sbw, screen)
+-    Widget sbw;
+-    TScreen *screen;
+-{
+-    XtRealizeWidget (sbw);
+-}
+-
+ 
+ ScrollBarReverseVideo(scrollWidget)
+ 	register Widget scrollWidget;
+@@ -255,14 +248,28 @@
+ 	
+ }
+ 
+-ResizeScrollBar(scrollWidget, x, y, height)
+-	register Widget scrollWidget;
+-	int x, y;
+-	unsigned height;
++void
++ResizeScrollBar(TScreen *screen)
+ {
+-	XtConfigureWidget(scrollWidget, x, y, scrollWidget->core.width,
+-	    height, scrollWidget->core.border_width);
+-	ScrollBarDrawThumb(scrollWidget);
++	XtConfigureWidget(
++		screen->scrollWidget,
++#ifdef SCROLLBAR_RIGHT
++			(term->misc.useRight)
++			? (screen->fullVwin.fullwidth -
++			   screen->scrollWidget->core.width -
++			   screen->scrollWidget->core.border_width)
++			: -1,
++#else
++		-1,
++#endif
++		-1,
++		screen->scrollWidget->core.width,
++#ifdef STATUSLINE
++		screen->statusheight +
++#endif /* STATUSLINE */
++		screen->fullVwin.height + screen->border * 2,
++		screen->scrollWidget->core.border_width);
++	ScrollBarDrawThumb(screen->scrollWidget);
+ }
+ 
+ WindowScroll(screen, top)
+@@ -297,7 +304,7 @@
+ 		scrolltop = lines;
+ 		refreshtop = scrollheight;
+ 	}
+-	x = screen->scrollbar +	screen->border;
++ 	x = OriginX(screen);
+ 	scrolling_copy_area(screen, scrolltop, scrollheight, -i);
+ 	screen->topline = top;
+ 
+@@ -385,17 +392,28 @@
+ #endif /* !KTERM */
+ 	}
+ 
+-	ResizeScrollBar (screen->scrollWidget, -1, -1, 
+-#ifdef STATUSLINE
+-			 screen->statusheight +
+-#endif /* STATUSLINE */
+-			 Height (screen) + border);
+-	RealizeScrollBar (screen->scrollWidget, screen);
++	ResizeScrollBar (screen);
++	XtRealizeWidget (screen->scrollWidget);
+ 	screen->scrollbar = screen->scrollWidget->core.width +
+ 	     screen->scrollWidget->core.border_width;
+ 
+ 	ScrollBarDrawThumb(screen->scrollWidget);
+ 	DoResizeScreen (xw);
++
++#ifdef SCROLLBAR_RIGHT
++	/*
++	 * Adjust the scrollbar position if we're asked to turn on scrollbars
++	 * for the first time after the xterm is already running.  That makes
++	 * the window grow after we've initially configured the scrollbar's
++	 * position.  (There must be a better way).
++	 */
++	if (term->misc.useRight
++	 && screen->fullVwin.fullwidth < term->core.width)
++		XtVaSetValues(screen->scrollWidget, XtNx,
++		screen->fullVwin.fullwidth - screen->scrollWidget->core.border_width,
++        NULL);
++#endif
++
+ 	XtMapWidget(screen->scrollWidget);
+ 	update_scrollbar ();
+ 	if (screen->buf) {
+--- util.c.org	Tue Jul  2 14:01:53 1996
++++ util.c	Sun Sep  9 05:07:49 2001
+@@ -116,7 +116,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -240,7 +240,7 @@
+ 		XClearArea (
+ 		   screen->display,
+ 		   TextWindow(screen),
+-		   (int) screen->border + screen->scrollbar,
++		   (int) OriginX(screen),
+ 		   (int) refreshtop * FontHeight(screen) + screen->border,
+ 		   (unsigned) Width(screen),
+ 		   (unsigned) refreshheight * FontHeight(screen),
+@@ -320,7 +320,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -381,7 +381,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -458,7 +458,7 @@
+ 		XClearArea (
+ 		    screen->display,
+ 		    TextWindow(screen),
+-		    (int) screen->border + screen->scrollbar,
++		    (int) OriginX(screen),
+ 		    (int) refreshtop * FontHeight(screen) + screen->border,
+ 		    (unsigned) Width(screen),
+ 		    (unsigned) refreshheight * FontHeight(screen),
+@@ -570,7 +570,7 @@
+ 		     screen->normalGC :
+ #endif /* STATUSLINE */
+ 		     screen->reverseGC,
+-		     screen->border + screen->scrollbar
++		     OriginX(screen)
+ 		       + Width(screen) - n*FontWidth(screen),
+ 		     CursorY (screen, screen->cur_row), n * FontWidth(screen),
+ 		     FontHeight(screen));
+@@ -599,8 +599,8 @@
+ 			height = screen->max_row;
+ 		if((height -= top) > 0)
+ 			XClearArea(screen->display, TextWindow(screen),
+-			 screen->border + screen->scrollbar, top *
+-			 FontHeight(screen) + screen->border,
++			 OriginX(screen),
++             top * FontHeight(screen) + screen->border,
+ 			 Width(screen), height * FontHeight(screen), FALSE);
+ 
+ 		if(screen->cur_row - screen->topline <= screen->max_row)
+@@ -623,8 +623,8 @@
+ 			FlushScroll(screen);
+ 		if(++top <= screen->max_row)
+ 			XClearArea(screen->display, TextWindow(screen),
+-			 screen->border + screen->scrollbar, top *
+-			 FontHeight(screen) + screen->border,
++			 OriginX(screen),
++             top * FontHeight(screen) + screen->border,
+ 			 Width(screen), (screen->max_row - top + 1) *
+ 			 FontHeight(screen), FALSE);
+ 	}
+@@ -713,7 +713,7 @@
+ 		     screen->normalGC :
+ #endif /* STATUSLINE */
+ 		     screen->reverseGC,
+-		     screen->border + screen->scrollbar,
++		     OriginX(screen),
+ 		      CursorY (screen, screen->cur_row),
+ 		     (screen->cur_col + 1) * FontWidth(screen),
+ 		     FontHeight(screen));
+@@ -764,7 +764,7 @@
+ 		     screen->normalGC :
+ #endif /* STATUSLINE */
+ 		     screen->reverseGC,
+-		     screen->border + screen->scrollbar,
++		     OriginX(screen),
+ 		      CursorY (screen, screen->cur_row),
+ 		     Width(screen), FontHeight(screen));
+ 	    }
+@@ -796,7 +796,7 @@
+ 			XClearWindow(screen->display, TextWindow(screen));
+ 		else
+ 			XClearArea(screen->display, TextWindow(screen),
+-			 screen->border + screen->scrollbar, 
++			 OriginX(screen),
+ 			 top * FontHeight(screen) + screen->border,	
+ 		 	 Width(screen), (screen->max_row - top + 1) *
+ 			 FontHeight(screen), FALSE);
+@@ -913,7 +913,7 @@
+     int amount;			/* number of lines to move up (neg=down) */
+ {
+     if(nlines > 0) {
+-	int src_x = screen->border + screen->scrollbar;
++ 	int src_x = OriginX(screen);
+ 	int src_y = firstline * FontHeight(screen) + screen->border;
+ 
+ 	copy_area(screen, src_x, src_y,
+@@ -1001,15 +1001,13 @@
+ 	if(toprow > screen->max_row + 1)
+ 		toprow = screen->max_row + 1;
+ #endif /* STATUSLINE */
+-	leftcol = (rect_x - screen->border - screen->scrollbar)
+-	    / FontWidth(screen);
++	leftcol = (rect_x - OriginX(screen)) / FontWidth(screen);
+ 	if(leftcol < 0)
+ 		leftcol = 0;
+ 	nrows = (rect_y + rect_height - 1 - screen->border) / 
+-		FontHeight(screen) - toprow + 1;
+-	ncols =
+-	 (rect_x + rect_width - 1 - screen->border - screen->scrollbar) /
+-			FontWidth(screen) - leftcol + 1;
++    	FontHeight(screen) - toprow + 1;
++	ncols = (rect_x + rect_width - 1 - OriginX(screen)) /
++		FontWidth(screen) - leftcol + 1;
+ 	toprow -= screen->scrolls;
+ 	if (toprow < 0) {
+ 		nrows += toprow;
+--- xim.c.org	Fri Jul 12 14:01:43 1996
++++ xim.c	Sun Sep  9 05:03:27 2001
+@@ -149,9 +149,9 @@
+ TScreen *screen;
+ XRectangle *rect_p;
+ {
+-	rect_p->x = screen->scrollbar;
++	rect_p->x = ScrollbarX(screen);
+ 	rect_p->y = 0;
+-	rect_p->width  = FullWidth(screen)  - screen->scrollbar;
++	rect_p->width  = FullWidth(screen)  - Scrollbar(screen);
+ 	rect_p->height = FullHeight(screen);
+ }
+ 
diff -u -r -N kterm.org/files/patch-rightbar.rej kterm/files/patch-rightbar.rej
--- kterm.org/files/patch-rightbar.rej	Thu Jan  1 09:00:00 1970
+++ kterm/files/patch-rightbar.rej	Sun Oct 21 17:15:06 2001
@@ -0,0 +1,17 @@
+***************
+*** 663,669 ****
+  
+     MISC_DEFINES =
+      XKB_DEFINES =
+-         DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE
+  
+          XIMSRCS = xim.c
+          XIMOBJS = xim.o
+--- 663,669 ----
+  
+     MISC_DEFINES =
+      XKB_DEFINES =
++         DEFINES = $(XKB_DEFINES) $(XPOLL_DEF) -DKTERM -DSTATUSLINE -DKEEPALIVE -DSCROLLBAR_RIGHT
+  
+          XIMSRCS = xim.c
+          XIMOBJS = xim.o
>Release-Note:
>Audit-Trail:
>Unformatted: