Mercurial > hg > xemacs-beta
view netinstall/ini.h @ 4502:8748a3f7ceb4
Handle varalias chains, custom variables in #'user-variable-p.
src/ChangeLog addition:
2008-08-23 Aidan Kehoe <kehoea@parhasard.net>
* eval.c (Fuser_variable_p): Moved to symbols.c
* symbols.c (Fcustom_variable_p): Moved here from custom.el.
(user_variable_alias_check_fun): Mapper function used in
`user-variable-p'.
(Fuser_variable_p): Moved here from eval.c, to allow it to examine
the variable alias chain. Expanded to check each entry in the
variable alias chain for signs of being a user variable;
documentation updated, noting the differences between GNU's
behaviour and ours (ours is a little more sensible)
(map_varalias_chain): New.
Given a C function, call it at least once for each symbol in a
symbol's varalias chain, signalling an error if there's a cycle,
and returning immediately if the function returns something other
than Qzero.
(Fdefvaralias): Correct the use of the word "alias" in the
docstring and in the argument name. Motivate this in a
comment. Add support for a DOCSTRING argument, something GNU has
too, and document this
* gc.c (vars_of_gc): Start the docstring of
`garbage-collection-messages' with an asterisk, to indicate that
it's a user variable.
lisp/ChangeLog addition:
2008-08-23 Aidan Kehoe <kehoea@parhasard.net>
* custom.el: Move #'custom-variable-p to C, since it's now called
from #'user-variable-p.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sat, 23 Aug 2008 16:38:51 +0200 |
parents | ce0b3f2eff35 |
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> * */ /* When setup.ini is parsed, the information is stored according to the declarations here. ini.cc (via inilex and iniparse) initializes these structures. choose.cc sets the action and trust fields. download.cc downloads any needed files for selected packages (the chosen "install" field). install.cc installs selected packages. */ #define YYSTYPE char * /* lowest number must be most trusted, highest least trusted */ #define TRUST_PREV 0 #define TRUST_CURR 1 #define TRUST_TEST 2 #define NTRUST 3 #define TRUST_UNKNOWN 3 /* intentionally not in NTRUST */ #define TY_GENERIC 0 #define TY_CYGWIN 1 #define TY_NATIVE 2 #define ACTION_UNKNOWN 0 #define ACTION_SAME 1 #define ACTION_NEW 2 #define ACTION_UPGRADE 3 #define ACTION_UNINSTALL 4 #define ACTION_ERROR 5 #define SRCACTION_NO 0 #define SRCACTION_YES 1 typedef struct { char *name; /* package name, like "cygwin" */ char *sdesc; /* short description (replaces "name" if provided) */ char *ldesc; /* long description (multi-line) */ int action; /* ACTION_* - only NEW and UPGRADE get installed */ int srcaction;/* SRCACTION_ */ int trust; /* TRUST_* (selects among info[] below) */ int type; /* TY_GENERIC, TY_CYGWIN or TY_NATIVE. */ struct { char *version; /* version part of filename */ char *install; /* file name to install */ int install_size; /* in bytes */ char *source; /* sources for installed binaries */ int source_size; /* in bytes */ } info[NTRUST+1]; /* +1 for TRUST_UNKNOWN */ } Package; #ifdef __cplusplus extern "C" { #endif extern Package *package; extern Package *xemacs_package; extern int npackages; Package *new_package (char *name); void ini_init (char *string); #define pinfo(p) ((p).info[(p).trust]) #define pi pinfo(package[i]) #define LOOP_PACKAGES \ for (i=0; i<npackages; i++) \ if ((package[i].action == ACTION_NEW \ || package[i].action == ACTION_UPGRADE) \ && pi.install) #ifdef __cplusplus } #endif