ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Convert-UUlib/UUlib.xs
(Generate patch)

Comparing Convert-UUlib/UUlib.xs (file contents):
Revision 1.2 by root, Mon Jun 11 20:42:36 2001 UTC vs.
Revision 1.16 by root, Fri Jul 10 01:17:08 2015 UTC

5#include "uulib/fptools.h" 5#include "uulib/fptools.h"
6#include "uulib/uudeview.h" 6#include "uulib/uudeview.h"
7#include "uulib/uuint.h" 7#include "uulib/uuint.h"
8 8
9static int 9static int
10not_here(char *s) 10not_here (char *s)
11{ 11{
12 croak("%s not implemented on this architecture", s); 12 croak("%s not implemented", s);
13 return -1; 13 return -1;
14} 14}
15 15
16static int 16static int
17constant(char *name) 17constant (char *name)
18{ 18{
19 errno = 0; 19 errno = 0;
20 switch (*name) { 20 switch (*name)
21 {
21 case 'A': 22 case 'A':
22 if (strEQ(name, "ACT_COPYING")) return UUACT_COPYING; 23 if (strEQ(name, "ACT_COPYING")) return UUACT_COPYING;
23 if (strEQ(name, "ACT_DECODING")) return UUACT_DECODING; 24 if (strEQ(name, "ACT_DECODING")) return UUACT_DECODING;
24 if (strEQ(name, "ACT_ENCODING")) return UUACT_ENCODING; 25 if (strEQ(name, "ACT_ENCODING")) return UUACT_ENCODING;
25 if (strEQ(name, "ACT_IDLE")) return UUACT_IDLE; 26 if (strEQ(name, "ACT_IDLE")) return UUACT_IDLE;
26 if (strEQ(name, "ACT_SCANNING")) return UUACT_SCANNING; 27 if (strEQ(name, "ACT_SCANNING")) return UUACT_SCANNING;
27 case 'F': 28 case 'F':
28 if (strEQ(name, "FILE_DECODED")) return UUFILE_DECODED; 29 if (strEQ(name, "FILE_DECODED")) return UUFILE_DECODED;
29 if (strEQ(name, "FILE_ERROR")) return UUFILE_ERROR; 30 if (strEQ(name, "FILE_ERROR")) return UUFILE_ERROR;
30 if (strEQ(name, "FILE_MISPART")) return UUFILE_MISPART; 31 if (strEQ(name, "FILE_MISPART")) return UUFILE_MISPART;
31 if (strEQ(name, "FILE_NOBEGIN")) return UUFILE_NOBEGIN; 32 if (strEQ(name, "FILE_NOBEGIN")) return UUFILE_NOBEGIN;
32 if (strEQ(name, "FILE_NODATA")) return UUFILE_NODATA; 33 if (strEQ(name, "FILE_NODATA")) return UUFILE_NODATA;
33 if (strEQ(name, "FILE_NOEND")) return UUFILE_NOEND; 34 if (strEQ(name, "FILE_NOEND")) return UUFILE_NOEND;
34 if (strEQ(name, "FILE_OK")) return UUFILE_OK; 35 if (strEQ(name, "FILE_OK")) return UUFILE_OK;
35 if (strEQ(name, "FILE_READ")) return UUFILE_READ; 36 if (strEQ(name, "FILE_READ")) return UUFILE_READ;
36 if (strEQ(name, "FILE_TMPFILE")) return UUFILE_TMPFILE; 37 if (strEQ(name, "FILE_TMPFILE")) return UUFILE_TMPFILE;
37 break; 38 break;
38 case 'M': 39 case 'M':
39 if (strEQ(name, "MSG_ERROR")) return UUMSG_ERROR; 40 if (strEQ(name, "MSG_ERROR")) return UUMSG_ERROR;
40 if (strEQ(name, "MSG_FATAL")) return UUMSG_FATAL; 41 if (strEQ(name, "MSG_FATAL")) return UUMSG_FATAL;
41 if (strEQ(name, "MSG_MESSAGE")) return UUMSG_MESSAGE; 42 if (strEQ(name, "MSG_MESSAGE")) return UUMSG_MESSAGE;
42 if (strEQ(name, "MSG_NOTE")) return UUMSG_NOTE; 43 if (strEQ(name, "MSG_NOTE")) return UUMSG_NOTE;
43 if (strEQ(name, "MSG_PANIC")) return UUMSG_PANIC; 44 if (strEQ(name, "MSG_PANIC")) return UUMSG_PANIC;
44 if (strEQ(name, "MSG_WARNING")) return UUMSG_WARNING; 45 if (strEQ(name, "MSG_WARNING")) return UUMSG_WARNING;
45 case 'O': 46 case 'O':
47 if (strEQ(name, "OPT_VERSION")) return UUOPT_VERSION;
48 if (strEQ(name, "OPT_FAST")) return UUOPT_FAST;
49 if (strEQ(name, "OPT_DUMBNESS")) return UUOPT_DUMBNESS;
46 if (strEQ(name, "OPT_BRACKPOL")) return UUOPT_BRACKPOL; 50 if (strEQ(name, "OPT_BRACKPOL")) return UUOPT_BRACKPOL;
47 if (strEQ(name, "OPT_DEBUG")) return UUOPT_DEBUG; 51 if (strEQ(name, "OPT_VERBOSE")) return UUOPT_VERBOSE;
48 if (strEQ(name, "OPT_DESPERATE")) return UUOPT_DESPERATE; 52 if (strEQ(name, "OPT_DESPERATE")) return UUOPT_DESPERATE;
49 if (strEQ(name, "OPT_DUMBNESS")) return UUOPT_DUMBNESS;
50 if (strEQ(name, "OPT_ENCEXT")) return UUOPT_ENCEXT;
51 if (strEQ(name, "OPT_ERRNO")) return UUOPT_ERRNO;
52 if (strEQ(name, "OPT_FAST")) return UUOPT_FAST;
53 if (strEQ(name, "OPT_IGNMODE")) return UUOPT_IGNMODE;
54 if (strEQ(name, "OPT_IGNREPLY")) return UUOPT_IGNREPLY; 53 if (strEQ(name, "OPT_IGNREPLY")) return UUOPT_IGNREPLY;
55 if (strEQ(name, "OPT_OVERWRITE")) return UUOPT_OVERWRITE; 54 if (strEQ(name, "OPT_OVERWRITE")) return UUOPT_OVERWRITE;
56 if (strEQ(name, "OPT_PREAMB")) return UUOPT_PREAMB;
57 if (strEQ(name, "OPT_PROGRESS")) return UUOPT_PROGRESS;
58 if (strEQ(name, "OPT_SAVEPATH")) return UUOPT_SAVEPATH; 55 if (strEQ(name, "OPT_SAVEPATH")) return UUOPT_SAVEPATH;
59 if (strEQ(name, "OPT_TINYB64")) return UUOPT_TINYB64; 56 if (strEQ(name, "OPT_IGNMODE")) return UUOPT_IGNMODE;
57 if (strEQ(name, "OPT_DEBUG")) return UUOPT_DEBUG;
58 if (strEQ(name, "OPT_ERRNO")) return UUOPT_ERRNO;
59 if (strEQ(name, "OPT_PROGRESS")) return UUOPT_PROGRESS;
60 if (strEQ(name, "OPT_USETEXT")) return UUOPT_USETEXT; 60 if (strEQ(name, "OPT_USETEXT")) return UUOPT_USETEXT;
61 if (strEQ(name, "OPT_VERBOSE")) return UUOPT_VERBOSE; 61 if (strEQ(name, "OPT_PREAMB")) return UUOPT_PREAMB;
62 if (strEQ(name, "OPT_TINYB64")) return UUOPT_TINYB64;
62 if (strEQ(name, "OPT_VERSION")) return UUOPT_VERSION; 63 if (strEQ(name, "OPT_ENCEXT")) return UUOPT_ENCEXT;
63 if (strEQ(name, "OPT_REMOVE")) return UUOPT_REMOVE; 64 if (strEQ(name, "OPT_REMOVE")) return UUOPT_REMOVE;
64 if (strEQ(name, "OPT_MOREMIME")) return UUOPT_MOREMIME; 65 if (strEQ(name, "OPT_MOREMIME")) return UUOPT_MOREMIME;
66 if (strEQ(name, "OPT_DOTDOT")) return UUOPT_DOTDOT;
67 if (strEQ(name, "OPT_RBUF")) return UUOPT_RBUF;
68 if (strEQ(name, "OPT_WBUF")) return UUOPT_WBUF;
69 if (strEQ(name, "OPT_AUTOCHECK")) return UUOPT_AUTOCHECK;
65 case 'R': 70 case 'R':
66 if (strEQ(name, "RET_CANCEL")) return UURET_CANCEL; 71 if (strEQ(name, "RET_CANCEL")) return UURET_CANCEL;
67 if (strEQ(name, "RET_CONT")) return UURET_CONT; 72 if (strEQ(name, "RET_CONT")) return UURET_CONT;
68 if (strEQ(name, "RET_EXISTS")) return UURET_EXISTS; 73 if (strEQ(name, "RET_EXISTS")) return UURET_EXISTS;
69 if (strEQ(name, "RET_ILLVAL")) return UURET_ILLVAL; 74 if (strEQ(name, "RET_ILLVAL")) return UURET_ILLVAL;
70 if (strEQ(name, "RET_IOERR")) return UURET_IOERR; 75 if (strEQ(name, "RET_IOERR")) return UURET_IOERR;
71 if (strEQ(name, "RET_NODATA")) return UURET_NODATA; 76 if (strEQ(name, "RET_NODATA")) return UURET_NODATA;
72 if (strEQ(name, "RET_NOEND")) return UURET_NOEND; 77 if (strEQ(name, "RET_NOEND")) return UURET_NOEND;
73 if (strEQ(name, "RET_NOMEM")) return UURET_NOMEM; 78 if (strEQ(name, "RET_NOMEM")) return UURET_NOMEM;
74 if (strEQ(name, "RET_OK")) return UURET_OK; 79 if (strEQ(name, "RET_OK")) return UURET_OK;
75 if (strEQ(name, "RET_UNSUP")) return UURET_UNSUP; 80 if (strEQ(name, "RET_UNSUP")) return UURET_UNSUP;
76 case 'B': 81 case 'B':
77 if (strEQ(name, "B64ENCODED")) return B64ENCODED; 82 if (strEQ(name, "B64_ENCODED")) return B64ENCODED;
78 if (strEQ(name, "BH_ENCODED")) return BH_ENCODED; 83 if (strEQ(name, "BH_ENCODED")) return BH_ENCODED;
79 case 'P': 84 case 'P':
80 if (strEQ(name, "PT_ENCODED")) return PT_ENCODED; 85 if (strEQ(name, "PT_ENCODED")) return PT_ENCODED;
81 case 'Q': 86 case 'Q':
82 if (strEQ(name, "QP_ENCODED")) return QP_ENCODED; 87 if (strEQ(name, "QP_ENCODED")) return QP_ENCODED;
83 case 'U': 88 case 'U':
84 if (strEQ(name, "UU_ENCODED")) return UU_ENCODED; 89 if (strEQ(name, "UU_ENCODED")) return UU_ENCODED;
85 case 'X': 90 case 'X':
86 if (strEQ(name, "XX_ENCODED")) return XX_ENCODED; 91 if (strEQ(name, "XX_ENCODED")) return XX_ENCODED;
92 case 'Y':
93 if (strEQ(name, "YENC_ENCODED")) return YENC_ENCODED;
87 } 94 }
95
88 errno = EINVAL; 96 errno = EINVAL;
89 return 0; 97 return 0;
90} 98}
91 99
100static void
92static void uu_msg_callback (void *cb, char *msg, int level) 101uu_msg_callback (void *cb, char *msg, int level)
93{ 102{
94 dSP; 103 dSP;
95 104
96 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,2); 105 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 2);
97 106
98 PUSHs(sv_2mortal(newSVpv(msg,0))); 107 PUSHs (sv_2mortal (newSVpv (msg, 0)));
99 PUSHs(sv_2mortal(newSViv(level))); 108 PUSHs (sv_2mortal (newSViv (level)));
100 109
101 PUTBACK; (void) perl_call_sv ((SV *)cb, G_VOID|G_DISCARD); SPAGAIN; 110 PUTBACK; (void) perl_call_sv ((SV *)cb, G_VOID|G_DISCARD); SPAGAIN;
102 PUTBACK; FREETMPS; LEAVE; 111 PUTBACK; FREETMPS; LEAVE;
103} 112}
104 113
114static int
105static int uu_busy_callback (void *cb, uuprogress *uup) 115uu_busy_callback (void *cb, uuprogress *uup)
106{ 116{
107 dSP; 117 dSP;
108 int count; 118 int count;
109 int retval; 119 int retval;
110 120
111 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,6); 121 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 6);
112 122
113 PUSHs(sv_2mortal(newSViv(uup->action))); 123 PUSHs (sv_2mortal (newSViv (uup->action)));
114 PUSHs(sv_2mortal(newSVpv(uup->curfile,0))); 124 PUSHs (sv_2mortal (newSVpv (uup->curfile, 0)));
115 PUSHs(sv_2mortal(newSViv(uup->partno))); 125 PUSHs (sv_2mortal (newSViv (uup->partno)));
116 PUSHs(sv_2mortal(newSViv(uup->numparts))); 126 PUSHs (sv_2mortal (newSViv (uup->numparts)));
117 PUSHs(sv_2mortal(newSViv(uup->fsize))); 127 PUSHs (sv_2mortal (newSViv (uup->fsize)));
118 PUSHs(sv_2mortal(newSViv(uup->percent))); 128 PUSHs (sv_2mortal (newSViv (uup->percent)));
119 129
120 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 130 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
121 131
122 if (count != 1) 132 if (count != 1)
123 croak ("busycallback perl callback returned more than one argument"); 133 croak ("busycallback perl callback returned more than one argument");
127 PUTBACK; FREETMPS; LEAVE; 137 PUTBACK; FREETMPS; LEAVE;
128 138
129 return retval; 139 return retval;
130} 140}
131 141
142static char *
132static char *uu_fnamefilter_callback (void *cb, char *fname) 143uu_fnamefilter_callback (void *cb, char *fname)
133{ 144{
134 dSP; 145 dSP;
135 int count; 146 int count;
136 static char *str; 147 static char *str;
137 148
138 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,1); 149 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 1);
139 150
140 PUSHs(sv_2mortal(newSVpv(fname,0))); 151 PUSHs (sv_2mortal (newSVpv (fname, 0)));
141 152
142 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 153 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
143 154
144 if (count != 1) 155 if (count != 1)
145 croak ("fnamefilter perl callback returned more than one argument"); 156 croak ("fnamefilter perl callback MUST return a single filename exactly");
146 157
147 FP_free(str); str = FP_strdup (POPp); 158 _FP_free (str); str = _FP_strdup (SvPV_nolen (TOPs));
148 159
149 PUTBACK; FREETMPS; LEAVE; 160 PUTBACK; FREETMPS; LEAVE;
150 161
151 return str; 162 return str;
152} 163}
153 164
165static int
154static int uu_file_callback (void *cb, char *id, char *fname, int retrieve) 166uu_file_callback (void *cb, char *id, char *fname, int retrieve)
155{ 167{
156 dSP; 168 dSP;
157 int count; 169 int count;
158 int retval; 170 int retval;
159 SV *xfname = newSVpv ("", 0); 171 SV *xfname = newSVpv ("", 0);
160 STRLEN dc; 172
161
162 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,3); 173 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 3);
163 174
164 PUSHs(sv_2mortal(newSVpv(id,0))); 175 PUSHs (sv_2mortal (newSVpv (id, 0)));
165 PUSHs(sv_2mortal(xfname)); 176 PUSHs (sv_2mortal (xfname));
166 PUSHs(sv_2mortal(newSViv(retrieve))); 177 PUSHs (sv_2mortal (newSViv (retrieve)));
167 178
168 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 179 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
169 180
170 if (count != 1) 181 if (count != 1)
171 croak ("filecallback perl callback returned more than one argument"); 182 croak ("filecallback perl callback must return a single return status");
172 183
173 strcpy (fname, SvPV (xfname, dc)); 184 strcpy (fname, SvPV_nolen (xfname));
174
175 retval = POPi; 185 retval = POPi;
176 186
177 PUTBACK; FREETMPS; LEAVE; 187 PUTBACK; FREETMPS; LEAVE;
178 188
179 return retval; 189 return retval;
180} 190}
181 191
192static char *
193uu_filename_callback (void *cb, char *subject, char *filename)
194{
195 dSP;
196 int count;
197
198 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 2);
199
200 PUSHs (sv_2mortal(newSVpv(subject, 0)));
201 PUSHs (filename ? sv_2mortal(newSVpv(filename, 0)) : &PL_sv_undef);
202
203 PUTBACK; count = perl_call_sv ((SV *)cb, G_ARRAY); SPAGAIN;
204
205 if (count > 1)
206 croak ("filenamecallback perl callback must return nothing or a single filename");
207
208 if (count)
209 {
210 _FP_free (filename);
211
212 filename = SvOK (TOPs)
213 ? _FP_strdup (SvPV_nolen (TOPs))
214 : 0;
215 }
216
217 PUTBACK; FREETMPS; LEAVE;
218
219 return filename;
220}
221
182static SV *uu_msg_sv, *uu_busy_sv, *uu_file_sv, *uu_fnamefilter_sv; 222static SV *uu_msg_sv, *uu_busy_sv, *uu_file_sv, *uu_fnamefilter_sv, *uu_filename_sv;
183 223
184#define FUNC_CB(cb) (void *)(sv_setsv (cb ## _sv, func), cb ## _sv), func ? cb ## _callback : NULL 224#define FUNC_CB(cb) (void *)(sv_setsv (cb ## _sv, func), cb ## _sv), func ? cb ## _callback : NULL
185 225
226static int
186static int uu_info_file(void *cb, char *info) 227uu_info_file (void *cb, char *info)
187{ 228{
188 dSP; 229 dSP;
189 int count; 230 int count;
190 int retval; 231 int retval;
191 232
192 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,1); 233 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,1);
193 234
194 PUSHs(sv_2mortal(newSVpv(info,0))); 235 PUSHs(sv_2mortal(newSVpv(info,0)));
195 236
196 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 237 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
224MODULE = Convert::UUlib PACKAGE = Convert::UUlib PREFIX = UU 265MODULE = Convert::UUlib PACKAGE = Convert::UUlib PREFIX = UU
225 266
226PROTOTYPES: ENABLE 267PROTOTYPES: ENABLE
227 268
228int 269int
229constant(name) 270constant (name)
230 char * name 271 char * name
231 272
232 273
233void 274void
234UUInitialize() 275UUInitialize ()
235 CODE: 276 CODE:
236 if (!uu_initialized) 277 if (!uu_initialized)
237 { 278 {
238 int retval; 279 int retval;
239 280
240 if ((retval = UUInitialize ()) != UURET_OK) 281 if ((retval = UUInitialize ()) != UURET_OK)
241 croak ("unable to initialize uudeview library (%s)", UUstrerror (retval)); 282 croak ("unable to initialize uudeview library (%s)", UUstrerror (retval));
242 283
243 uu_initialized = 1; 284 uu_initialized = 1;
244 } 285 }
245 286
246void 287void
247UUCleanUp() 288UUCleanUp ()
248 CODE: 289 CODE:
249 if (uu_initialized) 290 if (uu_initialized)
250 UUCleanUp (); 291 UUCleanUp ();
251 292
252 uu_initialized = 0; 293 uu_initialized = 0;
253 294
254SV * 295SV *
255UUGetOption(opt) 296UUGetOption (opt)
256 int opt 297 int opt
257 CODE: 298 CODE:
258 { 299{
259 if (opt == UUOPT_PROGRESS) 300 if (opt == UUOPT_PROGRESS)
260 croak ("GetOption(UUOPT_PROGRESS) is not yet implemented"); 301 croak ("GetOption(UUOPT_PROGRESS) is not yet implemented");
261 else if (uu_opt_isstring (opt)) 302 else if (uu_opt_isstring (opt))
262 { 303 {
263 char cval[8192]; 304 char cval[8192];
264 305
265 UUGetOption (opt, 0, cval, sizeof cval); 306 UUGetOption (opt, 0, cval, sizeof cval);
266 RETVAL = newSVpv (cval, 0); 307 RETVAL = newSVpv (cval, 0);
267 } 308 }
268 else 309 else
269 { 310 {
270 RETVAL = newSViv (UUGetOption (opt, 0, 0, 0)); 311 RETVAL = newSViv (UUGetOption (opt, 0, 0, 0));
271 } 312 }
272 } 313}
273 OUTPUT: 314 OUTPUT:
274 RETVAL 315 RETVAL
275 316
276int 317int
277UUSetOption(opt,val) 318UUSetOption (opt, val)
278 int opt 319 int opt
279 SV * val 320 SV * val
280 CODE: 321 CODE:
281 { 322{
282 STRLEN dc; 323 STRLEN dc;
283 324
284 if (uu_opt_isstring (opt)) 325 if (uu_opt_isstring (opt))
285 RETVAL = UUSetOption (opt, 0, SvPV (val, dc)); 326 RETVAL = UUSetOption (opt, 0, SvPV (val, dc));
286 else 327 else
287 RETVAL = UUSetOption (opt, SvIV (val), (void *)0); 328 RETVAL = UUSetOption (opt, SvIV (val), (void *)0);
288 } 329}
289 OUTPUT: 330 OUTPUT:
290 RETVAL 331 RETVAL
291 332
292char * 333char *
293UUstrerror(errcode) 334UUstrerror (errcode)
294 int errcode 335 int errcode
295 336
296void 337void
297UUSetMsgCallback(func=0) 338UUSetMsgCallback (func = 0)
298 SV * func 339 SV * func
299 CODE: 340 CODE:
300 UUSetMsgCallback (FUNC_CB(uu_msg)); 341 UUSetMsgCallback (FUNC_CB (uu_msg));
301 342
302void 343void
303UUSetBusyCallback(func=0,msecs=1000) 344UUSetBusyCallback (func = 0,msecs = 1000)
304 SV * func 345 SV * func
305 long msecs 346 long msecs
306 CODE: 347 CODE:
307 UUSetBusyCallback (FUNC_CB(uu_busy), msecs); 348 UUSetBusyCallback (FUNC_CB (uu_busy), msecs);
308 349
309void 350void
310UUSetFileCallback(func=0) 351UUSetFileCallback (func = 0)
311 SV * func 352 SV * func
312 CODE: 353 CODE:
313 UUSetFileCallback (FUNC_CB(uu_file)); 354 UUSetFileCallback (FUNC_CB (uu_file));
314 355
315void 356void
316UUSetFNameFilter(func=0) 357UUSetFNameFilter (func = 0)
317 SV * func 358 SV * func
318 CODE: 359 CODE:
319 UUSetFNameFilter (FUNC_CB(uu_fnamefilter)); 360 UUSetFNameFilter (FUNC_CB (uu_fnamefilter));
361
362void
363UUSetFileNameCallback (func = 0)
364 SV * func
365 CODE:
366 UUSetFileNameCallback (FUNC_CB (uu_filename));
320 367
321char * 368char *
322UUFNameFilter(fname) 369UUFNameFilter (fname)
323 char * fname 370 char * fname
324 371
325void 372void
326UULoadFile(fname,id=0,delflag=0) 373UULoadFile (fname, id = 0, delflag = 0, partno = -1)
327 char * fname 374 char * fname
328 char * id 375 char * id
329 int delflag 376 int delflag
377 int partno
330 PPCODE: 378 PPCODE:
331 { 379{
332 int count; 380 int count;
333 381
334 XPUSHs(sv_2mortal(newSViv(UULoadFile (fname, id, delflag, &count)))); 382 XPUSHs (sv_2mortal (newSViv (UULoadFileWithPartNo (fname, id, delflag, partno, &count))));
335 if (GIMME_V == G_ARRAY) 383 if (GIMME_V == G_ARRAY)
336 XPUSHs(sv_2mortal(newSViv(count))); 384 XPUSHs (sv_2mortal (newSViv (count)));
337 } 385}
338 386
339int 387int
340UUSmerge(pass) 388UUSmerge (pass)
341 int pass 389 int pass
342 390
343int 391int
344UUQuickDecode(datain,dataout,boundary,maxpos) 392UUQuickDecode(datain,dataout,boundary,maxpos)
345 FILE * datain 393 FILE * datain
415 char * from 463 char * from
416 char * subject 464 char * subject
417 int isemail 465 int isemail
418 466
419uulist * 467uulist *
420UUGetFileListItem(num) 468UUGetFileListItem (num)
421 int num 469 int num
422 470
471MODULE = Convert::UUlib PACKAGE = Convert::UUlib::Item
472
423int 473int
424UURenameFile(item,newname) 474rename (item, newname)
425 uulist *item 475 uulist *item
426 char * newname 476 char * newname
427 ALIAS: 477 CODE:
428 Convert::UUlib::Item::rename = 1 478 RETVAL = UURenameFile (item, newname);
479 OUTPUT:
480 RETVAL
429 481
430int 482int
431UUDecodeToTemp(item) 483decode_temp (item)
432 uulist *item 484 uulist *item
433 ALIAS: 485 CODE:
434 Convert::UUlib::Item::decode_temp = 1 486 RETVAL = UUDecodeToTemp (item);
487 OUTPUT:
488 RETVAL
435 489
436int 490int
437UURemoveTemp(item) 491remove_temp (item)
438 uulist *item 492 uulist *item
439 ALIAS: 493 CODE:
440 Convert::UUlib::Item::remove_temp = 1 494 RETVAL = UURemoveTemp (item);
495 OUTPUT:
496 RETVAL
441 497
442int 498int
443UUDecodeFile(item,target=0) 499decode (item, target = 0)
444 uulist *item 500 uulist *item
445 char * target 501 char * target
446 ALIAS: 502 CODE:
447 Convert::UUlib::Item::decode = 1 503 RETVAL = UUDecodeFile (item, target);
504 OUTPUT:
505 RETVAL
448 506
449void 507void
450UUInfoFile(item,func) 508info (item, func)
451 uulist *item 509 uulist *item
452 SV * func 510 SV * func
453 CODE: 511 CODE:
454 UUInfoFile(item,(void *)func,uu_info_file); 512 UUInfoFile (item,(void *)func, uu_info_file);
455 ALIAS:
456 Convert::UUlib::Item::info = 1
457
458MODULE = Convert::UUlib PACKAGE = Convert::UUlib::Item
459 513
460short 514short
461state(li) 515state(li)
462 uulist *li 516 uulist *li
463 CODE: 517 CODE:
491 RETVAL = li->size; 545 RETVAL = li->size;
492 OUTPUT: 546 OUTPUT:
493 RETVAL 547 RETVAL
494 548
495char * 549char *
496filename(li,newfilename=0) 550filename (li, newfilename = 0)
497 uulist *li 551 uulist *li
498 char * newfilename 552 char * newfilename
499 CODE: 553 CODE:
500 if (newfilename) 554 if (newfilename)
501 { 555 {
502 FP_free (li->filename); 556 _FP_free (li->filename);
503 li->filename = FP_strdup (newfilename); 557 li->filename = _FP_strdup (newfilename);
504 } 558 }
505 RETVAL = li->filename; 559 RETVAL = li->filename;
506 OUTPUT: 560 OUTPUT:
507 RETVAL 561 RETVAL
508 562
509char * 563char *
510subfname(li) 564subfname (li)
511 uulist *li 565 uulist *li
512 CODE: 566 CODE:
513 RETVAL = li->subfname; 567 RETVAL = li->subfname;
514 OUTPUT: 568 OUTPUT:
515 RETVAL 569 RETVAL
516 570
517char * 571char *
518mimeid(li) 572mimeid (li)
519 uulist *li 573 uulist *li
520 CODE: 574 CODE:
521 RETVAL = li->mimeid; 575 RETVAL = li->mimeid;
522 OUTPUT: 576 OUTPUT:
523 RETVAL 577 RETVAL
524 578
525char * 579char *
526mimetype(li) 580mimetype (li)
527 uulist *li 581 uulist *li
528 CODE: 582 CODE:
529 RETVAL = li->mimetype; 583 RETVAL = li->mimetype;
530 OUTPUT: 584 OUTPUT:
531 RETVAL 585 RETVAL
532 586
533char * 587char *
534binfile(li) 588binfile (li)
535 uulist *li 589 uulist *li
536 CODE: 590 CODE:
537 RETVAL = li->binfile; 591 RETVAL = li->binfile;
538 OUTPUT: 592 OUTPUT:
539 RETVAL 593 RETVAL
540 594
541# functions accessing internal data(!) 595# methods accessing internal data(!)
542 596
543void 597void
544parts(li) 598parts (li)
545 uulist *li 599 uulist *li
546 PPCODE: 600 PPCODE:
547 { 601{
548 struct _uufile *p = li->thisfile; 602 struct _uufile *p = li->thisfile;
549 603
550 while (p) 604 while (p)
551 { 605 {
552 HV *pi = newHV (); 606 HV *pi = newHV ();
553 607
554 hv_store (pi, "partno" , 6, newSViv (p->partno) , 0); 608 hv_store (pi, "partno" , 6, newSViv (p->partno) , 0);
555 609
556 if (p->filename) 610 if (p->filename)
557 hv_store (pi, "filename", 8, newSVpv (p->filename, 0) , 0); 611 hv_store (pi, "filename", 8, newSVpv (p->filename, 0) , 0);
558 if(p->subfname) 612 if(p->subfname)
559 hv_store (pi, "subfname", 8, newSVpv (p->subfname, 0) , 0); 613 hv_store (pi, "subfname", 8, newSVpv (p->subfname, 0) , 0);
560 if(p->mimeid) 614 if(p->mimeid)
561 hv_store (pi, "mimeid" , 6, newSVpv (p->mimeid , 0) , 0); 615 hv_store (pi, "mimeid" , 6, newSVpv (p->mimeid , 0) , 0);
562 if(p->mimetype) 616 if(p->mimetype)
563 hv_store (pi, "mimetype", 8, newSVpv (p->mimetype, 0) , 0); 617 hv_store (pi, "mimetype", 8, newSVpv (p->mimetype, 0) , 0);
564 if (p->data->subject) 618 if (p->data->subject)
565 hv_store (pi, "subject" , 7, newSVpv (p->data->subject,0), 0); 619 hv_store (pi, "subject" , 7, newSVpv (p->data->subject,0), 0);
566 if (p->data->origin) 620 if (p->data->origin)
567 hv_store (pi, "origin" , 6, newSVpv (p->data->origin ,0), 0); 621 hv_store (pi, "origin" , 6, newSVpv (p->data->origin ,0), 0);
568 if (p->data->sfname) 622 if (p->data->sfname)
569 hv_store (pi, "sfname" , 6, newSVpv (p->data->sfname ,0), 0); 623 hv_store (pi, "sfname" , 6, newSVpv (p->data->sfname ,0), 0);
570 624
571 XPUSHs (sv_2mortal (newRV_noinc ((SV *)pi))); 625 XPUSHs (sv_2mortal (newRV_noinc ((SV *)pi)));
572 626
573 p = p->NEXT; 627 p = p->NEXT;
574 }
575 } 628 }
629}
576 630
577BOOT: 631BOOT:
578uu_msg_sv = newSVsv(&PL_sv_undef); 632 uu_msg_sv = newSVsv (&PL_sv_undef);
579uu_busy_sv = newSVsv(&PL_sv_undef); 633 uu_busy_sv = newSVsv (&PL_sv_undef);
580uu_file_sv = newSVsv(&PL_sv_undef); 634 uu_file_sv = newSVsv (&PL_sv_undef);
581uu_fnamefilter_sv = newSVsv(&PL_sv_undef); 635 uu_fnamefilter_sv = newSVsv (&PL_sv_undef);
636 uu_filename_sv = newSVsv (&PL_sv_undef);
582 637

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines