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.5 by root, Sun Mar 31 21:42:35 2002 UTC vs.
Revision 1.17 by root, Fri Feb 28 06:57:25 2020 UTC

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

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines