* etc/NEWS, doc/lispref/tips.texi (Coding Conventions): Mention
[emacs.git] / src / ccl.h
blobcc5daf11e1c7d280ee8c8754f2aa13c60008b661
1 /* Header for CCL (Code Conversion Language) interpreter.
2 Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
3 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012
4 National Institute of Advanced Industrial Science and Technology (AIST)
5 Registration Number H14PRO021
6 Copyright (C) 2003
7 National Institute of Advanced Industrial Science and Technology (AIST)
8 Registration Number H13PRO009
10 This file is part of GNU Emacs.
12 GNU Emacs is free software: you can redistribute it and/or modify
13 it under the terms of the GNU General Public License as published by
14 the Free Software Foundation, either version 3 of the License, or
15 (at your option) any later version.
17 GNU Emacs is distributed in the hope that it will be useful,
18 but WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 GNU General Public License for more details.
22 You should have received a copy of the GNU General Public License
23 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
26 #ifndef EMACS_CCL_H
27 #define EMACS_CCL_H
29 #include "character.h" /* For MAX_MULTIBYTE_LENGTH */
31 /* Macros for exit status of CCL program. */
32 #define CCL_STAT_SUCCESS 0 /* Terminated successfully. */
33 #define CCL_STAT_SUSPEND_BY_SRC 1 /* Terminated by empty input. */
34 #define CCL_STAT_SUSPEND_BY_DST 2 /* Terminated by output buffer full. */
35 #define CCL_STAT_INVALID_CMD 3 /* Terminated because of invalid
36 command. */
37 #define CCL_STAT_QUIT 4 /* Terminated because of quit. */
39 /* Structure to hold information about running CCL code. Read
40 comments in the file ccl.c for the detail of each field. */
41 struct ccl_program {
42 ptrdiff_t idx; /* Index number of the CCL program.
43 -1 means that the program was given
44 by a vector, not by a program
45 name. */
46 int size; /* Size of the compiled code. */
47 Lisp_Object *prog; /* Pointer into the compiled code. */
48 int ic; /* Instruction Counter (index for PROG). */
49 int eof_ic; /* Instruction Counter for end-of-file
50 processing code. */
51 int reg[8]; /* CCL registers, reg[7] is used for
52 condition flag of relational
53 operations. */
54 int private_state; /* CCL instruction may use this
55 for private use, mainly for saving
56 internal states on suspending.
57 This variable is set to 0 when ccl is
58 set up. */
59 int last_block; /* Set to 1 while processing the last
60 block. */
61 int status; /* Exit status of the CCL program. */
62 int buf_magnification; /* Output buffer magnification. How
63 many times bigger the output buffer
64 should be than the input buffer. */
65 int stack_idx; /* How deep the call of CCL_Call is nested. */
66 int src_multibyte; /* 1 if the input buffer is multibyte. */
67 int dst_multibyte; /* 1 if the output buffer is multibyte. */
68 int cr_consumed; /* Flag for encoding DOS-like EOL
69 format when the CCL program is used
70 for encoding by a coding
71 system. */
72 int consumed;
73 int produced;
74 int suppress_error; /* If nonzero, don't insert error
75 message in the output. */
76 int eight_bit_control; /* If nonzero, ccl_driver counts all
77 eight-bit-control bytes written by
78 CCL_WRITE_CHAR. After execution,
79 if no such byte is written, set
80 this value to zero. */
81 int quit_silently; /* If nonzero, don't append "CCL:
82 Quitted" to the generated text when
83 CCL program is quitted. */
86 /* This data type is used for the spec field of the structure
87 coding_system. */
89 struct ccl_spec {
90 struct ccl_program ccl;
91 int cr_carryover; /* CR carryover flag. */
92 unsigned char eight_bit_carryover[MAX_MULTIBYTE_LENGTH];
95 #define CODING_SPEC_CCL_PROGRAM(coding) ((coding)->spec.ccl.ccl)
97 /* Setup fields of the structure pointed by CCL appropriately for the
98 execution of ccl program CCL_PROG (symbol or vector). */
99 extern int setup_ccl_program (struct ccl_program *, Lisp_Object);
101 extern void ccl_driver (struct ccl_program *, int *, int *, int, int,
102 Lisp_Object);
104 extern Lisp_Object Qccl, Qcclp;
106 #define CHECK_CCL_PROGRAM(x) \
107 do { \
108 if (NILP (Fccl_program_p (x))) \
109 wrong_type_argument (Qcclp, (x)); \
110 } while (0);
112 #endif /* EMACS_CCL_H */