Mercurial > hg > xemacs-beta
annotate lib-src/make-dump-id.c @ 5574:d4f334808463
Support inlining labels, bytecomp.el.
lisp/ChangeLog addition:
2011-10-02 Aidan Kehoe <kehoea@parhasard.net>
* bytecomp.el (byte-compile-initial-macro-environment):
Add #'declare to this, so it doesn't need to rely on
#'cl-compiling file to determine when we're byte-compiling.
Update #'labels to support declaring labels inline, as Common Lisp
requires.
* bytecomp.el (byte-compile-function-form):
Don't error if FUNCTION is quoting a non-lambda, non-symbol, just
return it.
* cl-extra.el (cl-macroexpand-all):
If a label name has been quoted, expand to the label placeholder
quoted with 'function. This allows the byte compiler to
distinguish between uses of the placeholder as data and uses in
contexts where it should be inlined.
* cl-macs.el:
* cl-macs.el (cl-do-proclaim):
When proclaming something as inline, if it is bound as a label,
don't modify the symbol's plist; instead, treat the first element
of its placeholder constant vector as a place to store compile
information.
* cl-macs.el (declare):
Leave processing declarations while compiling to the
implementation of #'declare in
byte-compile-initial-macro-environment.
tests/ChangeLog addition:
2011-10-02 Aidan Kehoe <kehoea@parhasard.net>
* automated/lisp-tests.el:
* automated/lisp-tests.el (+):
Test #'labels and inlining.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sun, 02 Oct 2011 15:32:16 +0100 |
parents | 308d34e9f07d |
children |
rev | line source |
---|---|
442 | 1 /* Generate a unique dump-id for use with the portable dumper. |
2 Copyright (C) 2000 Olivier Galibert, Martin Buchholz | |
3 | |
4 This file is part of XEmacs. | |
5 | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2367
diff
changeset
|
6 XEmacs is free software: you can redistribute it and/or modify it |
442 | 7 under the terms of the GNU General Public License as published by the |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2367
diff
changeset
|
8 Free Software Foundation, either version 3 of the License, or (at your |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2367
diff
changeset
|
9 option) any later version. |
442 | 10 |
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
14 for more details. | |
15 | |
16 You should have received a copy of the GNU General Public License | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
2367
diff
changeset
|
17 along with XEmacs. If not, see <http://www.gnu.org/licenses/>. */ |
442 | 18 |
19 #include <config.h> | |
20 #include <stdio.h> | |
21 #include <stdlib.h> | |
22 #include "../src/systime.h" | |
23 | |
24 #ifdef WIN32_NATIVE | |
25 #include <sys/timeb.h> | |
26 | |
27 /* Emulate gettimeofday (Ulrich Leodolter, 1/11/95). */ | |
28 void | |
29 gettimeofday (struct timeval *tv, struct timezone *tz) | |
30 { | |
31 struct _timeb tb; | |
32 _ftime (&tb); | |
33 | |
34 tv->tv_sec = tb.time; | |
35 tv->tv_usec = tb.millitm * 1000L; | |
36 if (tz) | |
37 { | |
38 tz->tz_minuteswest = tb.timezone; /* minutes west of Greenwich */ | |
39 tz->tz_dsttime = tb.dstflag; /* type of dst correction */ | |
40 } | |
41 } | |
42 #endif | |
43 | |
44 /* Generates an (extremely) pseudo random number for the dump-id */ | |
45 static unsigned int | |
46 generate_dump_id (void) | |
47 { | |
48 EMACS_TIME thyme; | |
49 EMACS_GET_TIME (thyme); | |
50 | |
51 return (unsigned int) (EMACS_SECS (thyme) ^ EMACS_USECS (thyme)); | |
52 } | |
53 | |
54 int | |
2367 | 55 main (int argc, char **argv) |
442 | 56 { |
57 FILE *f; | |
58 | |
59 if ((f = fopen ("dump-id.c", "w")) == NULL) | |
60 { | |
61 perror ("open dump-id.c"); | |
62 return EXIT_FAILURE; | |
63 } | |
64 | |
1688 | 65 /* dump_id is declared as extern "C" in dumper.h */ |
66 fputs ("extern\n", f); | |
67 fputs ("#ifdef __cplusplus\n", f); | |
68 fputs ("\"C\"\n", f); | |
69 fputs ("#endif\n", f); | |
70 fputs ("unsigned int dump_id;\n", f); | |
460 | 71 fprintf (f, "unsigned int dump_id = %uU;\n", generate_dump_id ()); |
442 | 72 |
73 if ((fclose (f)) != 0) | |
74 { | |
75 perror ("close dump-id.c"); | |
76 return EXIT_FAILURE; | |
77 } | |
78 | |
79 return EXIT_SUCCESS; | |
80 } |