changeset 1784:11f62e53acff

Make scrollbar structures into lisp objects, so that they can be GC'd; this allows windows and scrollbars can refer to each other without worrying about dangling pointers. * xterm.h (struct x_display): vertical_scrollbars and judge_timestamp members deleted. (struct scrollbar): Redesigned to be a template for a Lisp_Vector. (SCROLLBAR_VEC_SIZE, XSCROLLBAR, SCROLLBAR_PACK, SCROLLBAR_UNPACK, SCROLLBAR_X_WINDOW, SET_SCROLLBAR_X_WINDOW, VERTICAL_SCROLLBAR_INSIDE_WIDTH, VERTICAL_SCROLLBAR_TOP_RANGE, VERTICAL_SCROLLBAR_INSIDE_HEIGHT, VERTICAL_SCROLLBAR_MIN_HANDLE): New macros, to help deal with the lispy structures, and deal with the graphics. * frame.h (WINDOW_VERTICAL_SCROLLBAR): Macro deleted. (struct frame): New fields `scrollbars' and `condemned_scrollbars', for use by the scrollbar implementation. [MULTI_FRAME and not MULTI_FRAME] (FRAME_SCROLLBARS, FRAME_CONDEMNED_SCROLLBARS): Accessors for the new field. * window.h (struct window): Doc fix for vertical_scrollbar field. * frame.c (make_frame): Initialize the `scrollbars' and `condemned_scrollbars' fields of the new frame. * alloc.c (mark_object): Mark the `scrollbars' and `condemned_scrollbars' slots of frames. * xterm.c (x_window_to_scrollbar): Scrollbars are chained on frames' scrollbar field, not their x.display->vertical_scrollbars field. (x_scrollbar_create, x_scrollbar_set_handle, x_scrollbar_move, x_scrollbar_remove, XTset_vertical_scrollbar, XTcondemn_scrollbars, XTredeem_scrollbar, XTjudge_scrollbars, x_scrollbar_expose, x_scrollbar_handle_click, x_scrollbar_handle_motion): Substantially rewritten to correct typos and brainos, and to accomodate the lispy structures.
author Jim Blandy <jimb@redhat.com>
date Thu, 14 Jan 1993 15:17:39 +0000
parents 8e7932110418
children 19755499df90
files src/alloc.c src/frame.c src/window.h
diffstat 3 files changed, 13 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/src/alloc.c	Thu Jan 14 15:17:11 1993 +0000
+++ b/src/alloc.c	Thu Jan 14 15:17:39 1993 +0000
@@ -1,11 +1,11 @@
 /* Storage allocation and gc for GNU Emacs Lisp interpreter.
-   Copyright (C) 1985, 1986, 1988, 1992 Free Software Foundation, Inc.
+   Copyright (C) 1985, 1986, 1988, 1992, 1993 Free Software Foundation, Inc.
 
 This file is part of GNU Emacs.
 
 GNU Emacs is free software; you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 1, or (at your option)
+the Free Software Foundation; either version 2, or (at your option)
 any later version.
 
 GNU Emacs is distributed in the hope that it will be useful,
@@ -1497,6 +1497,8 @@
 	mark_object (&ptr->selected_window);
 	mark_object (&ptr->minibuffer_window);
 	mark_object (&ptr->param_alist);
+	mark_object (&ptr->scrollbars);
+	mark_object (&ptr->condemned_scrollbars);
       }
       break;
 #endif /* not MULTI_FRAME */
--- a/src/frame.c	Thu Jan 14 15:17:11 1993 +0000
+++ b/src/frame.c	Thu Jan 14 15:17:39 1993 +0000
@@ -1,5 +1,5 @@
 /* Generic frame functions.
-   Copyright (C) 1989, 1992 Free Software Foundation.
+   Copyright (C) 1989, 1992, 1993 Free Software Foundation.
 
 This file is part of GNU Emacs.
 
@@ -160,8 +160,9 @@
   f->explicit_name = 0;
   f->can_have_scrollbars = 0;
   f->has_vertical_scrollbars = 0;
-
   f->param_alist = Qnil;
+  f->scrollbars = Qnil;
+  f->condemned_scrollbars = Qnil;
 
   root_window = make_window ();
   if (mini_p)
--- a/src/window.h	Thu Jan 14 15:17:11 1993 +0000
+++ b/src/window.h	Thu Jan 14 15:17:39 1993 +0000
@@ -1,5 +1,5 @@
 /* Window definitions for GNU Emacs.
-   Copyright (C) 1985, 1986, 1992 Free Software Foundation, Inc.
+   Copyright (C) 1985, 1986, 1992, 1993 Free Software Foundation, Inc.
 
 This file is part of GNU Emacs.
 
@@ -123,10 +123,11 @@
     Lisp_Object last_modified;
     /* Value of point at that time */
     Lisp_Object last_point;
-    /* Pointer to this window's vertical scrollbar, tagged as an
-       integer.  If this window is newly created and we haven't
-       displayed a scrollbar in it yet, or if the frame doesn't have
-       any scrollbars, this is nil.  */
+    /* This window's vertical scrollbar.  This field is only for use
+       by the window-system-dependent code which implements the
+       scrollbars; it can store anything it likes here.  If this
+       window is newly created and we haven't displayed a scrollbar in
+       it yet, or if the frame doesn't have any scrollbars, this is nil.  */
     Lisp_Object vertical_scrollbar;
 
 /* The rest are currently not used or only half used */