Mercurial > hg > xemacs-beta
view netinstall/netio.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 | 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> * */ /* This is the parent class for all the access methods known to setup (i.e. ways to download files from the internet or other sources */ class NetIO { protected: NetIO (char *url); void set_url (char *url); public: /* if nonzero, this is the estimated total file size */ int file_size; /* broken down url FYI */ char *url; char *proto; char *host; int port; char *path; virtual ~NetIO (); /* The user calls this function to create a suitable accessor for the given URL. It uses the network setup state in state.h. If anything fails, either the return values is NULL or the returned object is !ok() */ static NetIO * open (char *url); /* If !ok() that means the transfer isn't happening. */ virtual int ok (); /* Read `nbytes' bytes from the file. Returns zero when the file is complete. */ virtual int read (char *buf, int nbytes); /* Helper functions for http/ftp protocols. Both return nonzero for "cancel", zero for "ok". They set net_proxy_user, etc, in state.h */ int get_auth (); int get_proxy_auth (); };