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

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines