ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Convert-UUlib/uulib/uudeview.h
Revision: 1.7
Committed: Mon May 2 19:58:40 2005 UTC (19 years, 1 month ago) by root
Content type: text/plain
Branch: MAIN
CVS Tags: rel-1_11, rel-1_10, rel-1_12, rel-0_7, rel-1_06, rel-1_08, rel-1_09
Changes since 1.6: +2 -0 lines
Log Message:
*** empty log message ***

File Contents

# User Rev Content
1 root 1.1 /*
2     * This file is part of uudeview, the simple and friendly multi-part multi-
3     * file uudecoder program (c) 1994-2001 by Frank Pilhofer. The author may
4     * be contacted at fp@fpx.de
5     *
6     * This program is free software; you can redistribute it and/or modify
7     * it under the terms of the GNU General Public License as published by
8     * the Free Software Foundation; either version 2 of the License, or
9     * (at your option) any later version.
10     *
11     * This program is distributed in the hope that it will be useful,
12     * but WITHOUT ANY WARRANTY; without even the implied warranty of
13     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14     * GNU General Public License for more details.
15     */
16    
17     #ifndef __UUDEVIEW_H__
18     #define __UUDEVIEW_H__
19    
20     /*
21     * This include file features all the definitions that should
22     * be externally visible. This isn't much.
23     *
24 root 1.6 * $Id$
25 root 1.1 */
26    
27     #ifndef _ANSI_ARGS_
28     #ifdef PROTOTYPES
29     #define _ANSI_ARGS_(c) c
30     #else
31     #define _ANSI_ARGS_(c) ()
32     #endif
33     #endif
34    
35     /*
36     * Message Types
37     */
38    
39     #define UUMSG_MESSAGE (0) /* just a message, nothing important */
40     #define UUMSG_NOTE (1) /* something that should be noticed */
41     #define UUMSG_WARNING (2) /* important msg, processing continues */
42     #define UUMSG_ERROR (3) /* processing has been terminated */
43     #define UUMSG_FATAL (4) /* decoder cannot process further requests */
44     #define UUMSG_PANIC (5) /* recovery impossible, app must terminate */
45    
46     /*
47     * Return Values
48     */
49    
50     #define UURET_OK (0) /* everything went fine */
51     #define UURET_IOERR (1) /* I/O Error - examine errno */
52     #define UURET_NOMEM (2) /* not enough memory */
53     #define UURET_ILLVAL (3) /* illegal value for operation */
54     #define UURET_NODATA (4) /* decoder didn't find any data */
55     #define UURET_NOEND (5) /* encoded data wasn't ended properly */
56     #define UURET_UNSUP (6) /* unsupported function (encoding) */
57     #define UURET_EXISTS (7) /* file exists (decoding) */
58     #define UURET_CONT (8) /* continue -- special from ScanPart */
59     #define UURET_CANCEL (9) /* operation canceled */
60    
61     /*
62     * File states, may be OR'ed
63     */
64    
65     #define UUFILE_READ (0) /* Read in, but not further processed */
66     #define UUFILE_MISPART (1) /* Missing Part(s) detected */
67     #define UUFILE_NOBEGIN (2) /* No 'begin' found */
68     #define UUFILE_NOEND (4) /* No 'end' found */
69     #define UUFILE_NODATA (8) /* File does not contain valid uudata */
70     #define UUFILE_OK (16) /* All Parts found, ready to decode */
71     #define UUFILE_ERROR (32) /* Error while decoding */
72     #define UUFILE_DECODED (64) /* Successfully decoded */
73     #define UUFILE_TMPFILE (128) /* Temporary decoded file exists */
74    
75     /*
76     * Encoding Types
77     */
78    
79     #define UU_ENCODED (1) /* UUencoded data */
80     #define B64ENCODED (2) /* Mime-Base64 data */
81     #define XX_ENCODED (3) /* XXencoded data */
82     #define BH_ENCODED (4) /* Binhex encoded */
83     #define PT_ENCODED (5) /* Plain-Text encoded (MIME) */
84     #define QP_ENCODED (6) /* Quoted-Printable (MIME) */
85 root 1.2 #define YENC_ENCODED (7) /* yEnc encoded */
86 root 1.1
87     /*
88     * Option indices for GetOption / SetOption
89     */
90    
91 root 1.7 #define UUOPT_RBUF (90) /* file read I/O buffer size */
92     #define UUOPT_WBUF (91) /* file write I/O buffer size */
93 root 1.1 #define UUOPT_VERSION (0) /* version number MAJOR.MINORplPATCH (ro) */
94     #define UUOPT_FAST (1) /* assumes only one part per file */
95     #define UUOPT_DUMBNESS (2) /* switch off the program's intelligence */
96     #define UUOPT_BRACKPOL (3) /* give numbers in [] higher precendence */
97     #define UUOPT_VERBOSE (4) /* generate informative messages */
98     #define UUOPT_DESPERATE (5) /* try to decode incomplete files */
99     #define UUOPT_IGNREPLY (6) /* ignore RE:plies (off by default) */
100     #define UUOPT_OVERWRITE (7) /* whether it's OK to overwrite ex. files */
101     #define UUOPT_SAVEPATH (8) /* prefix to save-files on disk */
102     #define UUOPT_IGNMODE (9) /* ignore the original file mode */
103     #define UUOPT_DEBUG (10) /* print messages with FILE/LINE info */
104     #define UUOPT_ERRNO (14) /* get last error code for UURET_IOERR (ro) */
105     #define UUOPT_PROGRESS (15) /* retrieve progress information */
106     #define UUOPT_USETEXT (16) /* handle text messages */
107     #define UUOPT_PREAMB (17) /* handle Mime preambles/epilogues */
108     #define UUOPT_TINYB64 (18) /* detect short B64 outside of Mime */
109     #define UUOPT_ENCEXT (19) /* extension for single-part encoded files */
110     #define UUOPT_REMOVE (20) /* remove input files after decoding */
111     #define UUOPT_MOREMIME (21) /* strict MIME adherence */
112 root 1.4 #define UUOPT_DOTDOT (22) /* .. unescaping has not yet been done on input files */
113 root 1.1
114     /*
115     * Code for the "action" in the progress structure
116     */
117    
118     #define UUACT_IDLE (0) /* we don't do anything */
119     #define UUACT_SCANNING (1) /* scanning an input file */
120     #define UUACT_DECODING (2) /* decoding into a temp file */
121     #define UUACT_COPYING (3) /* copying temp to target */
122     #define UUACT_ENCODING (4) /* encoding a file */
123    
124     /*
125     * forward definition
126     */
127    
128     struct _uufile;
129    
130     /*
131     * Structure for holding the list of files that have been found
132     * uufile items are inserted into this list with UUInsertPartToList
133     * After inserting a bunch of files, UUCheckGlobalList must be called
134     * to update the states.
135     */
136    
137     typedef struct _uulist {
138     short state; /* Status as described by the macros above */
139     short mode; /* file mode as found on begin line */
140    
141     int begin; /* part number where begin was detected */
142     int end; /* part number where end was detected */
143    
144     short uudet; /* Encoding type (see macros above) */
145     int flags; /* flags, especially for single-part files */
146    
147     long size; /* approximate size of resulting file */
148     char *filename; /* malloc'ed file name */
149     char *subfname; /* malloc'ed ID from subject line */
150     char *mimeid; /* malloc'ed MIME-ID, if available */
151     char *mimetype; /* malloc'ed Content-Type, if available */
152    
153     char *binfile; /* name of temp file, if already decoded */
154    
155     struct _uufile *thisfile; /* linked list of this file's parts */
156    
157     int *haveparts; /* the parts we have (max. 256 are listed) */
158     int *misparts; /* list of missing parts (max. 256) */
159    
160     struct _uulist *NEXT; /* next item of the list */
161     struct _uulist *PREV; /* previous item of the list */
162     } uulist;
163    
164     /*
165     * The "progress" structure which is passed to the Busy Callback
166     */
167    
168     typedef struct {
169     int action; /* see UUACT_* definitions above */
170     char curfile[256]; /* the file we are working on, incl. path */
171     int partno; /* part we're currently decoding */
172     int numparts; /* total number of parts of this file */
173     long fsize; /* size of the current file */
174     int percent; /* % of _current part_ */
175     long foffset; /* file offset -- internal use only */
176     long totsize; /* file total size -- internal use only */
177     } uuprogress;
178    
179    
180     /*
181     * Externally visible Functions
182     */
183    
184     #ifndef UUEXPORT
185     #define UUEXPORT
186     #endif
187    
188     #ifdef __cplusplus
189     extern "C" {
190     #endif
191    
192     int UUEXPORT UUInitialize _ANSI_ARGS_((void));
193     int UUEXPORT UUGetOption _ANSI_ARGS_((int, int *, char *, int));
194     int UUEXPORT UUSetOption _ANSI_ARGS_((int, int, char *));
195     char * UUEXPORT UUstrerror _ANSI_ARGS_((int));
196     int UUEXPORT UUSetMsgCallback _ANSI_ARGS_((void *,
197     void (*) (void *,
198     char *,
199     int)));
200     int UUEXPORT UUSetBusyCallback _ANSI_ARGS_((void *,
201     int (*) (void *,
202     uuprogress *),
203     long));
204     int UUEXPORT UUSetFileCallback _ANSI_ARGS_((void *,
205     int (*) (void *, char *,
206     char *, int)));
207     int UUEXPORT UUSetFNameFilter _ANSI_ARGS_((void *,
208     char * (*) (void *,
209     char *)));
210 root 1.3 int UUEXPORT UUSetFileNameCallback _ANSI_ARGS_((void *,
211     char * (*) (void *,
212     char *, char *)));
213 root 1.1 char * UUEXPORT UUFNameFilter _ANSI_ARGS_((char *));
214 root 1.2 int UUEXPORT UULoadFile _ANSI_ARGS_((char *, char *, int, int *));
215 root 1.6 int UUEXPORT UULoadFileWithPartNo _ANSI_ARGS_((char *, char *, int, int, int *));
216 root 1.1 uulist *UUEXPORT UUGetFileListItem _ANSI_ARGS_((int));
217     int UUEXPORT UURenameFile _ANSI_ARGS_((uulist *, char *));
218     int UUEXPORT UUDecodeToTemp _ANSI_ARGS_((uulist *));
219     int UUEXPORT UURemoveTemp _ANSI_ARGS_((uulist *));
220     int UUEXPORT UUDecodeFile _ANSI_ARGS_((uulist *, char *));
221     int UUEXPORT UUInfoFile _ANSI_ARGS_((uulist *, void *,
222     int (*) (void *,
223     char *)));
224     int UUEXPORT UUSmerge _ANSI_ARGS_((int));
225     int UUEXPORT UUCleanUp _ANSI_ARGS_((void));
226    
227     int UUEXPORT UUQuickDecode _ANSI_ARGS_((FILE *, FILE *,
228     char *, long));
229    
230     int UUEXPORT UUEncodeMulti _ANSI_ARGS_((FILE *, FILE *,
231     char *, int,
232     char *, char *, int));
233     int UUEXPORT UUEncodePartial _ANSI_ARGS_((FILE *, FILE *,
234     char *, int,
235     char *, char *,
236 root 1.5 int, int, long,
237     unsigned long*));
238 root 1.1 int UUEXPORT UUEncodeToStream _ANSI_ARGS_((FILE *, FILE *,
239     char *, int,
240     char *, int));
241     int UUEXPORT UUEncodeToFile _ANSI_ARGS_((FILE *, char *, int,
242     char *, char *, long));
243     int UUEXPORT UUE_PrepSingle _ANSI_ARGS_((FILE *, FILE *,
244     char *, int,
245     char *, int,
246     char *, char *,
247     char *, int));
248     int UUEXPORT UUE_PrepPartial _ANSI_ARGS_((FILE *, FILE *,
249     char *, int,
250     char *, int,
251     int, long, long, char *,
252     char *, char *, int));
253    
254     int UUEXPORT UUE_PrepSingleExt _ANSI_ARGS_((FILE *, FILE *,
255     char *, int,
256     char *, int,
257     char *, char *,
258     char *, char *,
259     int));
260     int UUEXPORT UUE_PrepPartialExt _ANSI_ARGS_((FILE *, FILE *,
261     char *, int,
262     char *, int,
263     int, long, long, char *,
264     char *, char *, char *,
265     int));
266     #ifdef __cplusplus
267     }
268     #endif
269     #endif