Mercurial > hg > xemacs-beta
view netinstall/autoload.c @ 5241:d579d76f3dcc
Be more careful about side-effects from Lisp code, #'reduce
src/ChangeLog addition:
2010-07-24 Aidan Kehoe <kehoea@parhasard.net>
* lisp.h (PARSE_KEYWORDS):
Always accept a nil :allow-other-keys keyword argument, as
described in the ALLOW-OTHER-KEYS-NIL Common Lisp issue writeup,
and as necessary for Paul Dietz' tests for #'reduce.
* fns.c (mapping_interaction_error): New.
(Freduce): Call mapping_interaction_error when KEY or FUNCTION
have modified a string SEQUENCE such that the byte length of the
string has changed, or such that the current cursor pointer
doesn't point to the beginning of a character.
Cf. the MAPPING-DESTRUCTIVE-INTERACTION Common Lisp issue
writeup.
When traversing a list, GCPRO the part of it we still have to
traverse, to avoid any crashes if FUNCTION or KEY amputate it
behind us and force a garbage collection.
tests/ChangeLog addition:
2010-07-24 Aidan Kehoe <kehoea@parhasard.net>
* automated/lisp-tests.el:
Test a couple of things #'reduce was just made more careful
about.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sat, 24 Jul 2010 15:56:57 +0100 |
parents | 3078fd1074e8 |
children |
line wrap: on
line source
/* * Copyright (c) 2000, Red Hat, Inc. * * This program 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 2 of the License, or * (at your option) any later version. * * A copy of the GNU General Public License can be found at * http://www.gnu.org/ * * Written by DJ Delorie <dj@cygnus.com> * */ #include "win32.h" typedef struct { char *name; HINSTANCE handle; } DllInfo; #define DLL(n) static DllInfo n ## _info __asm__ (#n "_info") = { #n, 0} #define Auto(dll, func, size) \ __asm__ ("\t.data"); \ __asm__ ("\t.global\t_" #func "@" #size); \ __asm__ ("_" #func "@" #size ":"); \ __asm__ ("\tcall\tautoload_common"); \ __asm__ ("\t.long\t" #dll "_info"); \ __asm__ ("\t.ascii\t\"" #func "\\0\"") DLL (wininet); Auto (wininet, InternetAttemptConnect, 4); Auto (wininet, InternetCloseHandle, 4); Auto (wininet, InternetGetLastResponseInfoA, 12); Auto (wininet, InternetOpenA, 20); Auto (wininet, InternetOpenUrlA, 24); Auto (wininet, InternetReadFile, 16); Auto (wininet, InternetSetOptionA, 16); Auto (wininet, InternetQueryOptionA, 16); Auto (wininet, HttpQueryInfoA, 20); Auto (wininet, HttpSendRequestA, 20); typedef struct { DllInfo *dll; char name[100]; } AutoEntry; static void autoload_common () __asm__ ("autoload_common"); static void autoload_common (int x) { int fp, rel; unsigned char *proc; HINSTANCE h; AutoEntry *a; a = *(AutoEntry **)(&x - 1); if (a->dll->handle == 0) { h = LoadLibrary (a->dll->name); a->dll->handle = h; } fp = (int) GetProcAddress (a->dll->handle, a->name); proc = ((unsigned char *)a) - 5; rel = fp - (int)(a); /* now it's a relative call */ *proc++ = 0xe9; /* jump near 32-bit relative */ *proc++ = rel; *proc++ = rel>>8; *proc++ = rel>>16; *proc++ = rel>>24; *(int *)(&x-1) = (int)proc-5; }