Mercurial > hg > xemacs-beta
view netinstall/autoload.c @ 5066:545ec923b4eb
add documentation on keywords to cl*.el
-------------------- ChangeLog entries follow: --------------------
lisp/ChangeLog addition:
2010-02-22 Ben Wing <ben@xemacs.org>
* cl-seq.el:
* cl-seq.el (reduce):
* cl-seq.el (fill):
* cl-seq.el (replace):
* cl-seq.el (remove*):
* cl-seq.el (remove-if):
* cl-seq.el (remove-if-not):
* cl-seq.el (delete*):
* cl-seq.el (delete-if):
* cl-seq.el (delete-if-not):
* cl-seq.el (remove-duplicates):
* cl-seq.el (delete-duplicates):
* cl-seq.el (substitute):
* cl-seq.el (substitute-if):
* cl-seq.el (substitute-if-not):
* cl-seq.el (nsubstitute):
* cl-seq.el (nsubstitute-if):
* cl-seq.el (nsubstitute-if-not):
* cl-seq.el (find):
* cl-seq.el (find-if):
* cl-seq.el (find-if-not):
* cl-seq.el (position):
* cl-seq.el (position-if):
* cl-seq.el (position-if-not):
* cl-seq.el (count):
* cl-seq.el (count-if):
* cl-seq.el (count-if-not):
* cl-seq.el (mismatch):
* cl-seq.el (search):
* cl-seq.el (sort*):
* cl-seq.el (stable-sort):
* cl-seq.el (merge):
* cl-seq.el (member*):
* cl-seq.el (member-if):
* cl-seq.el (member-if-not):
* cl-seq.el (assoc*):
* cl-seq.el (assoc-if):
* cl-seq.el (assoc-if-not):
* cl-seq.el (rassoc*):
* cl-seq.el (rassoc-if):
* cl-seq.el (rassoc-if-not):
* cl-seq.el (union):
* cl-seq.el (nunion):
* cl-seq.el (intersection):
* cl-seq.el (nintersection):
* cl-seq.el (set-difference):
* cl-seq.el (nset-difference):
* cl-seq.el (set-exclusive-or):
* cl-seq.el (nset-exclusive-or):
* cl-seq.el (subsetp):
* cl-seq.el (subst-if):
* cl-seq.el (subst-if-not):
* cl-seq.el (nsubst):
* cl-seq.el (nsubst-if):
* cl-seq.el (nsubst-if-not):
* cl-seq.el (sublis):
* cl-seq.el (nsublis):
* cl-seq.el (tree-equal):
* cl-seq.el (cl-tree-equal-rec):
* cl.el:
* cl.el (pushnew):
* cl.el (adjoin):
* cl.el (subst):
Document the keywords to the various sequence/list functions.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Mon, 22 Feb 2010 21:17:47 -0600 |
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; }