Mercurial > hg > xemacs-beta
view src/mule-ccl.h @ 5509:9ac0016d8fe8
Remove `bind-inits', cl-macs.el, it's no longer used.
2011-05-18 Aidan Kehoe <kehoea@parhasard.net>
* cl-macs.el (bind-inits)): Removed.
* cl-macs.el (defun*):
* cl-macs.el (defmacro*):
* cl-macs.el (function*):
* cl-macs.el (macrolet):
* cl-macs.el (cl-transform-function-property):
* cl-macs.el (destructuring-bind):
Remove `bind-inits' from this file, and only ever return nil as
the first element of cl-transform-lambda's result list; bind-inits
hasn't been used since the support for non-self-quoting keywords
was removed, and its absence (and the guarantee that the first
element of the result of cl-transform-lambda is nil) make the
implementations of various other macros easier and clearer.
* cl-macs.el (cl-transform-lambda):
Give this function a docstring.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Wed, 18 May 2011 14:21:52 +0100 |
parents | 308d34e9f07d |
children |
line wrap: on
line source
/* Header for CCL (Code Conversion Language) interpreter. Copyright (C) 1995 Electrotechnical Laboratory, JAPAN. Licensed to the Free Software Foundation. This file is part of XEmacs. XEmacs 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 3 of the License, or (at your option) any later version. XEmacs is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with XEmacs. If not, see <http://www.gnu.org/licenses/>. */ #ifndef INCLUDED_mule_ccl_h_ #define INCLUDED_mule_ccl_h_ /* Macros for exit status of CCL program. */ #define CCL_STAT_SUCCESS 0 /* Terminated successfully. */ #define CCL_STAT_SUSPEND_BY_SRC 1 /* Terminated by empty input. */ #define CCL_STAT_SUSPEND_BY_DST 2 /* Terminated by output buffer full. */ #define CCL_STAT_INVALID_CMD 3 /* Terminated because of invalid command. */ #define CCL_STAT_QUIT 4 /* Terminated because of quit. */ /* Structure to hold information about running CCL code. Read comments in the file ccl.c for the detail of each field. */ struct ccl_program { int size; /* Size of the compiled code. */ Lisp_Object *prog; /* Pointer into the compiled code. */ int ic; /* Instruction Counter (index for PROG). */ int eof_ic; /* Instruction Counter for end-of-file processing code. */ int reg[8]; /* CCL registers, reg[7] is used for condition flag of relational operations. */ int private_state; /* CCL instruction may use this for private use, mainly for saving internal states on suspending. This variable is set to 0 when ccl is set up. */ int last_block; /* Set to 1 while processing the last block. */ int status; /* Exit status of the CCL program. */ int buf_magnification; /* Output buffer magnification. How many times bigger the output buffer should be than the input buffer. */ int stack_idx; /* How deep the call of CCL_Call is nested. */ int eol_type; /* When the CCL program is used for encoding by a coding system, set to the eol_type of the coding system. */ int multibyte; /* 1 if the source text is multibyte. */ }; #define CCL_MODE_ENCODING 0 #define CCL_MODE_DECODING 1 #define CCL_CODING_EOL_LF 0 /* Line-feed only, same as Emacs' internal format. */ #define CCL_CODING_EOL_CRLF 1 /* Sequence of carriage-return and line-feed. */ #define CCL_CODING_EOL_CR 2 /* Carriage-return only. */ /* If OBJECT is symbol designating a registered CCL program, return it. Else if OBJECT is a vector CCL program with no unresolved symbols, return it. Else, if OBJECT is a vector CCL program with unresolved symbols, return a newly-created vector reflecting the CCL program with all symbols resolved, if that is currently possible in this XEmacs. Otherwise, signal `invalid-argument'. */ extern Lisp_Object get_ccl_program (Lisp_Object object); /* Set up fields of the structure pointed by CCL appropriately for the execution of ccl program CCL_PROG (a symbol or a vector). If CCL_PROG is a vector and contains unresolved symbols, this function will throw an assertion failure. To avoid this, call get_ccl_program at the point that you receive the CCL program from Lisp, and use and store its (resolved) result instead. */ extern int setup_ccl_program (struct ccl_program *, Lisp_Object ccl_prog); extern int ccl_driver (struct ccl_program *, const unsigned char *, unsigned_char_dynarr *, int, int *, int); EXFUN (Fregister_ccl_program, 2); extern Lisp_Object Qccl_program; /* Vector of CCL program names vs corresponding program data. */ extern Lisp_Object Vccl_program_table; /* Symbols of ccl program have this property, a value of the property is an index for Vccl_program_table. */ extern Lisp_Object Qccl_program_idx; #endif /* INCLUDED_mule_ccl_h_ */