Mercurial > hg > xemacs-beta
annotate modules/zlib/zlib.c @ 5634:2014ff433daf
Support hash COLLECTIONs, #'{all,try}-completion{s,}; add #'test-completion
src/ChangeLog addition:
2012-01-01 Aidan Kehoe <kehoea@parhasard.net>
Add #'test-completion, API from GNU.
Accept hash table COLLECTIONs in it and in the other
completion-oriented functions, #'try-completion,
#'all-completions, and those Lisp functions implemented in terms
of them.
* lisp.h: Update the prototype of map_obarray(), making FN
compatible with the FUNCTION argument of elisp_maphash();
* abbrev.c (abbrev_match_mapper):
* abbrev.c (record_symbol):
* doc.c (verify_doc_mapper):
* symbols.c (mapatoms_1):
* symbols.c (apropos_mapper):
Update these mapper functions to reflect the new argument to
map_obarray().
* symbols.c (map_obarray):
Call FN with two arguments, the string name of the symbol, and the
symbol itself, for API (mapper) compatibility with
elisp_maphash().
* minibuf.c (map_completion): New. Map a maphash_function_t across
a non function COLLECTION, as appropriate for #'try-completion and
friends.
* minibuf.c (map_completion_list): New. Map a maphash_function_t
across a pseudo-alist, as appropriate for the completion
functions.
* minibuf.c (ignore_completion_p): PRED needs to be called with
two args if and only if the collection is a hash table. Implement
this.
* minibuf.c (try_completion_mapper): New. The loop body of
#'try-completion, refactored out.
* minibuf.c (Ftry_completion): Use try_completion_mapper(),
map_completion().
* minibuf.c (all_completions_mapper): New. The loop body of
#'all-completions, refactored out.
* minibuf.c (Fall_completions): Use all_completions_mapper(),
map_completion().
* minibuf.c (test_completion_mapper): New. The loop body of
#'test-completion.
* minibuf.c (Ftest_completion): New, API from GNU.
* minibuf.c (syms_of_minibuf): Make Ftest_completion available.
tests/ChangeLog addition:
2012-01-01 Aidan Kehoe <kehoea@parhasard.net>
* automated/completion-tests.el: New.
Test #'try-completion, #'all-completion and #'test-completion with
list, vector and hash-table COLLECTION arguments.
| author | Aidan Kehoe <kehoea@parhasard.net> |
|---|---|
| date | Sun, 01 Jan 2012 15:18:52 +0000 |
| parents | 308d34e9f07d |
| children |
| rev | line source |
|---|---|
| 428 | 1 /* zlib interface for XEmacs. |
| 2 Copyright (C) 1998 Free Software Foundation, Inc. | |
| 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:
428
diff
changeset
|
6 XEmacs is free software: you can redistribute it and/or modify it |
| 428 | 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:
428
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:
428
diff
changeset
|
9 option) any later version. |
| 428 | 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:
428
diff
changeset
|
17 along with XEmacs. If not, see <http://www.gnu.org/licenses/>. */ |
| 428 | 18 |
| 19 /* Synched up with: Not in FSF. */ | |
| 20 | |
| 21 /* Author: William Perry <wmperry@aventail.com> */ | |
| 22 | |
| 23 #include <emodules.h> | |
| 24 | |
| 25 DEFUN ("compress", Fcompress, 1, 6, 0, /* | |
| 26 Return the compressed version of an object. | |
| 27 OBJECT is either a string or a buffer. | |
| 28 Optional argument LEVEL specifies how much to compress - valid range is 0 - 9. | |
| 29 Optional arguments START and END denote buffer positions for compressing | |
| 30 a portion of OBJECT. The optional CODING argument specifies the coding | |
| 31 system the text is to be represented in while computing the digest. This only | |
| 32 has meaning with MULE, and defaults to the current format of the data. | |
| 33 If ERROR-ME-NOT is nil, report an error if the coding system can't be | |
| 34 determined. Else assume binary coding if all else fails. | |
| 35 */ | |
| 36 (object, level, start, end, coding, error_me_not)) | |
| 37 { | |
| 38 return(Qnil); | |
| 39 } | |
| 40 | |
| 41 DEFUN ("decompress", Fdecompress, 1, 5, 0, /* | |
| 42 Uncompress an object. | |
| 43 OBJECT is either a string or a buffer. | |
| 44 Optional arguments START and END denote buffer positions for decompressing | |
| 45 a portion of OBJECT. The optional CODING argument specifies the coding | |
| 46 system the text is to be represented in while computing the digest. This only | |
| 47 has meaning with MULE, and defaults to the current format of the data. | |
| 48 If ERROR-ME-NOT is nil, report an error if the coding system can't be | |
| 49 determined. Else assume binary coding if all else fails. | |
| 50 */ | |
| 51 (object, start, end, coding, error_me_not)) | |
| 52 { | |
| 53 return(Qnil); | |
| 54 } | |
| 55 | |
| 56 void | |
| 57 syms_of_zlib (void) | |
| 58 { | |
| 59 DEFSUBR(Fcompress); | |
| 60 DEFSUBR(Fdecompress); | |
| 61 } | |
| 62 | |
| 63 void | |
| 64 vars_of_zlib (void) | |
| 65 { | |
| 66 Fprovide (intern ("zlib")); | |
| 67 } |
