source: branches/1.0.x/abcl/src/org/armedbear/lisp/BuiltInClass.java

Last change on this file was 13445, checked in by ehuelsmann, 14 years ago

Print unreadable strings with unreadableString() exclusively,
so it can throw a Lisp error when printing something unreadable.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 16.9 KB
Line 
1/*
2 * BuiltInClass.java
3 *
4 * Copyright (C) 2003-2007 Peter Graves
5 * $Id: BuiltInClass.java 13445 2011-08-06 14:46:28Z ehuelsmann $
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
20 *
21 * As a special exception, the copyright holders of this library give you
22 * permission to link this library with independent modules to produce an
23 * executable, regardless of the license terms of these independent
24 * modules, and to copy and distribute the resulting executable under
25 * terms of your choice, provided that you also meet, for each linked
26 * independent module, the terms and conditions of the license of that
27 * module.  An independent module is a module which is not derived from
28 * or based on this library.  If you modify this library, you may extend
29 * this exception to your version of the library, but you are not
30 * obligated to do so.  If you do not wish to do so, delete this
31 * exception statement from your version.
32 */
33
34package org.armedbear.lisp;
35
36import static org.armedbear.lisp.Lisp.*;
37
38public class BuiltInClass extends LispClass
39{
40  private BuiltInClass(Symbol symbol)
41  {
42    super(symbol);
43  }
44
45  @Override
46  public LispObject typeOf()
47  {
48    return Symbol.BUILT_IN_CLASS;
49  }
50
51  @Override
52  public LispObject classOf()
53  {
54    return StandardClass.BUILT_IN_CLASS;
55  }
56
57  @Override
58  public boolean isFinalized()
59  {
60    return true;
61  }
62
63  @Override
64  public LispObject typep(LispObject type)
65  {
66    if (type == Symbol.BUILT_IN_CLASS)
67      return T;
68    if (type == StandardClass.BUILT_IN_CLASS)
69      return T;
70    return super.typep(type);
71  }
72
73  @Override
74  public LispObject getDescription()
75  {
76    return new SimpleString(princToString());
77  }
78
79  @Override
80  public String printObject()
81  {
82    return unreadableString(getName().princToString());
83  }
84
85  private static BuiltInClass addClass(Symbol symbol)
86  {
87    BuiltInClass c = new BuiltInClass(symbol);
88    addClass(symbol, c);
89    return c;
90  }
91
92  public static final BuiltInClass CLASS_T              = addClass(T);
93
94  public static final BuiltInClass ARRAY                = addClass(Symbol.ARRAY);
95  public static final BuiltInClass BIGNUM               = addClass(Symbol.BIGNUM);
96  public static final BuiltInClass BASE_STRING          = addClass(Symbol.BASE_STRING);
97  public static final BuiltInClass BIT_VECTOR           = addClass(Symbol.BIT_VECTOR);
98  public static final BuiltInClass CHARACTER            = addClass(Symbol.CHARACTER);
99  public static final BuiltInClass COMPLEX              = addClass(Symbol.COMPLEX);
100  public static final BuiltInClass CONS                 = addClass(Symbol.CONS);
101  public static final BuiltInClass DOUBLE_FLOAT         = addClass(Symbol.DOUBLE_FLOAT);
102  public static final BuiltInClass ENVIRONMENT          = addClass(Symbol.ENVIRONMENT);
103  public static final BuiltInClass FIXNUM               = addClass(Symbol.FIXNUM);
104  public static final BuiltInClass FLOAT                = addClass(Symbol.FLOAT);
105  public static final BuiltInClass FUNCTION             = addClass(Symbol.FUNCTION);
106  public static final BuiltInClass HASH_TABLE           = addClass(Symbol.HASH_TABLE);
107  public static final BuiltInClass INTEGER              = addClass(Symbol.INTEGER);
108  public static final BuiltInClass JAVA_OBJECT          = addClass(Symbol.JAVA_OBJECT);
109  public static final BuiltInClass LIST                 = addClass(Symbol.LIST);
110  public static final BuiltInClass LOGICAL_PATHNAME     = addClass(Symbol.LOGICAL_PATHNAME);
111  public static final BuiltInClass MAILBOX              = addClass(Symbol.MAILBOX);
112  public static final BuiltInClass METHOD_COMBINATION   = addClass(Symbol.METHOD_COMBINATION);
113  public static final BuiltInClass MUTEX                = addClass(Symbol.MUTEX);
114  public static final BuiltInClass NIL_VECTOR           = addClass(Symbol.NIL_VECTOR);
115  public static final BuiltInClass NULL                 = addClass(Symbol.NULL);
116  public static final BuiltInClass NUMBER               = addClass(Symbol.NUMBER);
117  public static final BuiltInClass PACKAGE              = addClass(Symbol.PACKAGE);
118  public static final BuiltInClass PATHNAME             = addClass(Symbol.PATHNAME);
119  public static final BuiltInClass JAR_PATHNAME         = addClass(Symbol.JAR_PATHNAME);
120  public static final BuiltInClass URL_PATHNAME         = addClass(Symbol.URL_PATHNAME);
121  public static final BuiltInClass RANDOM_STATE         = addClass(Symbol.RANDOM_STATE);
122  public static final BuiltInClass RATIO                = addClass(Symbol.RATIO);
123  public static final BuiltInClass RATIONAL             = addClass(Symbol.RATIONAL);
124  public static final BuiltInClass READTABLE            = addClass(Symbol.READTABLE);
125  public static final BuiltInClass REAL                 = addClass(Symbol.REAL);
126  public static final BuiltInClass RESTART              = addClass(Symbol.RESTART);
127  public static final BuiltInClass SEQUENCE             = addClass(Symbol.SEQUENCE); 
128  public static final BuiltInClass SIMPLE_ARRAY         = addClass(Symbol.SIMPLE_ARRAY);
129  public static final BuiltInClass SIMPLE_BASE_STRING   = addClass(Symbol.SIMPLE_BASE_STRING);
130  public static final BuiltInClass SIMPLE_BIT_VECTOR    = addClass(Symbol.SIMPLE_BIT_VECTOR);
131  public static final BuiltInClass SIMPLE_STRING        = addClass(Symbol.SIMPLE_STRING);
132  public static final BuiltInClass SIMPLE_VECTOR        = addClass(Symbol.SIMPLE_VECTOR);
133  public static final BuiltInClass SINGLE_FLOAT         = addClass(Symbol.SINGLE_FLOAT);
134  public static final BuiltInClass STRING               = addClass(Symbol.STRING);
135  public static final BuiltInClass SYMBOL               = addClass(Symbol.SYMBOL);
136  public static final BuiltInClass THREAD               = addClass(Symbol.THREAD);
137  public static final BuiltInClass VECTOR               = addClass(Symbol.VECTOR);
138  public static final BuiltInClass STACK_FRAME          = addClass(Symbol.STACK_FRAME);
139  public static final BuiltInClass LISP_STACK_FRAME     = addClass(Symbol.LISP_STACK_FRAME);
140  public static final BuiltInClass JAVA_STACK_FRAME     = addClass(Symbol.JAVA_STACK_FRAME);
141  public static final BuiltInClass WEAK_REFERENCE      = addClass(Symbol.WEAK_REFERENCE);
142
143
144  public static final StructureClass STRUCTURE_OBJECT =
145    (StructureClass)addClass(Symbol.STRUCTURE_OBJECT,
146             new StructureClass(Symbol.STRUCTURE_OBJECT, list(CLASS_T)));
147
148    /* All the stream classes below are being defined as structure classes
149       but won't be available as such until further action is taken:
150       the 'defstruct' internal administration is missing.
151
152       For STREAM and SYSTEM-STREAM, that bit is added in boot.lisp */
153
154  public static final LispClass STREAM =
155    addClass(Symbol.STREAM,
156             new StructureClass(Symbol.STREAM, list(STRUCTURE_OBJECT)));
157  public static final LispClass SYSTEM_STREAM =
158    addClass(Symbol.SYSTEM_STREAM,
159             new StructureClass(Symbol.SYSTEM_STREAM, list(STREAM)));
160  public static final LispClass TWO_WAY_STREAM =
161    addClass(Symbol.TWO_WAY_STREAM,
162             new StructureClass(Symbol.TWO_WAY_STREAM, list(SYSTEM_STREAM)));
163  public static final LispClass BROADCAST_STREAM =
164    addClass(Symbol.BROADCAST_STREAM,
165             new StructureClass(Symbol.BROADCAST_STREAM, list(SYSTEM_STREAM)));
166  public static final LispClass ECHO_STREAM =
167    addClass(Symbol.ECHO_STREAM,
168             new StructureClass(Symbol.ECHO_STREAM, list(SYSTEM_STREAM)));
169  public static final LispClass CASE_FROB_STREAM =
170    addClass(Symbol.CASE_FROB_STREAM,
171             new StructureClass(Symbol.CASE_FROB_STREAM, list(SYSTEM_STREAM)));
172  public static final LispClass STRING_STREAM =
173    addClass(Symbol.STRING_STREAM,
174             new StructureClass(Symbol.STRING_STREAM, list(SYSTEM_STREAM)));
175  public static final LispClass STRING_INPUT_STREAM =
176    addClass(Symbol.STRING_INPUT_STREAM,
177             new StructureClass(Symbol.STRING_INPUT_STREAM, list(STRING_STREAM)));
178  public static final LispClass STRING_OUTPUT_STREAM =
179    addClass(Symbol.STRING_OUTPUT_STREAM,
180             new StructureClass(Symbol.STRING_OUTPUT_STREAM, list(STRING_STREAM)));
181  public static final LispClass SYNONYM_STREAM =
182    addClass(Symbol.SYNONYM_STREAM,
183             new StructureClass(Symbol.SYNONYM_STREAM, list(SYSTEM_STREAM)));
184  public static final LispClass FILE_STREAM =
185    addClass(Symbol.FILE_STREAM,
186             new StructureClass(Symbol.FILE_STREAM, list(SYSTEM_STREAM)));
187  public static final LispClass JAR_STREAM =
188    addClass(Symbol.JAR_STREAM,
189             new StructureClass(Symbol.JAR_STREAM, list(SYSTEM_STREAM)));
190  public static final LispClass URL_STREAM =
191    addClass(Symbol.URL_STREAM,
192             new StructureClass(Symbol.URL_STREAM, list(SYSTEM_STREAM)));
193  public static final LispClass CONCATENATED_STREAM =
194    addClass(Symbol.CONCATENATED_STREAM,
195             new StructureClass(Symbol.CONCATENATED_STREAM, list(SYSTEM_STREAM)));
196
197
198
199    // Implementation defined streams
200  public static final LispClass SOCKET_STREAM =
201    addClass(Symbol.SOCKET_STREAM,
202             new StructureClass(Symbol.SOCKET_STREAM, list(TWO_WAY_STREAM)));
203  public static final LispClass SLIME_INPUT_STREAM =
204    addClass(Symbol.SLIME_INPUT_STREAM,
205             new StructureClass(Symbol.SLIME_INPUT_STREAM, list(STRING_STREAM)));
206  public static final LispClass SLIME_OUTPUT_STREAM =
207    addClass(Symbol.SLIME_OUTPUT_STREAM,
208             new StructureClass(Symbol.SLIME_OUTPUT_STREAM, list(STRING_STREAM)));
209
210
211
212  static
213  {
214    ARRAY.setDirectSuperclass(CLASS_T);
215    ARRAY.setCPL(ARRAY, CLASS_T);
216    BASE_STRING.setDirectSuperclass(STRING);
217    BASE_STRING.setCPL(BASE_STRING, STRING, VECTOR, ARRAY, SEQUENCE, CLASS_T);
218    BIGNUM.setDirectSuperclass(INTEGER);
219    BIGNUM.setCPL(BIGNUM, INTEGER, RATIONAL, REAL, NUMBER, CLASS_T);
220    BIT_VECTOR.setDirectSuperclass(VECTOR);
221    BIT_VECTOR.setCPL(BIT_VECTOR, VECTOR, ARRAY, SEQUENCE, CLASS_T);
222    BROADCAST_STREAM.setCPL(BROADCAST_STREAM, SYSTEM_STREAM, STREAM,
223                            STRUCTURE_OBJECT, CLASS_T);
224    CASE_FROB_STREAM.setCPL(CASE_FROB_STREAM, SYSTEM_STREAM, STREAM,
225                            STRUCTURE_OBJECT, CLASS_T);
226    CHARACTER.setDirectSuperclass(CLASS_T);
227    CHARACTER.setCPL(CHARACTER, CLASS_T);
228    CLASS_T.setCPL(CLASS_T);
229    COMPLEX.setDirectSuperclass(NUMBER);
230    COMPLEX.setCPL(COMPLEX, NUMBER, CLASS_T);
231    CONCATENATED_STREAM.setCPL(CONCATENATED_STREAM, SYSTEM_STREAM, STREAM,
232                               STRUCTURE_OBJECT, CLASS_T);
233    CONS.setDirectSuperclass(LIST);
234    CONS.setCPL(CONS, LIST, SEQUENCE, CLASS_T);
235    DOUBLE_FLOAT.setDirectSuperclass(FLOAT);
236    DOUBLE_FLOAT.setCPL(DOUBLE_FLOAT, FLOAT, REAL, NUMBER, CLASS_T);
237    ECHO_STREAM.setCPL(ECHO_STREAM, SYSTEM_STREAM, STREAM,
238                       STRUCTURE_OBJECT, CLASS_T);
239    ENVIRONMENT.setDirectSuperclass(CLASS_T);
240    ENVIRONMENT.setCPL(ENVIRONMENT, CLASS_T);
241    FIXNUM.setDirectSuperclass(INTEGER);
242    FIXNUM.setCPL(FIXNUM, INTEGER, RATIONAL, REAL, NUMBER, CLASS_T);
243    FILE_STREAM.setCPL(FILE_STREAM, SYSTEM_STREAM, STREAM,
244                       STRUCTURE_OBJECT, CLASS_T);
245    JAR_STREAM.setCPL(JAR_STREAM, SYSTEM_STREAM, STREAM,
246                      STRUCTURE_OBJECT, CLASS_T);
247    URL_STREAM.setCPL(URL_STREAM, SYSTEM_STREAM, STREAM,
248                      STRUCTURE_OBJECT, CLASS_T);
249    FLOAT.setDirectSuperclass(REAL);
250    FLOAT.setCPL(FLOAT, REAL, NUMBER, CLASS_T);
251    FUNCTION.setDirectSuperclass(CLASS_T);
252    FUNCTION.setCPL(FUNCTION, CLASS_T);
253    HASH_TABLE.setDirectSuperclass(CLASS_T);
254    HASH_TABLE.setCPL(HASH_TABLE, CLASS_T);
255    INTEGER.setDirectSuperclass(RATIONAL);
256    INTEGER.setCPL(INTEGER, RATIONAL, REAL, NUMBER, CLASS_T);
257    JAVA_OBJECT.setDirectSuperclass(CLASS_T);
258    JAVA_OBJECT.setCPL(JAVA_OBJECT, CLASS_T);
259    LIST.setDirectSuperclass(SEQUENCE);
260    LIST.setCPL(LIST, SEQUENCE, CLASS_T);
261    LOGICAL_PATHNAME.setDirectSuperclass(PATHNAME);
262    LOGICAL_PATHNAME.setCPL(LOGICAL_PATHNAME, PATHNAME, CLASS_T);
263    MAILBOX.setDirectSuperclass(CLASS_T);
264    MAILBOX.setCPL(MAILBOX, CLASS_T);
265    METHOD_COMBINATION.setDirectSuperclass(CLASS_T);
266    METHOD_COMBINATION.setCPL(METHOD_COMBINATION, CLASS_T);
267    MUTEX.setDirectSuperclass(CLASS_T);
268    MUTEX.setCPL(MUTEX, CLASS_T);
269    NIL_VECTOR.setDirectSuperclass(STRING);
270    NIL_VECTOR.setCPL(NIL_VECTOR, STRING, VECTOR, ARRAY, SEQUENCE, CLASS_T);
271    NULL.setDirectSuperclass(LIST);
272    NULL.setCPL(NULL, SYMBOL, LIST, SEQUENCE, CLASS_T);
273    NUMBER.setDirectSuperclass(CLASS_T);
274    NUMBER.setCPL(NUMBER, CLASS_T);
275    PACKAGE.setDirectSuperclass(CLASS_T);
276    PACKAGE.setCPL(PACKAGE, CLASS_T);
277    PATHNAME.setDirectSuperclass(CLASS_T);
278    PATHNAME.setCPL(PATHNAME, CLASS_T);
279    JAR_PATHNAME.setDirectSuperclass(PATHNAME);
280    JAR_PATHNAME.setCPL(JAR_PATHNAME, PATHNAME, CLASS_T);
281    URL_PATHNAME.setDirectSuperclass(PATHNAME);
282    URL_PATHNAME.setCPL(URL_PATHNAME, PATHNAME, CLASS_T);
283    RANDOM_STATE.setDirectSuperclass(CLASS_T);
284    RANDOM_STATE.setCPL(RANDOM_STATE, CLASS_T);
285    RATIO.setDirectSuperclass(RATIONAL);
286    RATIO.setCPL(RATIO, RATIONAL, REAL, NUMBER, CLASS_T);
287    RATIONAL.setDirectSuperclass(REAL);
288    RATIONAL.setCPL(RATIONAL, REAL, NUMBER, CLASS_T);
289    READTABLE.setDirectSuperclass(CLASS_T);
290    READTABLE.setCPL(READTABLE, CLASS_T);
291    REAL.setDirectSuperclass(NUMBER);
292    REAL.setCPL(REAL, NUMBER, CLASS_T);
293    RESTART.setDirectSuperclass(CLASS_T);
294    RESTART.setCPL(RESTART, CLASS_T);
295    SEQUENCE.setDirectSuperclass(CLASS_T);
296    SEQUENCE.setCPL(SEQUENCE, CLASS_T);
297    SIMPLE_ARRAY.setDirectSuperclass(ARRAY);
298    SIMPLE_ARRAY.setCPL(SIMPLE_ARRAY, ARRAY, CLASS_T);
299    SIMPLE_BASE_STRING.setDirectSuperclasses(list(BASE_STRING, SIMPLE_STRING));
300    SIMPLE_BASE_STRING.setCPL(SIMPLE_BASE_STRING, BASE_STRING, SIMPLE_STRING,
301                              STRING, VECTOR, SIMPLE_ARRAY, ARRAY, SEQUENCE,
302                              CLASS_T);
303    SIMPLE_BIT_VECTOR.setDirectSuperclasses(list(BIT_VECTOR, SIMPLE_ARRAY));
304    SIMPLE_BIT_VECTOR.setCPL(SIMPLE_BIT_VECTOR, BIT_VECTOR, VECTOR,
305                             SIMPLE_ARRAY, ARRAY, SEQUENCE, CLASS_T);
306    SIMPLE_STRING.setDirectSuperclasses(list(BASE_STRING, STRING, SIMPLE_ARRAY));
307    SIMPLE_STRING.setCPL(SIMPLE_STRING, BASE_STRING, STRING, VECTOR,
308                         SIMPLE_ARRAY, ARRAY, SEQUENCE, CLASS_T);
309    SIMPLE_VECTOR.setDirectSuperclasses(list(VECTOR, SIMPLE_ARRAY));
310    SIMPLE_VECTOR.setCPL(SIMPLE_VECTOR, VECTOR, SIMPLE_ARRAY, ARRAY, SEQUENCE,
311                         CLASS_T);
312    SINGLE_FLOAT.setDirectSuperclass(FLOAT);
313    SINGLE_FLOAT.setCPL(SINGLE_FLOAT, FLOAT, REAL, NUMBER, CLASS_T);
314    SLIME_INPUT_STREAM.setCPL(SLIME_INPUT_STREAM, STRING_STREAM, SYSTEM_STREAM,
315                              STREAM, STRUCTURE_OBJECT, CLASS_T);
316    SLIME_OUTPUT_STREAM.setCPL(SLIME_OUTPUT_STREAM, STRING_STREAM, SYSTEM_STREAM,
317                               STREAM, STRUCTURE_OBJECT, CLASS_T);
318    SOCKET_STREAM.setCPL(SOCKET_STREAM, TWO_WAY_STREAM, SYSTEM_STREAM, STREAM,
319                         STRUCTURE_OBJECT, CLASS_T);
320    STREAM.setCPL(STREAM, STRUCTURE_OBJECT, CLASS_T);
321    STRING.setDirectSuperclass(VECTOR);
322    STRING.setCPL(STRING, VECTOR, ARRAY, SEQUENCE, CLASS_T);
323    STRING_INPUT_STREAM.setCPL(STRING_INPUT_STREAM, STRING_STREAM,
324                               SYSTEM_STREAM, STREAM, STRUCTURE_OBJECT, CLASS_T);
325    STRING_OUTPUT_STREAM.setCPL(STRING_OUTPUT_STREAM, STRING_STREAM,
326                                SYSTEM_STREAM, STREAM, STRUCTURE_OBJECT, CLASS_T);
327    STRING_STREAM.setCPL(STRING_STREAM, SYSTEM_STREAM, STREAM,
328                         STRUCTURE_OBJECT, CLASS_T);
329    STRUCTURE_OBJECT.setCPL(STRUCTURE_OBJECT, CLASS_T);
330    SYMBOL.setDirectSuperclass(CLASS_T);
331    SYMBOL.setCPL(SYMBOL, CLASS_T);
332    SYNONYM_STREAM.setCPL(SYNONYM_STREAM, SYSTEM_STREAM,
333                          STREAM, STRUCTURE_OBJECT, CLASS_T);
334    SYSTEM_STREAM.setCPL(SYSTEM_STREAM, STREAM, STRUCTURE_OBJECT, CLASS_T);
335    THREAD.setDirectSuperclass(CLASS_T);
336    THREAD.setCPL(THREAD, CLASS_T);
337    TWO_WAY_STREAM.setCPL(TWO_WAY_STREAM, SYSTEM_STREAM, STREAM,
338                          STRUCTURE_OBJECT, CLASS_T);
339    VECTOR.setDirectSuperclasses(list(ARRAY, SEQUENCE));
340    VECTOR.setCPL(VECTOR, ARRAY, SEQUENCE, CLASS_T);
341    STACK_FRAME.setDirectSuperclasses(CLASS_T);
342    STACK_FRAME.setCPL(STACK_FRAME, CLASS_T);
343    LISP_STACK_FRAME.setDirectSuperclasses(STACK_FRAME);
344    LISP_STACK_FRAME.setCPL(LISP_STACK_FRAME, STACK_FRAME, CLASS_T);
345    JAVA_STACK_FRAME.setDirectSuperclasses(STACK_FRAME);
346    JAVA_STACK_FRAME.setCPL(JAVA_STACK_FRAME, STACK_FRAME, CLASS_T);
347  }
348
349  static
350  {
351    StandardClass.initializeStandardClasses();
352  }
353}
Note: See TracBrowser for help on using the repository browser.