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.17 by root, Fri Feb 28 06:57:25 2020 UTC vs.
Revision 1.25 by root, Sat Sep 24 17:40:45 2022 UTC

4 4
5#include "perlmulticore.h" 5#include "perlmulticore.h"
6 6
7#include "uulib/fptools.h" 7#include "uulib/fptools.h"
8#include "uulib/uudeview.h" 8#include "uulib/uudeview.h"
9#include "uulib/uuint.h"
10 9
11static int released; 10static int perlinterp_released;
12 11
13#define RELEASE do { released = 1; perlinterp_release (); } while (0) 12#define RELEASE do { perlinterp_released = 1; perlinterp_release (); } while (0)
14#define ACQUIRE do { perlinterp_acquire (); released = 0; } while (0) 13#define ACQUIRE do { perlinterp_acquire (); perlinterp_released = 0; } while (0)
15 14
16#define TEMP_ACQUIRE if (released) perlinterp_acquire (); 15#define TEMP_ACQUIRE if (perlinterp_released) perlinterp_acquire ();
17#define TEMP_RELEASE if (released) perlinterp_release (); 16#define TEMP_RELEASE if (perlinterp_released) perlinterp_release ();
18
19static int
20not_here (char *s)
21{
22 croak("%s not implemented", s);
23 return -1;
24}
25
26static int
27constant (char *name)
28{
29 errno = 0;
30 switch (*name)
31 {
32 case 'A':
33 if (strEQ(name, "ACT_COPYING")) return UUACT_COPYING;
34 if (strEQ(name, "ACT_DECODING")) return UUACT_DECODING;
35 if (strEQ(name, "ACT_ENCODING")) return UUACT_ENCODING;
36 if (strEQ(name, "ACT_IDLE")) return UUACT_IDLE;
37 if (strEQ(name, "ACT_SCANNING")) return UUACT_SCANNING;
38 case 'F':
39 if (strEQ(name, "FILE_DECODED")) return UUFILE_DECODED;
40 if (strEQ(name, "FILE_ERROR")) return UUFILE_ERROR;
41 if (strEQ(name, "FILE_MISPART")) return UUFILE_MISPART;
42 if (strEQ(name, "FILE_NOBEGIN")) return UUFILE_NOBEGIN;
43 if (strEQ(name, "FILE_NODATA")) return UUFILE_NODATA;
44 if (strEQ(name, "FILE_NOEND")) return UUFILE_NOEND;
45 if (strEQ(name, "FILE_OK")) return UUFILE_OK;
46 if (strEQ(name, "FILE_READ")) return UUFILE_READ;
47 if (strEQ(name, "FILE_TMPFILE")) return UUFILE_TMPFILE;
48 break;
49 case 'M':
50 if (strEQ(name, "MSG_ERROR")) return UUMSG_ERROR;
51 if (strEQ(name, "MSG_FATAL")) return UUMSG_FATAL;
52 if (strEQ(name, "MSG_MESSAGE")) return UUMSG_MESSAGE;
53 if (strEQ(name, "MSG_NOTE")) return UUMSG_NOTE;
54 if (strEQ(name, "MSG_PANIC")) return UUMSG_PANIC;
55 if (strEQ(name, "MSG_WARNING")) return UUMSG_WARNING;
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;
60 if (strEQ(name, "OPT_BRACKPOL")) return UUOPT_BRACKPOL;
61 if (strEQ(name, "OPT_VERBOSE")) return UUOPT_VERBOSE;
62 if (strEQ(name, "OPT_DESPERATE")) return UUOPT_DESPERATE;
63 if (strEQ(name, "OPT_IGNREPLY")) return UUOPT_IGNREPLY;
64 if (strEQ(name, "OPT_OVERWRITE")) return UUOPT_OVERWRITE;
65 if (strEQ(name, "OPT_SAVEPATH")) return UUOPT_SAVEPATH;
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;
70 if (strEQ(name, "OPT_USETEXT")) return UUOPT_USETEXT;
71 if (strEQ(name, "OPT_PREAMB")) return UUOPT_PREAMB;
72 if (strEQ(name, "OPT_TINYB64")) return UUOPT_TINYB64;
73 if (strEQ(name, "OPT_ENCEXT")) return UUOPT_ENCEXT;
74 if (strEQ(name, "OPT_REMOVE")) return UUOPT_REMOVE;
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;
80 case 'R':
81 if (strEQ(name, "RET_CANCEL")) return UURET_CANCEL;
82 if (strEQ(name, "RET_CONT")) return UURET_CONT;
83 if (strEQ(name, "RET_EXISTS")) return UURET_EXISTS;
84 if (strEQ(name, "RET_ILLVAL")) return UURET_ILLVAL;
85 if (strEQ(name, "RET_IOERR")) return UURET_IOERR;
86 if (strEQ(name, "RET_NODATA")) return UURET_NODATA;
87 if (strEQ(name, "RET_NOEND")) return UURET_NOEND;
88 if (strEQ(name, "RET_NOMEM")) return UURET_NOMEM;
89 if (strEQ(name, "RET_OK")) return UURET_OK;
90 if (strEQ(name, "RET_UNSUP")) return UURET_UNSUP;
91 case 'B':
92 if (strEQ(name, "B64_ENCODED")) return B64ENCODED;
93 if (strEQ(name, "BH_ENCODED")) return BH_ENCODED;
94 case 'P':
95 if (strEQ(name, "PT_ENCODED")) return PT_ENCODED;
96 case 'Q':
97 if (strEQ(name, "QP_ENCODED")) return QP_ENCODED;
98 case 'U':
99 if (strEQ(name, "UU_ENCODED")) return UU_ENCODED;
100 case 'X':
101 if (strEQ(name, "XX_ENCODED")) return XX_ENCODED;
102 case 'Y':
103 if (strEQ(name, "YENC_ENCODED")) return YENC_ENCODED;
104 }
105
106 errno = EINVAL;
107 return 0;
108}
109 17
110static void 18static void
111uu_msg_callback (void *cb, char *msg, int level) 19uu_msg_callback (void *cb, char *msg, int level)
112{ 20{
113 TEMP_ACQUIRE { 21 TEMP_ACQUIRE {
114 22
115 dSP; 23 dSP;
116 24
117 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 2); 25 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 2);
118 26
119 PUSHs (sv_2mortal (newSVpv (msg, 0))); 27 PUSHs (sv_2mortal (newSVpv (msg, 0)));
120 PUSHs (sv_2mortal (newSViv (level))); 28 PUSHs (sv_2mortal (newSViv (level)));
121 29
122 PUTBACK; (void) perl_call_sv ((SV *)cb, G_VOID|G_DISCARD); SPAGAIN; 30 PUTBACK; (void) perl_call_sv ((SV *)cb, G_VOID|G_DISCARD); SPAGAIN;
123 PUTBACK; FREETMPS; LEAVE; 31 PUTBACK; FREETMPS; LEAVE;
124 32
125 } TEMP_RELEASE; 33 } TEMP_RELEASE;
126} 34}
127 35
128static int 36static int
130{ 38{
131 int retval; 39 int retval;
132 40
133 TEMP_ACQUIRE { 41 TEMP_ACQUIRE {
134 42
135 dSP; 43 dSP;
136 int count; 44 int count;
137 45
138 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 6); 46 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 6);
139 47
140 PUSHs (sv_2mortal (newSViv (uup->action))); 48 PUSHs (sv_2mortal (newSViv (uup->action)));
141 PUSHs (sv_2mortal (newSVpv (uup->curfile, 0))); 49 PUSHs (sv_2mortal (newSVpv (uup->curfile, 0)));
142 PUSHs (sv_2mortal (newSViv (uup->partno))); 50 PUSHs (sv_2mortal (newSViv (uup->partno)));
143 PUSHs (sv_2mortal (newSViv (uup->numparts))); 51 PUSHs (sv_2mortal (newSViv (uup->numparts)));
144 PUSHs (sv_2mortal (newSViv (uup->fsize))); 52 PUSHs (sv_2mortal (newSViv (uup->fsize)));
145 PUSHs (sv_2mortal (newSViv (uup->percent))); 53 PUSHs (sv_2mortal (newSViv (uup->percent)));
146 54
147 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 55 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
148 56
149 if (count != 1) 57 if (count != 1)
150 croak ("busycallback perl callback returned more than one argument"); 58 croak ("busycallback perl callback returned more than one argument");
151 59
152 retval = POPi; 60 retval = POPi;
153 61
154 PUTBACK; FREETMPS; LEAVE; 62 PUTBACK; FREETMPS; LEAVE;
155 63
156 } TEMP_RELEASE; 64 } TEMP_RELEASE;
157 65
158 return retval; 66 return retval;
159} 67}
163{ 71{
164 static char *str; 72 static char *str;
165 73
166 TEMP_ACQUIRE { 74 TEMP_ACQUIRE {
167 75
168 dSP; 76 dSP;
169 int count; 77 int count;
170 78
171 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 1); 79 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 1);
172 80
173 PUSHs (sv_2mortal (newSVpv (fname, 0))); 81 PUSHs (sv_2mortal (newSVpv (fname, 0)));
174 82
175 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 83 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
176 84
177 if (count != 1) 85 if (count != 1)
178 croak ("fnamefilter perl callback MUST return a single filename exactly"); 86 croak ("fnamefilter perl callback MUST return a single filename exactly");
179 87
180 _FP_free (str); str = _FP_strdup (SvPV_nolen (TOPs)); 88 FP_free (str); str = FP_strdup (SvPV_nolen (TOPs));
181 89
182 PUTBACK; FREETMPS; LEAVE; 90 PUTBACK; FREETMPS; LEAVE;
183 91
184 } TEMP_RELEASE; 92 } TEMP_RELEASE;
185 93
186 return str; 94 return str;
187} 95}
191{ 99{
192 int retval; 100 int retval;
193 101
194 TEMP_ACQUIRE { 102 TEMP_ACQUIRE {
195 103
196 dSP; 104 dSP;
197 int count; 105 int count;
198 SV *xfname = newSVpv ("", 0); 106 SV *xfname = newSVpv ("", 0);
199 107
200 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 3); 108 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 3);
201 109
202 PUSHs (sv_2mortal (newSVpv (id, 0))); 110 PUSHs (sv_2mortal (newSVpv (id, 0)));
203 PUSHs (sv_2mortal (xfname)); 111 PUSHs (sv_2mortal (xfname));
204 PUSHs (sv_2mortal (newSViv (retrieve))); 112 PUSHs (sv_2mortal (newSViv (retrieve)));
205 113
206 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 114 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
207 115
208 if (count != 1) 116 if (count != 1)
209 croak ("filecallback perl callback must return a single return status"); 117 croak ("filecallback perl callback must return a single return status");
210 118
211 strcpy (fname, SvPV_nolen (xfname)); 119 strcpy (fname, SvPV_nolen (xfname));
212 retval = POPi; 120 retval = POPi;
213 121
214 PUTBACK; FREETMPS; LEAVE; 122 PUTBACK; FREETMPS; LEAVE;
215 123
216 } TEMP_RELEASE; 124 } TEMP_RELEASE;
217 125
218 return retval; 126 return retval;
219} 127}
221static char * 129static char *
222uu_filename_callback (void *cb, char *subject, char *filename) 130uu_filename_callback (void *cb, char *subject, char *filename)
223{ 131{
224 TEMP_ACQUIRE { 132 TEMP_ACQUIRE {
225 133
226 dSP; 134 dSP;
227 int count; 135 int count;
228 136
229 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 2); 137 ENTER; SAVETMPS; PUSHMARK (SP); EXTEND (SP, 2);
230 138
231 PUSHs (sv_2mortal(newSVpv(subject, 0))); 139 PUSHs (sv_2mortal (newSVpv (subject, 0)));
232 PUSHs (filename ? sv_2mortal(newSVpv(filename, 0)) : &PL_sv_undef); 140 PUSHs (filename ? sv_2mortal (newSVpv (filename, 0)) : &PL_sv_undef);
233 141
234 PUTBACK; count = perl_call_sv ((SV *)cb, G_ARRAY); SPAGAIN; 142 PUTBACK; count = perl_call_sv ((SV *)cb, G_ARRAY); SPAGAIN;
235 143
236 if (count > 1) 144 if (count > 1)
237 croak ("filenamecallback perl callback must return nothing or a single filename"); 145 croak ("filenamecallback perl callback must return nothing or a single filename");
238 146
239 if (count) 147 if (count)
240 { 148 {
241 _FP_free (filename); 149 FP_free (filename);
242 150
243 filename = SvOK (TOPs) 151 filename = SvOK (TOPs)
244 ? _FP_strdup (SvPV_nolen (TOPs)) 152 ? FP_strdup (SvPV_nolen (TOPs))
245 : 0; 153 : 0;
246 } 154 }
247 155
248 PUTBACK; FREETMPS; LEAVE; 156 PUTBACK; FREETMPS; LEAVE;
249 157
250 } TEMP_RELEASE; 158 } TEMP_RELEASE;
251 159
252 return filename; 160 return filename;
253} 161}
261{ 169{
262 int retval; 170 int retval;
263 171
264 TEMP_ACQUIRE { 172 TEMP_ACQUIRE {
265 173
266 dSP; 174 dSP;
267 int count; 175 int count;
268 176
269 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,1); 177 ENTER; SAVETMPS; PUSHMARK(SP); EXTEND(SP,1);
270 178
271 PUSHs(sv_2mortal(newSVpv(info,0))); 179 PUSHs(sv_2mortal(newSVpv(info,0)));
272 180
273 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN; 181 PUTBACK; count = perl_call_sv ((SV *)cb, G_SCALAR); SPAGAIN;
274 182
275 if (count != 1) 183 if (count != 1)
276 croak ("info_file perl callback returned more than one argument"); 184 croak ("info_file perl callback returned more than one argument");
277 185
278 retval = POPi; 186 retval = POPi;
279 187
280 PUTBACK; FREETMPS; LEAVE; 188 PUTBACK; FREETMPS; LEAVE;
281 189
282 } TEMP_RELEASE; 190 } TEMP_RELEASE;
283 191
284 return retval; 192 return retval;
285} 193}
296 default: 204 default:
297 return 0; 205 return 0;
298 } 206 }
299} 207}
300 208
301static int uu_initialized; 209static void
210initialise (void)
211{
212 int retval = UUInitialize ();
213
214 if (retval != UURET_OK)
215 croak ("unable to initialize uudeview library (%s)", UUstrerror (retval));
216}
302 217
303MODULE = Convert::UUlib PACKAGE = Convert::UUlib PREFIX = UU 218MODULE = Convert::UUlib PACKAGE = Convert::UUlib PREFIX = UU
304 219
305PROTOTYPES: ENABLE 220PROTOTYPES: ENABLE
306
307int
308constant (name)
309 char * name
310
311
312void
313UUInitialize ()
314 CODE:
315 if (!uu_initialized)
316 {
317 int retval;
318
319 if ((retval = UUInitialize ()) != UURET_OK)
320 croak ("unable to initialize uudeview library (%s)", UUstrerror (retval));
321
322 uu_initialized = 1;
323 }
324 221
325void 222void
326UUCleanUp () 223UUCleanUp ()
327 CODE: 224 CODE:
328 if (uu_initialized)
329 UUCleanUp (); 225 UUCleanUp ();
330 226 initialise ();
331 uu_initialized = 0;
332 227
333SV * 228SV *
334UUGetOption (opt) 229UUGetOption (opt)
335 int opt 230 int opt
336 CODE: 231 CODE:
447 char * outfname 342 char * outfname
448 char * mimetype 343 char * mimetype
449 int filemode 344 int filemode
450 345
451int 346int
452UUEncodePartial(outfile,infile,infname,encoding,outfname,mimetype,filemode,partno,linperfile) 347UUEncodePartial(outfile,infile,infname,encoding,outfname,mimetype,filemode,partno,linperfile,crc)
453 FILE * outfile 348 FILE * outfile
454 FILE * infile 349 FILE * infile
455 char * infname 350 char * infname
456 int encoding 351 int encoding
457 char * outfname 352 char * outfname
458 char * mimetype 353 char * mimetype
459 int filemode 354 int filemode
460 int partno 355 int partno
461 long linperfile 356 long linperfile
357 U32 &crc
358 OUTPUT:
359 RETVAL
360 crc
462 361
463int 362int
464UUEncodeToStream(outfile,infile,infname,encoding,outfname,filemode) 363UUEncodeToStream(outfile,infile,infname,encoding,outfname,filemode)
465 FILE * outfile 364 FILE * outfile
466 FILE * infile 365 FILE * infile
509 408
510uulist * 409uulist *
511UUGetFileListItem (num) 410UUGetFileListItem (num)
512 int num 411 int num
513 412
413void
414GetFileList ()
415 PPCODE:
416{
417 uulist *iter;
418
419 for (iter = UUGlobalFileList; iter; iter = iter->NEXT)
420 XPUSHs (sv_setref_pv (sv_newmortal (), "Convert::UUlib::Item", iter));
421}
422
514MODULE = Convert::UUlib PACKAGE = Convert::UUlib::Item 423MODULE = Convert::UUlib PACKAGE = Convert::UUlib::Item
515 424
516int 425int
517rename (item, newname) 426rename (item, newname)
518 uulist *item 427 uulist *item
602 uulist *li 511 uulist *li
603 char * newfilename 512 char * newfilename
604 CODE: 513 CODE:
605 if (newfilename) 514 if (newfilename)
606 { 515 {
607 _FP_free (li->filename); 516 FP_free (li->filename);
608 li->filename = _FP_strdup (newfilename); 517 li->filename = FP_strdup (newfilename);
609 } 518 }
610 RETVAL = li->filename; 519 RETVAL = li->filename;
611 OUTPUT: 520 OUTPUT:
612 RETVAL 521 RETVAL
613 522
654 563
655 while (p) 564 while (p)
656 { 565 {
657 HV *pi = newHV (); 566 HV *pi = newHV ();
658 567
659 hv_store (pi, "partno" , 6, newSViv (p->partno) , 0); 568 hv_store (pi, "partno" , 6, newSViv (p->partno) , 0);
660
661 if (p->filename)
662 hv_store (pi, "filename", 8, newSVpv (p->filename, 0) , 0); 569 if (p->filename ) hv_store (pi, "filename", 8, newSVpv (p->filename, 0) , 0);
663 if(p->subfname)
664 hv_store (pi, "subfname", 8, newSVpv (p->subfname, 0) , 0); 570 if (p->subfname ) hv_store (pi, "subfname", 8, newSVpv (p->subfname, 0) , 0);
665 if(p->mimeid) 571 if (p->mimeid ) hv_store (pi, "mimeid" , 6, newSVpv (p->mimeid , 0) , 0);
666 hv_store (pi, "mimeid" , 6, newSVpv (p->mimeid , 0) , 0);
667 if(p->mimetype)
668 hv_store (pi, "mimetype", 8, newSVpv (p->mimetype, 0) , 0); 572 if (p->mimetype ) hv_store (pi, "mimetype", 8, newSVpv (p->mimetype, 0) , 0);
669 if (p->data->subject)
670 hv_store (pi, "subject" , 7, newSVpv (p->data->subject,0), 0); 573 if (p->data->subject) hv_store (pi, "subject" , 7, newSVpv (p->data->subject,0), 0);
671 if (p->data->origin) 574 if (p->data->origin ) hv_store (pi, "origin" , 6, newSVpv (p->data->origin ,0), 0);
672 hv_store (pi, "origin" , 6, newSVpv (p->data->origin ,0), 0); 575 if (p->data->sfname ) hv_store (pi, "sfname" , 6, newSVpv (p->data->sfname ,0), 0);
673 if (p->data->sfname)
674 hv_store (pi, "sfname" , 6, newSVpv (p->data->sfname ,0), 0);
675 576
676 XPUSHs (sv_2mortal (newRV_noinc ((SV *)pi))); 577 XPUSHs (sv_2mortal (newRV_noinc ((SV *)pi)));
677 578
678 p = p->NEXT; 579 p = p->NEXT;
679 } 580 }
680} 581}
681 582
682BOOT: 583BOOT:
584{
585 HV *stash = GvSTASH (CvGV (cv));
586
587 static const struct {
588 const char *name;
589 IV iv;
590 } *civ, const_iv[] = {
591# define const_iv(name, value) { # name, (IV) value },
592 const_iv (ACT_COPYING , UUACT_COPYING)
593 const_iv (ACT_DECODING , UUACT_DECODING)
594 const_iv (ACT_ENCODING , UUACT_ENCODING)
595 const_iv (ACT_IDLE , UUACT_IDLE)
596 const_iv (ACT_SCANNING , UUACT_SCANNING)
597 const_iv (FILE_DECODED , UUFILE_DECODED)
598 const_iv (FILE_ERROR , UUFILE_ERROR)
599 const_iv (FILE_MISPART , UUFILE_MISPART)
600 const_iv (FILE_NOBEGIN , UUFILE_NOBEGIN)
601 const_iv (FILE_NODATA , UUFILE_NODATA)
602 const_iv (FILE_NOEND , UUFILE_NOEND)
603 const_iv (FILE_OK , UUFILE_OK)
604 const_iv (FILE_READ , UUFILE_READ)
605 const_iv (FILE_TMPFILE , UUFILE_TMPFILE)
606 const_iv (MSG_ERROR , UUMSG_ERROR)
607 const_iv (MSG_FATAL , UUMSG_FATAL)
608 const_iv (MSG_MESSAGE , UUMSG_MESSAGE)
609 const_iv (MSG_NOTE , UUMSG_NOTE)
610 const_iv (MSG_PANIC , UUMSG_PANIC)
611 const_iv (MSG_WARNING , UUMSG_WARNING)
612 const_iv (OPT_VERSION , UUOPT_VERSION)
613 const_iv (OPT_FAST , UUOPT_FAST)
614 const_iv (OPT_DUMBNESS , UUOPT_DUMBNESS)
615 const_iv (OPT_BRACKPOL , UUOPT_BRACKPOL)
616 const_iv (OPT_VERBOSE , UUOPT_VERBOSE)
617 const_iv (OPT_DESPERATE, UUOPT_DESPERATE)
618 const_iv (OPT_IGNREPLY , UUOPT_IGNREPLY)
619 const_iv (OPT_OVERWRITE, UUOPT_OVERWRITE)
620 const_iv (OPT_SAVEPATH , UUOPT_SAVEPATH)
621 const_iv (OPT_IGNMODE , UUOPT_IGNMODE)
622 const_iv (OPT_DEBUG , UUOPT_DEBUG)
623 const_iv (OPT_ERRNO , UUOPT_ERRNO)
624 const_iv (OPT_PROGRESS , UUOPT_PROGRESS)
625 const_iv (OPT_USETEXT , UUOPT_USETEXT)
626 const_iv (OPT_PREAMB , UUOPT_PREAMB)
627 const_iv (OPT_TINYB64 , UUOPT_TINYB64)
628 const_iv (OPT_ENCEXT , UUOPT_ENCEXT)
629 const_iv (OPT_REMOVE , UUOPT_REMOVE)
630 const_iv (OPT_MOREMIME , UUOPT_MOREMIME)
631 const_iv (OPT_DOTDOT , UUOPT_DOTDOT)
632 const_iv (OPT_RBUF , UUOPT_RBUF)
633 const_iv (OPT_WBUF , UUOPT_WBUF)
634 const_iv (OPT_AUTOCHECK, UUOPT_AUTOCHECK)
635 const_iv (RET_CANCEL , UURET_CANCEL)
636 const_iv (RET_CONT , UURET_CONT)
637 const_iv (RET_EXISTS , UURET_EXISTS)
638 const_iv (RET_ILLVAL , UURET_ILLVAL)
639 const_iv (RET_IOERR , UURET_IOERR)
640 const_iv (RET_NODATA , UURET_NODATA)
641 const_iv (RET_NOEND , UURET_NOEND)
642 const_iv (RET_NOMEM , UURET_NOMEM)
643 const_iv (RET_OK , UURET_OK)
644 const_iv (RET_UNSUP , UURET_UNSUP)
645 const_iv (B64_ENCODED , B64ENCODED)
646 const_iv (BH_ENCODED , BH_ENCODED)
647 const_iv (PT_ENCODED , PT_ENCODED)
648 const_iv (QP_ENCODED , QP_ENCODED)
649 const_iv (UU_ENCODED , UU_ENCODED)
650 const_iv (XX_ENCODED , XX_ENCODED)
651 const_iv (YENC_ENCODED , YENC_ENCODED)
652 };
653
654 for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ > const_iv; civ--)
655 newCONSTSUB (stash, (char *)civ[-1].name, newSViv (civ[-1].iv));
656
683 uu_msg_sv = newSVsv (&PL_sv_undef); 657 uu_msg_sv = newSVsv (&PL_sv_undef);
684 uu_busy_sv = newSVsv (&PL_sv_undef); 658 uu_busy_sv = newSVsv (&PL_sv_undef);
685 uu_file_sv = newSVsv (&PL_sv_undef); 659 uu_file_sv = newSVsv (&PL_sv_undef);
686 uu_fnamefilter_sv = newSVsv (&PL_sv_undef); 660 uu_fnamefilter_sv = newSVsv (&PL_sv_undef);
687 uu_filename_sv = newSVsv (&PL_sv_undef); 661 uu_filename_sv = newSVsv (&PL_sv_undef);
688 662
663 initialise ();
664}
665

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines