annotate src/opaque.c @ 424:11054d720c21 r21-2-20

Import from CVS: tag r21-2-20
author cvs
date Mon, 13 Aug 2007 11:26:11 +0200
parents 41dbb7a9d5f2
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 /* Opaque Lisp objects.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2 Copyright (C) 1993, 1994, 1995 Sun Microsystems, Inc.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 Copyright (C) 1995, 1996 Ben Wing.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 This file is part of XEmacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7 XEmacs is free software; you can redistribute it and/or modify it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
9 Free Software Foundation; either version 2, or (at your option) any
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10 later version.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
12 XEmacs is distributed in the hope that it will be useful, but WITHOUT
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 for more details.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 along with XEmacs; see the file COPYING. If not, write to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 Boston, MA 02111-1307, USA. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22 /* Synched up with: Not in FSF. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24 /* Written by Ben Wing, October 1993. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26 /* "Opaque" is used internally to hold keep track of allocated memory
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27 so it gets GC'd properly, and to store arbitrary data in places
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28 where a Lisp_Object is required and which may get GC'd. (e.g. as
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29 the argument to record_unwind_protect()). Once created in C,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 opaque objects cannot be resized.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32 OPAQUE OBJECTS SHOULD NEVER ESCAPE TO THE LISP LEVEL. Some code
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33 depends on this. As such, opaque objects are a generalization
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34 of the Qunbound marker.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
35 */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37 #include <config.h>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 #include "lisp.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39 #include "opaque.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 Lisp_Object Vopaque_ptr_free_list;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43 /* Should never, ever be called. (except by an external debugger) */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
44 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45 print_opaque (Lisp_Object obj, Lisp_Object printcharfun, int escapeflag)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 404
diff changeset
47 CONST Lisp_Opaque *p = XOPAQUE (obj);
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48 char buf[200];
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
49
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
50 sprintf (buf, "#<INTERNAL OBJECT (XEmacs bug?) (opaque, size=%lu) 0x%lx>",
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
51 (long)(p->size), (unsigned long) p);
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 write_c_string (buf, printcharfun);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54
272
c5d627a313b1 Import from CVS: tag r21-0b34
cvs
parents: 267
diff changeset
55 static size_t
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 404
diff changeset
56 sizeof_opaque (CONST void *header)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 404
diff changeset
58 CONST Lisp_Opaque *p = (CONST Lisp_Opaque *) header;
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
59 return offsetof (Lisp_Opaque, data) + p->size;
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
62 /* Return an opaque object of size SIZE.
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
63 If DATA is OPAQUE_CLEAR, the object's data is memset to '\0' bytes.
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
64 If DATA is OPAQUE_UNINIT, the object's data is uninitialized.
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
65 Else the object's data is initialized by copying from DATA. */
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 Lisp_Object
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 404
diff changeset
67 make_opaque (size_t size, CONST void *data)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 {
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
69 Lisp_Opaque *p = (Lisp_Opaque *)
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 396
diff changeset
70 alloc_lcrecord (offsetof (Lisp_Opaque, data) + size, &lrecord_opaque);
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
71 p->size = size;
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
72
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
73 if (data == OPAQUE_CLEAR)
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
74 memset (p->data, '\0', size);
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
75 else if (data == OPAQUE_UNINIT)
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
76 DO_NOTHING;
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 else
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
78 memcpy (p->data, data, size);
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
79
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
80 {
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
81 Lisp_Object val;
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
82 XSETOPAQUE (val, p);
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
83 return val;
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
84 }
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86
231
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
87 /* This will not work correctly for opaques with subobjects! */
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
88
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
89 static int
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
90 equal_opaque (Lisp_Object obj1, Lisp_Object obj2, int depth)
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
91 {
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
92 size_t size;
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
93 return ((size = XOPAQUE_SIZE (obj1)) == XOPAQUE_SIZE (obj2) &&
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
94 !memcmp (XOPAQUE_DATA (obj1), XOPAQUE_DATA (obj2), size));
231
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
95 }
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
96
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
97 /* This will not work correctly for opaques with subobjects! */
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
98
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
99 static unsigned long
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
100 hash_opaque (Lisp_Object obj, int depth)
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
101 {
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
102 if (XOPAQUE_SIZE (obj) == sizeof (unsigned long))
396
6719134a07c2 Import from CVS: tag r21-2-13
cvs
parents: 380
diff changeset
103 return *((unsigned long *) XOPAQUE_DATA (obj));
231
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
104 else
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
105 return memory_hash (XOPAQUE_DATA (obj), XOPAQUE_SIZE (obj));
231
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
106 }
557eaa0339bf Import from CVS: tag r20-5b14
cvs
parents: 185
diff changeset
107
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
108 static const struct lrecord_description opaque_description[] = {
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
109 { XD_END }
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
110 };
272
c5d627a313b1 Import from CVS: tag r21-0b34
cvs
parents: 267
diff changeset
111
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
112 DEFINE_LRECORD_SEQUENCE_IMPLEMENTATION ("opaque", opaque,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
113 0, print_opaque, 0,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
114 equal_opaque, hash_opaque,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
115 opaque_description,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
116 sizeof_opaque, Lisp_Opaque);
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 /* stuff to handle opaque pointers */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
120 /* Should never, ever be called. (except by an external debugger) */
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
121 static void
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
122 print_opaque_ptr (Lisp_Object obj, Lisp_Object printcharfun, int escapeflag)
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
123 {
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
124 CONST Lisp_Opaque_Ptr *p = XOPAQUE_PTR (obj);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
125 char buf[200];
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
126
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
127 sprintf (buf, "#<INTERNAL OBJECT (XEmacs bug?) (opaque_ptr, adr=0x%lx) 0x%lx>",
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
128 (long)(p->ptr), (unsigned long) p);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
129 write_c_string (buf, printcharfun);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
130 }
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
131
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
132 static int
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
133 equal_opaque_ptr (Lisp_Object obj1, Lisp_Object obj2, int depth)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 {
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
135 return (XOPAQUE_PTR (obj1)->ptr == XOPAQUE_PTR (obj2)->ptr);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
136 }
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
137
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
138 static unsigned long
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
139 hash_opaque_ptr (Lisp_Object obj, int depth)
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
140 {
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
141 return (unsigned long) XOPAQUE_PTR (obj)->ptr;
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
142 }
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
143
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
144 DEFINE_LRECORD_IMPLEMENTATION ("opaque_ptr", opaque_ptr,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
145 0, print_opaque_ptr, 0,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
146 equal_opaque_ptr, hash_opaque_ptr, 0,
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
147 Lisp_Opaque_Ptr);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
148
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
149 Lisp_Object
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
150 make_opaque_ptr (void *val)
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
151 {
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
152 Lisp_Object res = allocate_managed_lcrecord(Vopaque_ptr_free_list);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
153 set_opaque_ptr (res, val);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
154 return res;
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156
380
8626e4521993 Import from CVS: tag r21-2-5
cvs
parents: 371
diff changeset
157 /* Be very very careful with this. Same admonitions as with
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158 free_cons() apply. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 free_opaque_ptr (Lisp_Object ptr)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 {
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
163 free_managed_lcrecord (Vopaque_ptr_free_list, ptr);
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
164 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
165
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
166 void
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
167 reinit_opaque_once_early (void)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 {
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
169 Vopaque_ptr_free_list = make_lcrecord_list (sizeof (Lisp_Opaque_Ptr), &lrecord_opaque_ptr);
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
170 staticpro_nodump (&Vopaque_ptr_free_list);
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
171 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
172
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 init_opaque_once_early (void)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175 {
424
11054d720c21 Import from CVS: tag r21-2-20
cvs
parents: 420
diff changeset
176 reinit_opaque_once_early ();
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 }