Mercurial > hg > xemacs-beta
annotate nt/Win32.cf @ 5142:f965e31a35f0
reduce lcrecord headers to 2 words, rename printing_unreadable_object
-------------------- ChangeLog entries follow: --------------------
man/ChangeLog addition:
2010-03-13 Ben Wing <ben@xemacs.org>
* internals/internals.texi (Working with Lisp Objects):
* internals/internals.texi (Writing Macros):
* internals/internals.texi (lrecords):
More rewriting to correspond with changes from
*LRECORD* to *LISP_OBJECT*.
modules/ChangeLog addition:
2010-03-13 Ben Wing <ben@xemacs.org>
* postgresql/postgresql.c (print_pgconn):
* postgresql/postgresql.c (print_pgresult):
printing_unreadable_object -> printing_unreadable_object_fmt.
2010-03-13 Ben Wing <ben@xemacs.org>
* ldap/eldap.c (print_ldap):
printing_unreadable_object -> printing_unreadable_object_fmt.
src/ChangeLog addition:
2010-03-13 Ben Wing <ben@xemacs.org>
* alloc.c (alloc_sized_lrecord_1):
* alloc.c (alloc_sized_lrecord_array):
* alloc.c (old_alloc_sized_lcrecord):
* alloc.c (disksave_object_finalization_1):
* alloc.c (mark_lcrecord_list):
* alloc.c (alloc_managed_lcrecord):
* alloc.c (free_managed_lcrecord):
* alloc.c (tick_lcrecord_stats):
* alloc.c (sweep_lcrecords_1):
* buffer.c (print_buffer):
* buffer.c (DEFVAR_BUFFER_LOCAL_1):
* casetab.c:
* casetab.c (print_case_table):
* console.c (print_console):
* console.c (DEFVAR_CONSOLE_LOCAL_1):
* data.c (print_weak_list):
* data.c (print_weak_box):
* data.c (print_ephemeron):
* data.c (ephemeron_equal):
* database.c (print_database):
* database.c (finalize_database):
* device-msw.c (sync_printer_with_devmode):
* device-msw.c (print_devmode):
* device-msw.c (finalize_devmode):
* device.c:
* device.c (print_device):
* elhash.c:
* elhash.c (print_hash_table):
* eval.c (print_subr):
* eval.c (print_multiple_value):
* event-stream.c (event_stream_resignal_wakeup):
* events.c (clear_event_resource):
* events.c (zero_event):
* events.c (print_event):
* extents.c:
* extents.c (print_extent):
* file-coding.c (print_coding_system):
* font-mgr.c:
* font-mgr.c (Ffc_init):
* frame.c:
* frame.c (print_frame):
* gc.c:
* gc.c (GC_CHECK_NOT_FREE):
* glyphs.c:
* glyphs.c (print_image_instance):
* glyphs.c (print_glyph):
* gui.c (print_gui_item):
* gui.c (copy_gui_item):
* keymap.c (print_keymap):
* keymap.c (MARKED_SLOT):
* lisp.h:
* lisp.h (struct Lisp_String):
* lisp.h (DEFUN):
* lisp.h (DEFUN_NORETURN):
* lrecord.h:
* lrecord.h (NORMAL_LISP_OBJECT_UID):
* lrecord.h (struct lrecord_header):
* lrecord.h (set_lheader_implementation):
* lrecord.h (struct old_lcrecord_header):
* lrecord.h (struct free_lcrecord_header):
* marker.c (print_marker):
* mule-charset.c:
* mule-charset.c (print_charset):
* objects.c (print_color_instance):
* objects.c (print_font_instance):
* objects.c (finalize_font_instance):
* print.c (print_cons):
* print.c (printing_unreadable_object_fmt):
* print.c (printing_unreadable_lisp_object):
* print.c (external_object_printer):
* print.c (internal_object_printer):
* print.c (debug_p4):
* print.c (ext_print_begin):
* process.c (print_process):
* rangetab.c (print_range_table):
* rangetab.c (range_table_equal):
* scrollbar.c (free_scrollbar_instance):
* specifier.c (print_specifier):
* specifier.c (finalize_specifier):
* symbols.c (guts_of_unbound_marker):
* symeval.h:
* symeval.h (DEFVAR_SYMVAL_FWD):
* tooltalk.c:
* tooltalk.c (print_tooltalk_message):
* tooltalk.c (print_tooltalk_pattern):
* ui-gtk.c (ffi_object_printer):
* ui-gtk.c (emacs_gtk_object_printer):
* ui-gtk.c (emacs_gtk_boxed_printer):
* window.c (print_window):
* window.c (free_window_mirror):
* window.c (debug_print_window):
* xemacs.def.in.in:
(1) printing_unreadable_object -> printing_unreadable_object_fmt.
(2) printing_unreadable_lcrecord -> printing_unreadable_lisp_object
and fix up so it no longer requires an lcrecord.
These previous changes eliminate most of the remaining places where
the terms `lcrecord' and `lrecord' occurred outside of specialized
code.
(3) Fairly major change: Reduce the number of words in an lcrecord
from 3 to 2. The third word consisted of a uid that duplicated the
lrecord uid, and a single free bit, which was moved into the lrecord
structure. This reduces the size of the `uid' slot from 21 bits to
20 bits. Arguably this isn't enough -- we could easily have more than
1,000,000 or so objects created in a session. The answer is
(a) It doesn't really matter if we overflow the uid field because
it's only used for debugging, to identify an object uniquely
(or pretty much so).
(b) If we cared about it overflowing and wanted to reduce this,
we could make it so that cons, string, float and certain other
frob-block types that never print out the uid simply don't
store a uid in them and don't increment the lrecord_uid_counter.
(4) In conjunction with (3), create new macro NORMAL_LISP_OBJECT_UID()
and use it to abstract out the differences between NEWGC and old-GC
in accessing the `uid' value from a "normal Lisp Object pointer".
(5) In events.c, use zero_nonsized_lisp_object() in place of custom-
written equivalent. In font-mgr.c use external_object_printer()
in place of custom-written equivalents.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Sat, 13 Mar 2010 05:38:08 -0600 |
parents | 43dd3413c7c7 |
children |
rev | line source |
---|---|
155 | 1 XCOMM platform: $XConsortium: Win32.cf /main/51 1996/12/19 14:20:08 lehors $ |
2 | |
3 #ifndef OSName | |
4 #define OSName Microsoft Windows NT 4.0 | |
5 #endif | |
6 XCOMM operating system: OSName | |
7 #ifndef OSMajorVersion | |
8 #define OSMajorVersion 4 | |
9 #endif | |
10 #ifndef OSMinorVersion | |
11 #define OSMinorVersion 0 | |
12 #endif | |
13 #ifndef OSTeenyVersion | |
14 #define OSTeenyVersion 0 | |
15 #endif | |
16 | |
17 #ifndef CompilerMajorVersion | |
18 /* 0 == NT 3.1 Win32 SDK, 2 == MSVC++ 2, 4 == MSVC 4 */ | |
19 #define CompilerMajorVersion 4 | |
20 #endif | |
21 | |
22 #define BootstrapCFlags -DWIN32 | |
23 #ifdef _M_IX86 | |
24 #define CpuDefines -D_X86_ | |
25 #endif | |
26 /* brain-damaged windows headers will not compile with -Za */ | |
27 /*#define StandardDefines -DWIN32 -DWIN32_LEAN_AND_MEAN -D_DLL -D_MT -D__STDC__ CpuDefines*/ | |
28 /* Try with single threaded libc --marcpa */ | |
29 #define StandardDefines -DWIN32 -DWIN32_LEAN_AND_MEAN -D__STDC__ CpuDefines | |
30 #if CompilerMajorVersion < 4 | |
31 #define DefaultCCOptions -nologo -batch -G4 -W2 | |
32 #else | |
33 #define DefaultCCOptions -nologo -G4 -W2 | |
34 #endif | |
35 #if CompilerMajorVersion < 4 | |
36 #define DebuggableCDebugFlags -Zi | |
37 #else | |
38 #define DebuggableCDebugFlags -Zi -Od | |
39 #endif | |
40 #define ThreadedX NO | |
41 #define HasThreadSafeAPI NO | |
42 #define CpCmd copy | |
43 #define LnCmd copy | |
44 #define MvCmd ren | |
45 #define RmCmd del | |
46 #ifndef RmTreeCmd | |
47 /*#define RmTreeCmd del /q /s */ | |
48 #define RmTreeCmd rm -rf | |
49 #endif | |
50 #define CcCmd cl | |
51 #define HasCplusplus YES | |
52 #define CplusplusCmd cl | |
53 #if CompilerMajorVersion < 4 | |
54 #define PreProcessCmd CcCmd -nologo -batch -EP | |
55 #define CppCmd CcCmd -nologo -batch -E | |
56 #else | |
57 #define PreProcessCmd CcCmd -nologo -EP | |
58 #define CppCmd CcCmd -nologo -E | |
59 #endif | |
60 #define PatheticCpp YES | |
61 #define ConstructMFLAGS YES | |
62 #if (CompilerMajorVersion == 0) | |
63 #define ArCmdBase lib32 | |
64 #else | |
65 #define ArCmdBase lib | |
66 #endif | |
67 #define ArCmd ArCmdBase | |
68 #define CplusplusCmd cl | |
69 #define MkdirHierCmd mkdir | |
70 #define InstallCmd copy | |
71 #define InstPgmFlags /**/ | |
72 #define InstBinFlags /**/ | |
73 #define InstUidFlags /**/ | |
74 #define InstLibFlags /**/ | |
75 #define InstIncFlags /**/ | |
76 #define InstManFlags /**/ | |
77 #define InstDatFlags /**/ | |
78 #define InstallFlags /**/ | |
79 #if (CompilerMajorVersion == 0) | |
80 #define ExtraLibraries crtdll.lib kernel32.lib wsock32.lib | |
81 #elif (CompilerMajorVersion < 4) | |
82 #define ExtraLibraries msvcrt.lib kernel32.lib wsock32.lib | |
83 #else | |
84 /* Use LIBC.LIB instead of msvcrt.lib since we compile | |
85 with non-thread version. --marcpa */ | |
86 #define ExtraLibraries libc.lib kernel32.lib wsock32.lib -link -nodefaultlib:libc | |
87 #endif | |
88 #define MakeCmd nmake -nologo | |
89 #if (CompilerMajorVersion == 0) | |
90 #define LdCmd link32 | |
91 #else | |
92 #define LdCmd link | |
93 #endif | |
94 #define MathLibrary | |
95 #define HasSymLinks NO | |
96 #define HasPutenv YES | |
97 #define Osuf obj | |
98 #ifndef CCsuf | |
99 #define CCsuf cxx | |
100 #endif | |
101 #define BuildServer NO | |
102 #define ConnectionFlags -DTCPCONN | |
103 | |
104 /* override as necessary in site.def/host.def */ | |
105 #ifndef StdIncDir | |
106 #define StdIncDir C:/MSDEVSTD/INCLUDE | |
107 #endif | |
108 #define LdPreLib /**/ | |
109 #define LdPostLib /**/ | |
110 #ifndef UseInstalled | |
111 #define ImakeCmd $(IMAKESRC:/=\)\imake | |
112 #define DependCmd $(DEPENDSRC:/=\)\makedepend | |
113 #endif | |
114 #define DependFlags -D_WIN32 | |
115 #define FilesToClean *.bak *.obj *.lib make.log | |
116 #define ShLibDir $(BINDIR) | |
117 | |
118 #define XFileSearchPathBase Concat4($(LIBDIR)/;L/;T/;N;C,;S:$(LIBDIR)/;l/;T/;N;C,;S:$(LIBDIR)/;T/;N;C,;S:$(LIBDIR)/;L/;T/;N;S:$(LIBDIR)/;l/;T/;N;S:$(LIBDIR)/;T/;N;S) | |
119 | |
120 #define XawI18nDefines -DHAS_WCHAR_H | |
121 #define UseRgbTxt YES | |
122 #define HasCbrt NO | |
123 #define HasFfs NO | |
124 #define HasXdmAuth NO | |
125 | |
126 /* the following components haven't been ported yet */ | |
127 #define BuildLBX NO | |
128 #define BuildXprint NO | |
129 #define XprtServer NO | |
130 | |
131 #include <Win32.rules> |