This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Added a failing test for a bareword parsing regression created in 984f9f66
[perl5.git] / op.c
1 /*    op.c
2  *
3  *    Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
4  *    2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008 by Larry Wall and others
5  *
6  *    You may distribute under the terms of either the GNU General Public
7  *    License or the Artistic License, as specified in the README file.
8  *
9  */
10
11 /*
12  * 'You see: Mr. Drogo, he married poor Miss Primula Brandybuck.  She was
13  *  our Mr. Bilbo's first cousin on the mother's side (her mother being the
14  *  youngest of the Old Took's daughters); and Mr. Drogo was his second
15  *  cousin.  So Mr. Frodo is his first *and* second cousin, once removed
16  *  either way, as the saying is, if you follow me.'       --the Gaffer
17  *
18  *     [p.23 of _The Lord of the Rings_, I/i: "A Long-Expected Party"]
19  */
20
21 /* This file contains the functions that create, manipulate and optimize
22  * the OP structures that hold a compiled perl program.
23  *
24  * A Perl program is compiled into a tree of OPs. Each op contains
25  * structural pointers (eg to its siblings and the next op in the
26  * execution sequence), a pointer to the function that would execute the
27  * op, plus any data specific to that op. For example, an OP_CONST op
28  * points to the pp_const() function and to an SV containing the constant
29  * value. When pp_const() is executed, its job is to push that SV onto the
30  * stack.
31  *
32  * OPs are mainly created by the newFOO() functions, which are mainly
33  * called from the parser (in perly.y) as the code is parsed. For example
34  * the Perl code $a + $b * $c would cause the equivalent of the following
35  * to be called (oversimplifying a bit):
36  *
37  *  newBINOP(OP_ADD, flags,
38  *      newSVREF($a),
39  *      newBINOP(OP_MULTIPLY, flags, newSVREF($b), newSVREF($c))
40  *  )
41  *
42  * Note that during the build of miniperl, a temporary copy of this file
43  * is made, called opmini.c.
44  */
45
46 /*
47 Perl's compiler is essentially a 3-pass compiler with interleaved phases:
48
49     A bottom-up pass
50     A top-down pass
51     An execution-order pass
52
53 The bottom-up pass is represented by all the "newOP" routines and
54 the ck_ routines.  The bottom-upness is actually driven by yacc.
55 So at the point that a ck_ routine fires, we have no idea what the
56 context is, either upward in the syntax tree, or either forward or
57 backward in the execution order.  (The bottom-up parser builds that
58 part of the execution order it knows about, but if you follow the "next"
59 links around, you'll find it's actually a closed loop through the
60 top level node.)
61
62 Whenever the bottom-up parser gets to a node that supplies context to
63 its components, it invokes that portion of the top-down pass that applies
64 to that part of the subtree (and marks the top node as processed, so
65 if a node further up supplies context, it doesn't have to take the
66 plunge again).  As a particular subcase of this, as the new node is
67 built, it takes all the closed execution loops of its subcomponents
68 and links them into a new closed loop for the higher level node.  But
69 it's still not the real execution order.
70
71 The actual execution order is not known till we get a grammar reduction
72 to a top-level unit like a subroutine or file that will be called by
73 "name" rather than via a "next" pointer.  At that point, we can call
74 into peep() to do that code's portion of the 3rd pass.  It has to be
75 recursive, but it's recursive on basic blocks, not on tree nodes.
76 */
77
78 /* To implement user lexical pragmas, there needs to be a way at run time to
79    get the compile time state of %^H for that block.  Storing %^H in every
80    block (or even COP) would be very expensive, so a different approach is
81    taken.  The (running) state of %^H is serialised into a tree of HE-like
82    structs.  Stores into %^H are chained onto the current leaf as a struct
83    refcounted_he * with the key and the value.  Deletes from %^H are saved
84    with a value of PL_sv_placeholder.  The state of %^H at any point can be
85    turned back into a regular HV by walking back up the tree from that point's
86    leaf, ignoring any key you've already seen (placeholder or not), storing
87    the rest into the HV structure, then removing the placeholders. Hence
88    memory is only used to store the %^H deltas from the enclosing COP, rather
89    than the entire %^H on each COP.
90
91    To cause actions on %^H to write out the serialisation records, it has
92    magic type 'H'. This magic (itself) does nothing, but its presence causes
93    the values to gain magic type 'h', which has entries for set and clear.
94    C<Perl_magic_sethint> updates C<PL_compiling.cop_hints_hash> with a store
95    record, with deletes written by C<Perl_magic_clearhint>. C<SAVEHINTS>
96    saves the current C<PL_compiling.cop_hints_hash> on the save stack, so that
97    it will be correctly restored when any inner compiling scope is exited.
98 */
99
100 #include "EXTERN.h"
101 #define PERL_IN_OP_C
102 #include "perl.h"
103 #include "keywords.h"
104
105 #define CALL_PEEP(o) CALL_FPTR(PL_peepp)(aTHX_ o)
106 #define CALL_OPFREEHOOK(o) if (PL_opfreehook) CALL_FPTR(PL_opfreehook)(aTHX_ o)
107
108 #if defined(PL_OP_SLAB_ALLOC)
109
110 #ifdef PERL_DEBUG_READONLY_OPS
111 #  define PERL_SLAB_SIZE 4096
112 #  include <sys/mman.h>
113 #endif
114
115 #ifndef PERL_SLAB_SIZE
116 #define PERL_SLAB_SIZE 2048
117 #endif
118
119 void *
120 Perl_Slab_Alloc(pTHX_ size_t sz)
121 {
122     dVAR;
123     /*
124      * To make incrementing use count easy PL_OpSlab is an I32 *
125      * To make inserting the link to slab PL_OpPtr is I32 **
126      * So compute size in units of sizeof(I32 *) as that is how Pl_OpPtr increments
127      * Add an overhead for pointer to slab and round up as a number of pointers
128      */
129     sz = (sz + 2*sizeof(I32 *) -1)/sizeof(I32 *);
130     if ((PL_OpSpace -= sz) < 0) {
131 #ifdef PERL_DEBUG_READONLY_OPS
132         /* We need to allocate chunk by chunk so that we can control the VM
133            mapping */
134         PL_OpPtr = (I32**) mmap(0, PERL_SLAB_SIZE*sizeof(I32*), PROT_READ|PROT_WRITE,
135                         MAP_ANON|MAP_PRIVATE, -1, 0);
136
137         DEBUG_m(PerlIO_printf(Perl_debug_log, "mapped %lu at %p\n",
138                               (unsigned long) PERL_SLAB_SIZE*sizeof(I32*),
139                               PL_OpPtr));
140         if(PL_OpPtr == MAP_FAILED) {
141             perror("mmap failed");
142             abort();
143         }
144 #else
145
146         PL_OpPtr = (I32 **) PerlMemShared_calloc(PERL_SLAB_SIZE,sizeof(I32*)); 
147 #endif
148         if (!PL_OpPtr) {
149             return NULL;
150         }
151         /* We reserve the 0'th I32 sized chunk as a use count */
152         PL_OpSlab = (I32 *) PL_OpPtr;
153         /* Reduce size by the use count word, and by the size we need.
154          * Latter is to mimic the '-=' in the if() above
155          */
156         PL_OpSpace = PERL_SLAB_SIZE - (sizeof(I32)+sizeof(I32 **)-1)/sizeof(I32 **) - sz;
157         /* Allocation pointer starts at the top.
158            Theory: because we build leaves before trunk allocating at end
159            means that at run time access is cache friendly upward
160          */
161         PL_OpPtr += PERL_SLAB_SIZE;
162
163 #ifdef PERL_DEBUG_READONLY_OPS
164         /* We remember this slab.  */
165         /* This implementation isn't efficient, but it is simple. */
166         PL_slabs = (I32**) realloc(PL_slabs, sizeof(I32**) * (PL_slab_count + 1));
167         PL_slabs[PL_slab_count++] = PL_OpSlab;
168         DEBUG_m(PerlIO_printf(Perl_debug_log, "Allocate %p\n", PL_OpSlab));
169 #endif
170     }
171     assert( PL_OpSpace >= 0 );
172     /* Move the allocation pointer down */
173     PL_OpPtr   -= sz;
174     assert( PL_OpPtr > (I32 **) PL_OpSlab );
175     *PL_OpPtr   = PL_OpSlab;    /* Note which slab it belongs to */
176     (*PL_OpSlab)++;             /* Increment use count of slab */
177     assert( PL_OpPtr+sz <= ((I32 **) PL_OpSlab + PERL_SLAB_SIZE) );
178     assert( *PL_OpSlab > 0 );
179     return (void *)(PL_OpPtr + 1);
180 }
181
182 #ifdef PERL_DEBUG_READONLY_OPS
183 void
184 Perl_pending_Slabs_to_ro(pTHX) {
185     /* Turn all the allocated op slabs read only.  */
186     U32 count = PL_slab_count;
187     I32 **const slabs = PL_slabs;
188
189     /* Reset the array of pending OP slabs, as we're about to turn this lot
190        read only. Also, do it ahead of the loop in case the warn triggers,
191        and a warn handler has an eval */
192
193     PL_slabs = NULL;
194     PL_slab_count = 0;
195
196     /* Force a new slab for any further allocation.  */
197     PL_OpSpace = 0;
198
199     while (count--) {
200         void *const start = slabs[count];
201         const size_t size = PERL_SLAB_SIZE* sizeof(I32*);
202         if(mprotect(start, size, PROT_READ)) {
203             Perl_warn(aTHX_ "mprotect for %p %lu failed with %d",
204                       start, (unsigned long) size, errno);
205         }
206     }
207
208     free(slabs);
209 }
210
211 STATIC void
212 S_Slab_to_rw(pTHX_ void *op)
213 {
214     I32 * const * const ptr = (I32 **) op;
215     I32 * const slab = ptr[-1];
216
217     PERL_ARGS_ASSERT_SLAB_TO_RW;
218
219     assert( ptr-1 > (I32 **) slab );
220     assert( ptr < ( (I32 **) slab + PERL_SLAB_SIZE) );
221     assert( *slab > 0 );
222     if(mprotect(slab, PERL_SLAB_SIZE*sizeof(I32*), PROT_READ|PROT_WRITE)) {
223         Perl_warn(aTHX_ "mprotect RW for %p %lu failed with %d",
224                   slab, (unsigned long) PERL_SLAB_SIZE*sizeof(I32*), errno);
225     }
226 }
227
228 OP *
229 Perl_op_refcnt_inc(pTHX_ OP *o)
230 {
231     if(o) {
232         Slab_to_rw(o);
233         ++o->op_targ;
234     }
235     return o;
236
237 }
238
239 PADOFFSET
240 Perl_op_refcnt_dec(pTHX_ OP *o)
241 {
242     PERL_ARGS_ASSERT_OP_REFCNT_DEC;
243     Slab_to_rw(o);
244     return --o->op_targ;
245 }
246 #else
247 #  define Slab_to_rw(op)
248 #endif
249
250 void
251 Perl_Slab_Free(pTHX_ void *op)
252 {
253     I32 * const * const ptr = (I32 **) op;
254     I32 * const slab = ptr[-1];
255     PERL_ARGS_ASSERT_SLAB_FREE;
256     assert( ptr-1 > (I32 **) slab );
257     assert( ptr < ( (I32 **) slab + PERL_SLAB_SIZE) );
258     assert( *slab > 0 );
259     Slab_to_rw(op);
260     if (--(*slab) == 0) {
261 #  ifdef NETWARE
262 #    define PerlMemShared PerlMem
263 #  endif
264         
265 #ifdef PERL_DEBUG_READONLY_OPS
266         U32 count = PL_slab_count;
267         /* Need to remove this slab from our list of slabs */
268         if (count) {
269             while (count--) {
270                 if (PL_slabs[count] == slab) {
271                     dVAR;
272                     /* Found it. Move the entry at the end to overwrite it.  */
273                     DEBUG_m(PerlIO_printf(Perl_debug_log,
274                                           "Deallocate %p by moving %p from %lu to %lu\n",
275                                           PL_OpSlab,
276                                           PL_slabs[PL_slab_count - 1],
277                                           PL_slab_count, count));
278                     PL_slabs[count] = PL_slabs[--PL_slab_count];
279                     /* Could realloc smaller at this point, but probably not
280                        worth it.  */
281                     if(munmap(slab, PERL_SLAB_SIZE*sizeof(I32*))) {
282                         perror("munmap failed");
283                         abort();
284                     }
285                     break;
286                 }
287             }
288         }
289 #else
290     PerlMemShared_free(slab);
291 #endif
292         if (slab == PL_OpSlab) {
293             PL_OpSpace = 0;
294         }
295     }
296 }
297 #endif
298 /*
299  * In the following definition, the ", (OP*)0" is just to make the compiler
300  * think the expression is of the right type: croak actually does a Siglongjmp.
301  */
302 #define CHECKOP(type,o) \
303     ((PL_op_mask && PL_op_mask[type])                           \
304      ? ( op_free((OP*)o),                                       \
305          Perl_croak(aTHX_ "'%s' trapped by operation mask", PL_op_desc[type]),  \
306          (OP*)0 )                                               \
307      : CALL_FPTR(PL_check[type])(aTHX_ (OP*)o))
308
309 #define RETURN_UNLIMITED_NUMBER (PERL_INT_MAX / 2)
310
311 STATIC const char*
312 S_gv_ename(pTHX_ GV *gv)
313 {
314     SV* const tmpsv = sv_newmortal();
315
316     PERL_ARGS_ASSERT_GV_ENAME;
317
318     gv_efullname3(tmpsv, gv, NULL);
319     return SvPV_nolen_const(tmpsv);
320 }
321
322 STATIC OP *
323 S_no_fh_allowed(pTHX_ OP *o)
324 {
325     PERL_ARGS_ASSERT_NO_FH_ALLOWED;
326
327     yyerror(Perl_form(aTHX_ "Missing comma after first argument to %s function",
328                  OP_DESC(o)));
329     return o;
330 }
331
332 STATIC OP *
333 S_too_few_arguments(pTHX_ OP *o, const char *name)
334 {
335     PERL_ARGS_ASSERT_TOO_FEW_ARGUMENTS;
336
337     yyerror(Perl_form(aTHX_ "Not enough arguments for %s", name));
338     return o;
339 }
340
341 STATIC OP *
342 S_too_many_arguments(pTHX_ OP *o, const char *name)
343 {
344     PERL_ARGS_ASSERT_TOO_MANY_ARGUMENTS;
345
346     yyerror(Perl_form(aTHX_ "Too many arguments for %s", name));
347     return o;
348 }
349
350 STATIC void
351 S_bad_type(pTHX_ I32 n, const char *t, const char *name, const OP *kid)
352 {
353     PERL_ARGS_ASSERT_BAD_TYPE;
354
355     yyerror(Perl_form(aTHX_ "Type of arg %d to %s must be %s (not %s)",
356                  (int)n, name, t, OP_DESC(kid)));
357 }
358
359 STATIC void
360 S_no_bareword_allowed(pTHX_ const OP *o)
361 {
362     PERL_ARGS_ASSERT_NO_BAREWORD_ALLOWED;
363
364     if (PL_madskills)
365         return;         /* various ok barewords are hidden in extra OP_NULL */
366     qerror(Perl_mess(aTHX_
367                      "Bareword \"%"SVf"\" not allowed while \"strict subs\" in use",
368                      SVfARG(cSVOPo_sv)));
369 }
370
371 /* "register" allocation */
372
373 PADOFFSET
374 Perl_allocmy(pTHX_ const char *const name)
375 {
376     dVAR;
377     PADOFFSET off;
378     const bool is_our = (PL_parser->in_my == KEY_our);
379
380     PERL_ARGS_ASSERT_ALLOCMY;
381
382     /* complain about "my $<special_var>" etc etc */
383     if (*name &&
384         !(is_our ||
385           isALPHA(name[1]) ||
386           (USE_UTF8_IN_NAMES && UTF8_IS_START(name[1])) ||
387           (name[1] == '_' && (*name == '$' || name[2]))))
388     {
389         /* name[2] is true if strlen(name) > 2  */
390         if (!isPRINT(name[1]) || strchr("\t\n\r\f", name[1])) {
391             yyerror(Perl_form(aTHX_ "Can't use global %c^%c%s in \"%s\"",
392                               name[0], toCTRL(name[1]), name + 2,
393                               PL_parser->in_my == KEY_state ? "state" : "my"));
394         } else {
395             yyerror(Perl_form(aTHX_ "Can't use global %s in \"%s\"",name,
396                               PL_parser->in_my == KEY_state ? "state" : "my"));
397         }
398     }
399
400     /* check for duplicate declaration */
401     pad_check_dup(name, is_our, (PL_curstash ? PL_curstash : PL_defstash));
402
403     /* allocate a spare slot and store the name in that slot */
404
405     off = pad_add_name(name,
406                     PL_parser->in_my_stash,
407                     (is_our
408                         /* $_ is always in main::, even with our */
409                         ? (PL_curstash && !strEQ(name,"$_") ? PL_curstash : PL_defstash)
410                         : NULL
411                     ),
412                     0, /*  not fake */
413                     PL_parser->in_my == KEY_state
414     );
415     /* anon sub prototypes contains state vars should always be cloned,
416      * otherwise the state var would be shared between anon subs */
417
418     if (PL_parser->in_my == KEY_state && CvANON(PL_compcv))
419         CvCLONE_on(PL_compcv);
420
421     return off;
422 }
423
424 /* free the body of an op without examining its contents.
425  * Always use this rather than FreeOp directly */
426
427 static void
428 S_op_destroy(pTHX_ OP *o)
429 {
430     if (o->op_latefree) {
431         o->op_latefreed = 1;
432         return;
433     }
434     FreeOp(o);
435 }
436
437 #ifdef USE_ITHREADS
438 #  define forget_pmop(a,b)      S_forget_pmop(aTHX_ a,b)
439 #else
440 #  define forget_pmop(a,b)      S_forget_pmop(aTHX_ a)
441 #endif
442
443 /* Destructor */
444
445 void
446 Perl_op_free(pTHX_ OP *o)
447 {
448     dVAR;
449     OPCODE type;
450
451     if (!o)
452         return;
453     if (o->op_latefreed) {
454         if (o->op_latefree)
455             return;
456         goto do_free;
457     }
458
459     type = o->op_type;
460     if (o->op_private & OPpREFCOUNTED) {
461         switch (type) {
462         case OP_LEAVESUB:
463         case OP_LEAVESUBLV:
464         case OP_LEAVEEVAL:
465         case OP_LEAVE:
466         case OP_SCOPE:
467         case OP_LEAVEWRITE:
468             {
469             PADOFFSET refcnt;
470             OP_REFCNT_LOCK;
471             refcnt = OpREFCNT_dec(o);
472             OP_REFCNT_UNLOCK;
473             if (refcnt) {
474                 /* Need to find and remove any pattern match ops from the list
475                    we maintain for reset().  */
476                 find_and_forget_pmops(o);
477                 return;
478             }
479             }
480             break;
481         default:
482             break;
483         }
484     }
485
486     /* Call the op_free hook if it has been set. Do it now so that it's called
487      * at the right time for refcounted ops, but still before all of the kids
488      * are freed. */
489     CALL_OPFREEHOOK(o);
490
491     if (o->op_flags & OPf_KIDS) {
492         register OP *kid, *nextkid;
493         for (kid = cUNOPo->op_first; kid; kid = nextkid) {
494             nextkid = kid->op_sibling; /* Get before next freeing kid */
495             op_free(kid);
496         }
497     }
498
499 #ifdef PERL_DEBUG_READONLY_OPS
500     Slab_to_rw(o);
501 #endif
502
503     /* COP* is not cleared by op_clear() so that we may track line
504      * numbers etc even after null() */
505     if (type == OP_NEXTSTATE || type == OP_DBSTATE
506             || (type == OP_NULL /* the COP might have been null'ed */
507                 && ((OPCODE)o->op_targ == OP_NEXTSTATE
508                     || (OPCODE)o->op_targ == OP_DBSTATE))) {
509         cop_free((COP*)o);
510     }
511
512     if (type == OP_NULL)
513         type = (OPCODE)o->op_targ;
514
515     op_clear(o);
516     if (o->op_latefree) {
517         o->op_latefreed = 1;
518         return;
519     }
520   do_free:
521     FreeOp(o);
522 #ifdef DEBUG_LEAKING_SCALARS
523     if (PL_op == o)
524         PL_op = NULL;
525 #endif
526 }
527
528 void
529 Perl_op_clear(pTHX_ OP *o)
530 {
531
532     dVAR;
533
534     PERL_ARGS_ASSERT_OP_CLEAR;
535
536 #ifdef PERL_MAD
537     /* if (o->op_madprop && o->op_madprop->mad_next)
538        abort(); */
539     /* FIXME for MAD - if I uncomment these two lines t/op/pack.t fails with
540        "modification of a read only value" for a reason I can't fathom why.
541        It's the "" stringification of $_, where $_ was set to '' in a foreach
542        loop, but it defies simplification into a small test case.
543        However, commenting them out has caused ext/List/Util/t/weak.t to fail
544        the last test.  */
545     /*
546       mad_free(o->op_madprop);
547       o->op_madprop = 0;
548     */
549 #endif    
550
551  retry:
552     switch (o->op_type) {
553     case OP_NULL:       /* Was holding old type, if any. */
554         if (PL_madskills && o->op_targ != OP_NULL) {
555             o->op_type = (Optype)o->op_targ;
556             o->op_targ = 0;
557             goto retry;
558         }
559     case OP_ENTEREVAL:  /* Was holding hints. */
560         o->op_targ = 0;
561         break;
562     default:
563         if (!(o->op_flags & OPf_REF)
564             || (PL_check[o->op_type] != MEMBER_TO_FPTR(Perl_ck_ftst)))
565             break;
566         /* FALL THROUGH */
567     case OP_GVSV:
568     case OP_GV:
569     case OP_AELEMFAST:
570         if (! (o->op_type == OP_AELEMFAST && o->op_flags & OPf_SPECIAL)) {
571             /* not an OP_PADAV replacement */
572 #ifdef USE_ITHREADS
573             if (cPADOPo->op_padix > 0) {
574                 /* No GvIN_PAD_off(cGVOPo_gv) here, because other references
575                  * may still exist on the pad */
576                 pad_swipe(cPADOPo->op_padix, TRUE);
577                 cPADOPo->op_padix = 0;
578             }
579 #else
580             SvREFCNT_dec(cSVOPo->op_sv);
581             cSVOPo->op_sv = NULL;
582 #endif
583         }
584         break;
585     case OP_METHOD_NAMED:
586     case OP_CONST:
587     case OP_HINTSEVAL:
588         SvREFCNT_dec(cSVOPo->op_sv);
589         cSVOPo->op_sv = NULL;
590 #ifdef USE_ITHREADS
591         /** Bug #15654
592           Even if op_clear does a pad_free for the target of the op,
593           pad_free doesn't actually remove the sv that exists in the pad;
594           instead it lives on. This results in that it could be reused as 
595           a target later on when the pad was reallocated.
596         **/
597         if(o->op_targ) {
598           pad_swipe(o->op_targ,1);
599           o->op_targ = 0;
600         }
601 #endif
602         break;
603     case OP_GOTO:
604     case OP_NEXT:
605     case OP_LAST:
606     case OP_REDO:
607         if (o->op_flags & (OPf_SPECIAL|OPf_STACKED|OPf_KIDS))
608             break;
609         /* FALL THROUGH */
610     case OP_TRANS:
611         if (o->op_private & (OPpTRANS_FROM_UTF|OPpTRANS_TO_UTF)) {
612 #ifdef USE_ITHREADS
613             if (cPADOPo->op_padix > 0) {
614                 pad_swipe(cPADOPo->op_padix, TRUE);
615                 cPADOPo->op_padix = 0;
616             }
617 #else
618             SvREFCNT_dec(cSVOPo->op_sv);
619             cSVOPo->op_sv = NULL;
620 #endif
621         }
622         else {
623             PerlMemShared_free(cPVOPo->op_pv);
624             cPVOPo->op_pv = NULL;
625         }
626         break;
627     case OP_SUBST:
628         op_free(cPMOPo->op_pmreplrootu.op_pmreplroot);
629         goto clear_pmop;
630     case OP_PUSHRE:
631 #ifdef USE_ITHREADS
632         if (cPMOPo->op_pmreplrootu.op_pmtargetoff) {
633             /* No GvIN_PAD_off here, because other references may still
634              * exist on the pad */
635             pad_swipe(cPMOPo->op_pmreplrootu.op_pmtargetoff, TRUE);
636         }
637 #else
638         SvREFCNT_dec(MUTABLE_SV(cPMOPo->op_pmreplrootu.op_pmtargetgv));
639 #endif
640         /* FALL THROUGH */
641     case OP_MATCH:
642     case OP_QR:
643 clear_pmop:
644         forget_pmop(cPMOPo, 1);
645         cPMOPo->op_pmreplrootu.op_pmreplroot = NULL;
646         /* we use the same protection as the "SAFE" version of the PM_ macros
647          * here since sv_clean_all might release some PMOPs
648          * after PL_regex_padav has been cleared
649          * and the clearing of PL_regex_padav needs to
650          * happen before sv_clean_all
651          */
652 #ifdef USE_ITHREADS
653         if(PL_regex_pad) {        /* We could be in destruction */
654             const IV offset = (cPMOPo)->op_pmoffset;
655             ReREFCNT_dec(PM_GETRE(cPMOPo));
656             PL_regex_pad[offset] = &PL_sv_undef;
657             sv_catpvn_nomg(PL_regex_pad[0], (const char *)&offset,
658                            sizeof(offset));
659         }
660 #else
661         ReREFCNT_dec(PM_GETRE(cPMOPo));
662         PM_SETRE(cPMOPo, NULL);
663 #endif
664
665         break;
666     }
667
668     if (o->op_targ > 0) {
669         pad_free(o->op_targ);
670         o->op_targ = 0;
671     }
672 }
673
674 STATIC void
675 S_cop_free(pTHX_ COP* cop)
676 {
677     PERL_ARGS_ASSERT_COP_FREE;
678
679     CopFILE_free(cop);
680     CopSTASH_free(cop);
681     if (! specialWARN(cop->cop_warnings))
682         PerlMemShared_free(cop->cop_warnings);
683     Perl_refcounted_he_free(aTHX_ cop->cop_hints_hash);
684 }
685
686 STATIC void
687 S_forget_pmop(pTHX_ PMOP *const o
688 #ifdef USE_ITHREADS
689               , U32 flags
690 #endif
691               )
692 {
693     HV * const pmstash = PmopSTASH(o);
694
695     PERL_ARGS_ASSERT_FORGET_PMOP;
696
697     if (pmstash && !SvIS_FREED(pmstash)) {
698         MAGIC * const mg = mg_find((const SV *)pmstash, PERL_MAGIC_symtab);
699         if (mg) {
700             PMOP **const array = (PMOP**) mg->mg_ptr;
701             U32 count = mg->mg_len / sizeof(PMOP**);
702             U32 i = count;
703
704             while (i--) {
705                 if (array[i] == o) {
706                     /* Found it. Move the entry at the end to overwrite it.  */
707                     array[i] = array[--count];
708                     mg->mg_len = count * sizeof(PMOP**);
709                     /* Could realloc smaller at this point always, but probably
710                        not worth it. Probably worth free()ing if we're the
711                        last.  */
712                     if(!count) {
713                         Safefree(mg->mg_ptr);
714                         mg->mg_ptr = NULL;
715                     }
716                     break;
717                 }
718             }
719         }
720     }
721     if (PL_curpm == o) 
722         PL_curpm = NULL;
723 #ifdef USE_ITHREADS
724     if (flags)
725         PmopSTASH_free(o);
726 #endif
727 }
728
729 STATIC void
730 S_find_and_forget_pmops(pTHX_ OP *o)
731 {
732     PERL_ARGS_ASSERT_FIND_AND_FORGET_PMOPS;
733
734     if (o->op_flags & OPf_KIDS) {
735         OP *kid = cUNOPo->op_first;
736         while (kid) {
737             switch (kid->op_type) {
738             case OP_SUBST:
739             case OP_PUSHRE:
740             case OP_MATCH:
741             case OP_QR:
742                 forget_pmop((PMOP*)kid, 0);
743             }
744             find_and_forget_pmops(kid);
745             kid = kid->op_sibling;
746         }
747     }
748 }
749
750 void
751 Perl_op_null(pTHX_ OP *o)
752 {
753     dVAR;
754
755     PERL_ARGS_ASSERT_OP_NULL;
756
757     if (o->op_type == OP_NULL)
758         return;
759     if (!PL_madskills)
760         op_clear(o);
761     o->op_targ = o->op_type;
762     o->op_type = OP_NULL;
763     o->op_ppaddr = PL_ppaddr[OP_NULL];
764 }
765
766 void
767 Perl_op_refcnt_lock(pTHX)
768 {
769     dVAR;
770     PERL_UNUSED_CONTEXT;
771     OP_REFCNT_LOCK;
772 }
773
774 void
775 Perl_op_refcnt_unlock(pTHX)
776 {
777     dVAR;
778     PERL_UNUSED_CONTEXT;
779     OP_REFCNT_UNLOCK;
780 }
781
782 /* Contextualizers */
783
784 #define LINKLIST(o) ((o)->op_next ? (o)->op_next : linklist((OP*)o))
785
786 static OP *
787 S_linklist(pTHX_ OP *o)
788 {
789     OP *first;
790
791     PERL_ARGS_ASSERT_LINKLIST;
792
793     if (o->op_next)
794         return o->op_next;
795
796     /* establish postfix order */
797     first = cUNOPo->op_first;
798     if (first) {
799         register OP *kid;
800         o->op_next = LINKLIST(first);
801         kid = first;
802         for (;;) {
803             if (kid->op_sibling) {
804                 kid->op_next = LINKLIST(kid->op_sibling);
805                 kid = kid->op_sibling;
806             } else {
807                 kid->op_next = o;
808                 break;
809             }
810         }
811     }
812     else
813         o->op_next = o;
814
815     return o->op_next;
816 }
817
818 static OP *
819 S_scalarkids(pTHX_ OP *o)
820 {
821     if (o && o->op_flags & OPf_KIDS) {
822         OP *kid;
823         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
824             scalar(kid);
825     }
826     return o;
827 }
828
829 STATIC OP *
830 S_scalarboolean(pTHX_ OP *o)
831 {
832     dVAR;
833
834     PERL_ARGS_ASSERT_SCALARBOOLEAN;
835
836     if (o->op_type == OP_SASSIGN && cBINOPo->op_first->op_type == OP_CONST) {
837         if (ckWARN(WARN_SYNTAX)) {
838             const line_t oldline = CopLINE(PL_curcop);
839
840             if (PL_parser && PL_parser->copline != NOLINE)
841                 CopLINE_set(PL_curcop, PL_parser->copline);
842             Perl_warner(aTHX_ packWARN(WARN_SYNTAX), "Found = in conditional, should be ==");
843             CopLINE_set(PL_curcop, oldline);
844         }
845     }
846     return scalar(o);
847 }
848
849 OP *
850 Perl_scalar(pTHX_ OP *o)
851 {
852     dVAR;
853     OP *kid;
854
855     /* assumes no premature commitment */
856     if (!o || (PL_parser && PL_parser->error_count)
857          || (o->op_flags & OPf_WANT)
858          || o->op_type == OP_RETURN)
859     {
860         return o;
861     }
862
863     o->op_flags = (o->op_flags & ~OPf_WANT) | OPf_WANT_SCALAR;
864
865     switch (o->op_type) {
866     case OP_REPEAT:
867         scalar(cBINOPo->op_first);
868         break;
869     case OP_OR:
870     case OP_AND:
871     case OP_COND_EXPR:
872         for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
873             scalar(kid);
874         break;
875     case OP_SPLIT:
876         if ((kid = cLISTOPo->op_first) && kid->op_type == OP_PUSHRE) {
877             if (!kPMOP->op_pmreplrootu.op_pmreplroot)
878                 deprecate_old("implicit split to @_");
879         }
880         /* FALL THROUGH */
881     case OP_MATCH:
882     case OP_QR:
883     case OP_SUBST:
884     case OP_NULL:
885     default:
886         if (o->op_flags & OPf_KIDS) {
887             for (kid = cUNOPo->op_first; kid; kid = kid->op_sibling)
888                 scalar(kid);
889         }
890         break;
891     case OP_LEAVE:
892     case OP_LEAVETRY:
893         kid = cLISTOPo->op_first;
894         scalar(kid);
895         while ((kid = kid->op_sibling)) {
896             if (kid->op_sibling)
897                 scalarvoid(kid);
898             else
899                 scalar(kid);
900         }
901         PL_curcop = &PL_compiling;
902         break;
903     case OP_SCOPE:
904     case OP_LINESEQ:
905     case OP_LIST:
906         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling) {
907             if (kid->op_sibling)
908                 scalarvoid(kid);
909             else
910                 scalar(kid);
911         }
912         PL_curcop = &PL_compiling;
913         break;
914     case OP_SORT:
915         if (ckWARN(WARN_VOID))
916             Perl_warner(aTHX_ packWARN(WARN_VOID), "Useless use of sort in scalar context");
917         break;
918     }
919     return o;
920 }
921
922 OP *
923 Perl_scalarvoid(pTHX_ OP *o)
924 {
925     dVAR;
926     OP *kid;
927     const char* useless = NULL;
928     SV* sv;
929     U8 want;
930
931     PERL_ARGS_ASSERT_SCALARVOID;
932
933     /* trailing mad null ops don't count as "there" for void processing */
934     if (PL_madskills &&
935         o->op_type != OP_NULL &&
936         o->op_sibling &&
937         o->op_sibling->op_type == OP_NULL)
938     {
939         OP *sib;
940         for (sib = o->op_sibling;
941                 sib && sib->op_type == OP_NULL;
942                 sib = sib->op_sibling) ;
943         
944         if (!sib)
945             return o;
946     }
947
948     if (o->op_type == OP_NEXTSTATE
949         || o->op_type == OP_DBSTATE
950         || (o->op_type == OP_NULL && (o->op_targ == OP_NEXTSTATE
951                                       || o->op_targ == OP_DBSTATE)))
952         PL_curcop = (COP*)o;            /* for warning below */
953
954     /* assumes no premature commitment */
955     want = o->op_flags & OPf_WANT;
956     if ((want && want != OPf_WANT_SCALAR)
957          || (PL_parser && PL_parser->error_count)
958          || o->op_type == OP_RETURN)
959     {
960         return o;
961     }
962
963     if ((o->op_private & OPpTARGET_MY)
964         && (PL_opargs[o->op_type] & OA_TARGLEX))/* OPp share the meaning */
965     {
966         return scalar(o);                       /* As if inside SASSIGN */
967     }
968
969     o->op_flags = (o->op_flags & ~OPf_WANT) | OPf_WANT_VOID;
970
971     switch (o->op_type) {
972     default:
973         if (!(PL_opargs[o->op_type] & OA_FOLDCONST))
974             break;
975         /* FALL THROUGH */
976     case OP_REPEAT:
977         if (o->op_flags & OPf_STACKED)
978             break;
979         goto func_ops;
980     case OP_SUBSTR:
981         if (o->op_private == 4)
982             break;
983         /* FALL THROUGH */
984     case OP_GVSV:
985     case OP_WANTARRAY:
986     case OP_GV:
987     case OP_SMARTMATCH:
988     case OP_PADSV:
989     case OP_PADAV:
990     case OP_PADHV:
991     case OP_PADANY:
992     case OP_AV2ARYLEN:
993     case OP_REF:
994     case OP_REFGEN:
995     case OP_SREFGEN:
996     case OP_DEFINED:
997     case OP_HEX:
998     case OP_OCT:
999     case OP_LENGTH:
1000     case OP_VEC:
1001     case OP_INDEX:
1002     case OP_RINDEX:
1003     case OP_SPRINTF:
1004     case OP_AELEM:
1005     case OP_AELEMFAST:
1006     case OP_ASLICE:
1007     case OP_HELEM:
1008     case OP_HSLICE:
1009     case OP_UNPACK:
1010     case OP_PACK:
1011     case OP_JOIN:
1012     case OP_LSLICE:
1013     case OP_ANONLIST:
1014     case OP_ANONHASH:
1015     case OP_SORT:
1016     case OP_REVERSE:
1017     case OP_RANGE:
1018     case OP_FLIP:
1019     case OP_FLOP:
1020     case OP_CALLER:
1021     case OP_FILENO:
1022     case OP_EOF:
1023     case OP_TELL:
1024     case OP_GETSOCKNAME:
1025     case OP_GETPEERNAME:
1026     case OP_READLINK:
1027     case OP_TELLDIR:
1028     case OP_GETPPID:
1029     case OP_GETPGRP:
1030     case OP_GETPRIORITY:
1031     case OP_TIME:
1032     case OP_TMS:
1033     case OP_LOCALTIME:
1034     case OP_GMTIME:
1035     case OP_GHBYNAME:
1036     case OP_GHBYADDR:
1037     case OP_GHOSTENT:
1038     case OP_GNBYNAME:
1039     case OP_GNBYADDR:
1040     case OP_GNETENT:
1041     case OP_GPBYNAME:
1042     case OP_GPBYNUMBER:
1043     case OP_GPROTOENT:
1044     case OP_GSBYNAME:
1045     case OP_GSBYPORT:
1046     case OP_GSERVENT:
1047     case OP_GPWNAM:
1048     case OP_GPWUID:
1049     case OP_GGRNAM:
1050     case OP_GGRGID:
1051     case OP_GETLOGIN:
1052     case OP_PROTOTYPE:
1053       func_ops:
1054         if (!(o->op_private & (OPpLVAL_INTRO|OPpOUR_INTRO)))
1055             /* Otherwise it's "Useless use of grep iterator" */
1056             useless = OP_DESC(o);
1057         break;
1058
1059     case OP_NOT:
1060        kid = cUNOPo->op_first;
1061        if (kid->op_type != OP_MATCH && kid->op_type != OP_SUBST &&
1062            kid->op_type != OP_TRANS) {
1063                 goto func_ops;
1064        }
1065        useless = "negative pattern binding (!~)";
1066        break;
1067
1068     case OP_RV2GV:
1069     case OP_RV2SV:
1070     case OP_RV2AV:
1071     case OP_RV2HV:
1072         if (!(o->op_private & (OPpLVAL_INTRO|OPpOUR_INTRO)) &&
1073                 (!o->op_sibling || o->op_sibling->op_type != OP_READLINE))
1074             useless = "a variable";
1075         break;
1076
1077     case OP_CONST:
1078         sv = cSVOPo_sv;
1079         if (cSVOPo->op_private & OPpCONST_STRICT)
1080             no_bareword_allowed(o);
1081         else {
1082             if (ckWARN(WARN_VOID)) {
1083                 if (SvOK(sv)) {
1084                     SV* msv = sv_2mortal(Perl_newSVpvf(aTHX_
1085                                 "a constant (%"SVf")", sv));
1086                     useless = SvPV_nolen(msv);
1087                 }
1088                 else
1089                     useless = "a constant (undef)";
1090                 if (o->op_private & OPpCONST_ARYBASE)
1091                     useless = NULL;
1092                 /* don't warn on optimised away booleans, eg 
1093                  * use constant Foo, 5; Foo || print; */
1094                 if (cSVOPo->op_private & OPpCONST_SHORTCIRCUIT)
1095                     useless = NULL;
1096                 /* the constants 0 and 1 are permitted as they are
1097                    conventionally used as dummies in constructs like
1098                         1 while some_condition_with_side_effects;  */
1099                 else if (SvNIOK(sv) && (SvNV(sv) == 0.0 || SvNV(sv) == 1.0))
1100                     useless = NULL;
1101                 else if (SvPOK(sv)) {
1102                   /* perl4's way of mixing documentation and code
1103                      (before the invention of POD) was based on a
1104                      trick to mix nroff and perl code. The trick was
1105                      built upon these three nroff macros being used in
1106                      void context. The pink camel has the details in
1107                      the script wrapman near page 319. */
1108                     const char * const maybe_macro = SvPVX_const(sv);
1109                     if (strnEQ(maybe_macro, "di", 2) ||
1110                         strnEQ(maybe_macro, "ds", 2) ||
1111                         strnEQ(maybe_macro, "ig", 2))
1112                             useless = NULL;
1113                 }
1114             }
1115         }
1116         op_null(o);             /* don't execute or even remember it */
1117         break;
1118
1119     case OP_POSTINC:
1120         o->op_type = OP_PREINC;         /* pre-increment is faster */
1121         o->op_ppaddr = PL_ppaddr[OP_PREINC];
1122         break;
1123
1124     case OP_POSTDEC:
1125         o->op_type = OP_PREDEC;         /* pre-decrement is faster */
1126         o->op_ppaddr = PL_ppaddr[OP_PREDEC];
1127         break;
1128
1129     case OP_I_POSTINC:
1130         o->op_type = OP_I_PREINC;       /* pre-increment is faster */
1131         o->op_ppaddr = PL_ppaddr[OP_I_PREINC];
1132         break;
1133
1134     case OP_I_POSTDEC:
1135         o->op_type = OP_I_PREDEC;       /* pre-decrement is faster */
1136         o->op_ppaddr = PL_ppaddr[OP_I_PREDEC];
1137         break;
1138
1139     case OP_OR:
1140     case OP_AND:
1141         kid = cLOGOPo->op_first;
1142         if (kid->op_type == OP_NOT
1143             && (kid->op_flags & OPf_KIDS)
1144             && !PL_madskills) {
1145             if (o->op_type == OP_AND) {
1146                 o->op_type = OP_OR;
1147                 o->op_ppaddr = PL_ppaddr[OP_OR];
1148             } else {
1149                 o->op_type = OP_AND;
1150                 o->op_ppaddr = PL_ppaddr[OP_AND];
1151             }
1152             op_null(kid);
1153         }
1154
1155     case OP_DOR:
1156     case OP_COND_EXPR:
1157     case OP_ENTERGIVEN:
1158     case OP_ENTERWHEN:
1159         for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
1160             scalarvoid(kid);
1161         break;
1162
1163     case OP_NULL:
1164         if (o->op_flags & OPf_STACKED)
1165             break;
1166         /* FALL THROUGH */
1167     case OP_NEXTSTATE:
1168     case OP_DBSTATE:
1169     case OP_ENTERTRY:
1170     case OP_ENTER:
1171         if (!(o->op_flags & OPf_KIDS))
1172             break;
1173         /* FALL THROUGH */
1174     case OP_SCOPE:
1175     case OP_LEAVE:
1176     case OP_LEAVETRY:
1177     case OP_LEAVELOOP:
1178     case OP_LINESEQ:
1179     case OP_LIST:
1180     case OP_LEAVEGIVEN:
1181     case OP_LEAVEWHEN:
1182         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
1183             scalarvoid(kid);
1184         break;
1185     case OP_ENTEREVAL:
1186         scalarkids(o);
1187         break;
1188     case OP_REQUIRE:
1189         /* all requires must return a boolean value */
1190         o->op_flags &= ~OPf_WANT;
1191         /* FALL THROUGH */
1192     case OP_SCALAR:
1193         return scalar(o);
1194     case OP_SPLIT:
1195         if ((kid = cLISTOPo->op_first) && kid->op_type == OP_PUSHRE) {
1196             if (!kPMOP->op_pmreplrootu.op_pmreplroot)
1197                 deprecate_old("implicit split to @_");
1198         }
1199         break;
1200     }
1201     if (useless && ckWARN(WARN_VOID))
1202         Perl_warner(aTHX_ packWARN(WARN_VOID), "Useless use of %s in void context", useless);
1203     return o;
1204 }
1205
1206 static OP *
1207 S_listkids(pTHX_ OP *o)
1208 {
1209     if (o && o->op_flags & OPf_KIDS) {
1210         OP *kid;
1211         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
1212             list(kid);
1213     }
1214     return o;
1215 }
1216
1217 OP *
1218 Perl_list(pTHX_ OP *o)
1219 {
1220     dVAR;
1221     OP *kid;
1222
1223     /* assumes no premature commitment */
1224     if (!o || (o->op_flags & OPf_WANT)
1225          || (PL_parser && PL_parser->error_count)
1226          || o->op_type == OP_RETURN)
1227     {
1228         return o;
1229     }
1230
1231     if ((o->op_private & OPpTARGET_MY)
1232         && (PL_opargs[o->op_type] & OA_TARGLEX))/* OPp share the meaning */
1233     {
1234         return o;                               /* As if inside SASSIGN */
1235     }
1236
1237     o->op_flags = (o->op_flags & ~OPf_WANT) | OPf_WANT_LIST;
1238
1239     switch (o->op_type) {
1240     case OP_FLOP:
1241     case OP_REPEAT:
1242         list(cBINOPo->op_first);
1243         break;
1244     case OP_OR:
1245     case OP_AND:
1246     case OP_COND_EXPR:
1247         for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
1248             list(kid);
1249         break;
1250     default:
1251     case OP_MATCH:
1252     case OP_QR:
1253     case OP_SUBST:
1254     case OP_NULL:
1255         if (!(o->op_flags & OPf_KIDS))
1256             break;
1257         if (!o->op_next && cUNOPo->op_first->op_type == OP_FLOP) {
1258             list(cBINOPo->op_first);
1259             return gen_constant_list(o);
1260         }
1261     case OP_LIST:
1262         listkids(o);
1263         break;
1264     case OP_LEAVE:
1265     case OP_LEAVETRY:
1266         kid = cLISTOPo->op_first;
1267         list(kid);
1268         while ((kid = kid->op_sibling)) {
1269             if (kid->op_sibling)
1270                 scalarvoid(kid);
1271             else
1272                 list(kid);
1273         }
1274         PL_curcop = &PL_compiling;
1275         break;
1276     case OP_SCOPE:
1277     case OP_LINESEQ:
1278         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling) {
1279             if (kid->op_sibling)
1280                 scalarvoid(kid);
1281             else
1282                 list(kid);
1283         }
1284         PL_curcop = &PL_compiling;
1285         break;
1286     case OP_REQUIRE:
1287         /* all requires must return a boolean value */
1288         o->op_flags &= ~OPf_WANT;
1289         return scalar(o);
1290     }
1291     return o;
1292 }
1293
1294 static OP *
1295 S_scalarseq(pTHX_ OP *o)
1296 {
1297     dVAR;
1298     if (o) {
1299         const OPCODE type = o->op_type;
1300
1301         if (type == OP_LINESEQ || type == OP_SCOPE ||
1302             type == OP_LEAVE || type == OP_LEAVETRY)
1303         {
1304             OP *kid;
1305             for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling) {
1306                 if (kid->op_sibling) {
1307                     scalarvoid(kid);
1308                 }
1309             }
1310             PL_curcop = &PL_compiling;
1311         }
1312         o->op_flags &= ~OPf_PARENS;
1313         if (PL_hints & HINT_BLOCK_SCOPE)
1314             o->op_flags |= OPf_PARENS;
1315     }
1316     else
1317         o = newOP(OP_STUB, 0);
1318     return o;
1319 }
1320
1321 STATIC OP *
1322 S_modkids(pTHX_ OP *o, I32 type)
1323 {
1324     if (o && o->op_flags & OPf_KIDS) {
1325         OP *kid;
1326         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
1327             mod(kid, type);
1328     }
1329     return o;
1330 }
1331
1332 /* Propagate lvalue ("modifiable") context to an op and its children.
1333  * 'type' represents the context type, roughly based on the type of op that
1334  * would do the modifying, although local() is represented by OP_NULL.
1335  * It's responsible for detecting things that can't be modified,  flag
1336  * things that need to behave specially in an lvalue context (e.g., "$$x = 5"
1337  * might have to vivify a reference in $x), and so on.
1338  *
1339  * For example, "$a+1 = 2" would cause mod() to be called with o being
1340  * OP_ADD and type being OP_SASSIGN, and would output an error.
1341  */
1342
1343 OP *
1344 Perl_mod(pTHX_ OP *o, I32 type)
1345 {
1346     dVAR;
1347     OP *kid;
1348     /* -1 = error on localize, 0 = ignore localize, 1 = ok to localize */
1349     int localize = -1;
1350
1351     if (!o || (PL_parser && PL_parser->error_count))
1352         return o;
1353
1354     if ((o->op_private & OPpTARGET_MY)
1355         && (PL_opargs[o->op_type] & OA_TARGLEX))/* OPp share the meaning */
1356     {
1357         return o;
1358     }
1359
1360     switch (o->op_type) {
1361     case OP_UNDEF:
1362         localize = 0;
1363         PL_modcount++;
1364         return o;
1365     case OP_CONST:
1366         if (!(o->op_private & OPpCONST_ARYBASE))
1367             goto nomod;
1368         localize = 0;
1369         if (PL_eval_start && PL_eval_start->op_type == OP_CONST) {
1370             CopARYBASE_set(&PL_compiling,
1371                            (I32)SvIV(cSVOPx(PL_eval_start)->op_sv));
1372             PL_eval_start = 0;
1373         }
1374         else if (!type) {
1375             SAVECOPARYBASE(&PL_compiling);
1376             CopARYBASE_set(&PL_compiling, 0);
1377         }
1378         else if (type == OP_REFGEN)
1379             goto nomod;
1380         else
1381             Perl_croak(aTHX_ "That use of $[ is unsupported");
1382         break;
1383     case OP_STUB:
1384         if ((o->op_flags & OPf_PARENS) || PL_madskills)
1385             break;
1386         goto nomod;
1387     case OP_ENTERSUB:
1388         if ((type == OP_UNDEF || type == OP_REFGEN) &&
1389             !(o->op_flags & OPf_STACKED)) {
1390             o->op_type = OP_RV2CV;              /* entersub => rv2cv */
1391             /* The default is to set op_private to the number of children,
1392                which for a UNOP such as RV2CV is always 1. And w're using
1393                the bit for a flag in RV2CV, so we need it clear.  */
1394             o->op_private &= ~1;
1395             o->op_ppaddr = PL_ppaddr[OP_RV2CV];
1396             assert(cUNOPo->op_first->op_type == OP_NULL);
1397             op_null(((LISTOP*)cUNOPo->op_first)->op_first);/* disable pushmark */
1398             break;
1399         }
1400         else if (o->op_private & OPpENTERSUB_NOMOD)
1401             return o;
1402         else {                          /* lvalue subroutine call */
1403             o->op_private |= OPpLVAL_INTRO;
1404             PL_modcount = RETURN_UNLIMITED_NUMBER;
1405             if (type == OP_GREPSTART || type == OP_ENTERSUB || type == OP_REFGEN) {
1406                 /* Backward compatibility mode: */
1407                 o->op_private |= OPpENTERSUB_INARGS;
1408                 break;
1409             }
1410             else {                      /* Compile-time error message: */
1411                 OP *kid = cUNOPo->op_first;
1412                 CV *cv;
1413                 OP *okid;
1414
1415                 if (kid->op_type != OP_PUSHMARK) {
1416                     if (kid->op_type != OP_NULL || kid->op_targ != OP_LIST)
1417                         Perl_croak(aTHX_
1418                                 "panic: unexpected lvalue entersub "
1419                                 "args: type/targ %ld:%"UVuf,
1420                                 (long)kid->op_type, (UV)kid->op_targ);
1421                     kid = kLISTOP->op_first;
1422                 }
1423                 while (kid->op_sibling)
1424                     kid = kid->op_sibling;
1425                 if (!(kid->op_type == OP_NULL && kid->op_targ == OP_RV2CV)) {
1426                     /* Indirect call */
1427                     if (kid->op_type == OP_METHOD_NAMED
1428                         || kid->op_type == OP_METHOD)
1429                     {
1430                         UNOP *newop;
1431
1432                         NewOp(1101, newop, 1, UNOP);
1433                         newop->op_type = OP_RV2CV;
1434                         newop->op_ppaddr = PL_ppaddr[OP_RV2CV];
1435                         newop->op_first = NULL;
1436                         newop->op_next = (OP*)newop;
1437                         kid->op_sibling = (OP*)newop;
1438                         newop->op_private |= OPpLVAL_INTRO;
1439                         newop->op_private &= ~1;
1440                         break;
1441                     }
1442
1443                     if (kid->op_type != OP_RV2CV)
1444                         Perl_croak(aTHX_
1445                                    "panic: unexpected lvalue entersub "
1446                                    "entry via type/targ %ld:%"UVuf,
1447                                    (long)kid->op_type, (UV)kid->op_targ);
1448                     kid->op_private |= OPpLVAL_INTRO;
1449                     break;      /* Postpone until runtime */
1450                 }
1451
1452                 okid = kid;
1453                 kid = kUNOP->op_first;
1454                 if (kid->op_type == OP_NULL && kid->op_targ == OP_RV2SV)
1455                     kid = kUNOP->op_first;
1456                 if (kid->op_type == OP_NULL)
1457                     Perl_croak(aTHX_
1458                                "Unexpected constant lvalue entersub "
1459                                "entry via type/targ %ld:%"UVuf,
1460                                (long)kid->op_type, (UV)kid->op_targ);
1461                 if (kid->op_type != OP_GV) {
1462                     /* Restore RV2CV to check lvalueness */
1463                   restore_2cv:
1464                     if (kid->op_next && kid->op_next != kid) { /* Happens? */
1465                         okid->op_next = kid->op_next;
1466                         kid->op_next = okid;
1467                     }
1468                     else
1469                         okid->op_next = NULL;
1470                     okid->op_type = OP_RV2CV;
1471                     okid->op_targ = 0;
1472                     okid->op_ppaddr = PL_ppaddr[OP_RV2CV];
1473                     okid->op_private |= OPpLVAL_INTRO;
1474                     okid->op_private &= ~1;
1475                     break;
1476                 }
1477
1478                 cv = GvCV(kGVOP_gv);
1479                 if (!cv)
1480                     goto restore_2cv;
1481                 if (CvLVALUE(cv))
1482                     break;
1483             }
1484         }
1485         /* FALL THROUGH */
1486     default:
1487       nomod:
1488         /* grep, foreach, subcalls, refgen */
1489         if (type == OP_GREPSTART || type == OP_ENTERSUB || type == OP_REFGEN)
1490             break;
1491         yyerror(Perl_form(aTHX_ "Can't modify %s in %s",
1492                      (o->op_type == OP_NULL && (o->op_flags & OPf_SPECIAL)
1493                       ? "do block"
1494                       : (o->op_type == OP_ENTERSUB
1495                         ? "non-lvalue subroutine call"
1496                         : OP_DESC(o))),
1497                      type ? PL_op_desc[type] : "local"));
1498         return o;
1499
1500     case OP_PREINC:
1501     case OP_PREDEC:
1502     case OP_POW:
1503     case OP_MULTIPLY:
1504     case OP_DIVIDE:
1505     case OP_MODULO:
1506     case OP_REPEAT:
1507     case OP_ADD:
1508     case OP_SUBTRACT:
1509     case OP_CONCAT:
1510     case OP_LEFT_SHIFT:
1511     case OP_RIGHT_SHIFT:
1512     case OP_BIT_AND:
1513     case OP_BIT_XOR:
1514     case OP_BIT_OR:
1515     case OP_I_MULTIPLY:
1516     case OP_I_DIVIDE:
1517     case OP_I_MODULO:
1518     case OP_I_ADD:
1519     case OP_I_SUBTRACT:
1520         if (!(o->op_flags & OPf_STACKED))
1521             goto nomod;
1522         PL_modcount++;
1523         break;
1524
1525     case OP_COND_EXPR:
1526         localize = 1;
1527         for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
1528             mod(kid, type);
1529         break;
1530
1531     case OP_RV2AV:
1532     case OP_RV2HV:
1533         if (type == OP_REFGEN && o->op_flags & OPf_PARENS) {
1534            PL_modcount = RETURN_UNLIMITED_NUMBER;
1535             return o;           /* Treat \(@foo) like ordinary list. */
1536         }
1537         /* FALL THROUGH */
1538     case OP_RV2GV:
1539         if (scalar_mod_type(o, type))
1540             goto nomod;
1541         ref(cUNOPo->op_first, o->op_type);
1542         /* FALL THROUGH */
1543     case OP_ASLICE:
1544     case OP_HSLICE:
1545         if (type == OP_LEAVESUBLV)
1546             o->op_private |= OPpMAYBE_LVSUB;
1547         localize = 1;
1548         /* FALL THROUGH */
1549     case OP_AASSIGN:
1550     case OP_NEXTSTATE:
1551     case OP_DBSTATE:
1552        PL_modcount = RETURN_UNLIMITED_NUMBER;
1553         break;
1554     case OP_RV2SV:
1555         ref(cUNOPo->op_first, o->op_type);
1556         localize = 1;
1557         /* FALL THROUGH */
1558     case OP_GV:
1559     case OP_AV2ARYLEN:
1560         PL_hints |= HINT_BLOCK_SCOPE;
1561     case OP_SASSIGN:
1562     case OP_ANDASSIGN:
1563     case OP_ORASSIGN:
1564     case OP_DORASSIGN:
1565         PL_modcount++;
1566         break;
1567
1568     case OP_AELEMFAST:
1569         localize = -1;
1570         PL_modcount++;
1571         break;
1572
1573     case OP_PADAV:
1574     case OP_PADHV:
1575        PL_modcount = RETURN_UNLIMITED_NUMBER;
1576         if (type == OP_REFGEN && o->op_flags & OPf_PARENS)
1577             return o;           /* Treat \(@foo) like ordinary list. */
1578         if (scalar_mod_type(o, type))
1579             goto nomod;
1580         if (type == OP_LEAVESUBLV)
1581             o->op_private |= OPpMAYBE_LVSUB;
1582         /* FALL THROUGH */
1583     case OP_PADSV:
1584         PL_modcount++;
1585         if (!type) /* local() */
1586             Perl_croak(aTHX_ "Can't localize lexical variable %s",
1587                  PAD_COMPNAME_PV(o->op_targ));
1588         break;
1589
1590     case OP_PUSHMARK:
1591         localize = 0;
1592         break;
1593
1594     case OP_KEYS:
1595         if (type != OP_SASSIGN)
1596             goto nomod;
1597         goto lvalue_func;
1598     case OP_SUBSTR:
1599         if (o->op_private == 4) /* don't allow 4 arg substr as lvalue */
1600             goto nomod;
1601         /* FALL THROUGH */
1602     case OP_POS:
1603     case OP_VEC:
1604         if (type == OP_LEAVESUBLV)
1605             o->op_private |= OPpMAYBE_LVSUB;
1606       lvalue_func:
1607         pad_free(o->op_targ);
1608         o->op_targ = pad_alloc(o->op_type, SVs_PADMY);
1609         assert(SvTYPE(PAD_SV(o->op_targ)) == SVt_NULL);
1610         if (o->op_flags & OPf_KIDS)
1611             mod(cBINOPo->op_first->op_sibling, type);
1612         break;
1613
1614     case OP_AELEM:
1615     case OP_HELEM:
1616         ref(cBINOPo->op_first, o->op_type);
1617         if (type == OP_ENTERSUB &&
1618              !(o->op_private & (OPpLVAL_INTRO | OPpDEREF)))
1619             o->op_private |= OPpLVAL_DEFER;
1620         if (type == OP_LEAVESUBLV)
1621             o->op_private |= OPpMAYBE_LVSUB;
1622         localize = 1;
1623         PL_modcount++;
1624         break;
1625
1626     case OP_SCOPE:
1627     case OP_LEAVE:
1628     case OP_ENTER:
1629     case OP_LINESEQ:
1630         localize = 0;
1631         if (o->op_flags & OPf_KIDS)
1632             mod(cLISTOPo->op_last, type);
1633         break;
1634
1635     case OP_NULL:
1636         localize = 0;
1637         if (o->op_flags & OPf_SPECIAL)          /* do BLOCK */
1638             goto nomod;
1639         else if (!(o->op_flags & OPf_KIDS))
1640             break;
1641         if (o->op_targ != OP_LIST) {
1642             mod(cBINOPo->op_first, type);
1643             break;
1644         }
1645         /* FALL THROUGH */
1646     case OP_LIST:
1647         localize = 0;
1648         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
1649             mod(kid, type);
1650         break;
1651
1652     case OP_RETURN:
1653         if (type != OP_LEAVESUBLV)
1654             goto nomod;
1655         break; /* mod()ing was handled by ck_return() */
1656     }
1657
1658     /* [20011101.069] File test operators interpret OPf_REF to mean that
1659        their argument is a filehandle; thus \stat(".") should not set
1660        it. AMS 20011102 */
1661     if (type == OP_REFGEN &&
1662         PL_check[o->op_type] == MEMBER_TO_FPTR(Perl_ck_ftst))
1663         return o;
1664
1665     if (type != OP_LEAVESUBLV)
1666         o->op_flags |= OPf_MOD;
1667
1668     if (type == OP_AASSIGN || type == OP_SASSIGN)
1669         o->op_flags |= OPf_SPECIAL|OPf_REF;
1670     else if (!type) { /* local() */
1671         switch (localize) {
1672         case 1:
1673             o->op_private |= OPpLVAL_INTRO;
1674             o->op_flags &= ~OPf_SPECIAL;
1675             PL_hints |= HINT_BLOCK_SCOPE;
1676             break;
1677         case 0:
1678             break;
1679         case -1:
1680             if (ckWARN(WARN_SYNTAX)) {
1681                 Perl_warner(aTHX_ packWARN(WARN_SYNTAX),
1682                     "Useless localization of %s", OP_DESC(o));
1683             }
1684         }
1685     }
1686     else if (type != OP_GREPSTART && type != OP_ENTERSUB
1687              && type != OP_LEAVESUBLV)
1688         o->op_flags |= OPf_REF;
1689     return o;
1690 }
1691
1692 STATIC bool
1693 S_scalar_mod_type(const OP *o, I32 type)
1694 {
1695     PERL_ARGS_ASSERT_SCALAR_MOD_TYPE;
1696
1697     switch (type) {
1698     case OP_SASSIGN:
1699         if (o->op_type == OP_RV2GV)
1700             return FALSE;
1701         /* FALL THROUGH */
1702     case OP_PREINC:
1703     case OP_PREDEC:
1704     case OP_POSTINC:
1705     case OP_POSTDEC:
1706     case OP_I_PREINC:
1707     case OP_I_PREDEC:
1708     case OP_I_POSTINC:
1709     case OP_I_POSTDEC:
1710     case OP_POW:
1711     case OP_MULTIPLY:
1712     case OP_DIVIDE:
1713     case OP_MODULO:
1714     case OP_REPEAT:
1715     case OP_ADD:
1716     case OP_SUBTRACT:
1717     case OP_I_MULTIPLY:
1718     case OP_I_DIVIDE:
1719     case OP_I_MODULO:
1720     case OP_I_ADD:
1721     case OP_I_SUBTRACT:
1722     case OP_LEFT_SHIFT:
1723     case OP_RIGHT_SHIFT:
1724     case OP_BIT_AND:
1725     case OP_BIT_XOR:
1726     case OP_BIT_OR:
1727     case OP_CONCAT:
1728     case OP_SUBST:
1729     case OP_TRANS:
1730     case OP_READ:
1731     case OP_SYSREAD:
1732     case OP_RECV:
1733     case OP_ANDASSIGN:
1734     case OP_ORASSIGN:
1735     case OP_DORASSIGN:
1736         return TRUE;
1737     default:
1738         return FALSE;
1739     }
1740 }
1741
1742 STATIC bool
1743 S_is_handle_constructor(const OP *o, I32 numargs)
1744 {
1745     PERL_ARGS_ASSERT_IS_HANDLE_CONSTRUCTOR;
1746
1747     switch (o->op_type) {
1748     case OP_PIPE_OP:
1749     case OP_SOCKPAIR:
1750         if (numargs == 2)
1751             return TRUE;
1752         /* FALL THROUGH */
1753     case OP_SYSOPEN:
1754     case OP_OPEN:
1755     case OP_SELECT:             /* XXX c.f. SelectSaver.pm */
1756     case OP_SOCKET:
1757     case OP_OPEN_DIR:
1758     case OP_ACCEPT:
1759         if (numargs == 1)
1760             return TRUE;
1761         /* FALLTHROUGH */
1762     default:
1763         return FALSE;
1764     }
1765 }
1766
1767 static OP *
1768 S_refkids(pTHX_ OP *o, I32 type)
1769 {
1770     if (o && o->op_flags & OPf_KIDS) {
1771         OP *kid;
1772         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
1773             ref(kid, type);
1774     }
1775     return o;
1776 }
1777
1778 OP *
1779 Perl_doref(pTHX_ OP *o, I32 type, bool set_op_ref)
1780 {
1781     dVAR;
1782     OP *kid;
1783
1784     PERL_ARGS_ASSERT_DOREF;
1785
1786     if (!o || (PL_parser && PL_parser->error_count))
1787         return o;
1788
1789     switch (o->op_type) {
1790     case OP_ENTERSUB:
1791         if ((type == OP_EXISTS || type == OP_DEFINED || type == OP_LOCK) &&
1792             !(o->op_flags & OPf_STACKED)) {
1793             o->op_type = OP_RV2CV;             /* entersub => rv2cv */
1794             o->op_ppaddr = PL_ppaddr[OP_RV2CV];
1795             assert(cUNOPo->op_first->op_type == OP_NULL);
1796             op_null(((LISTOP*)cUNOPo->op_first)->op_first);     /* disable pushmark */
1797             o->op_flags |= OPf_SPECIAL;
1798             o->op_private &= ~1;
1799         }
1800         break;
1801
1802     case OP_COND_EXPR:
1803         for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
1804             doref(kid, type, set_op_ref);
1805         break;
1806     case OP_RV2SV:
1807         if (type == OP_DEFINED)
1808             o->op_flags |= OPf_SPECIAL;         /* don't create GV */
1809         doref(cUNOPo->op_first, o->op_type, set_op_ref);
1810         /* FALL THROUGH */
1811     case OP_PADSV:
1812         if (type == OP_RV2SV || type == OP_RV2AV || type == OP_RV2HV) {
1813             o->op_private |= (type == OP_RV2AV ? OPpDEREF_AV
1814                               : type == OP_RV2HV ? OPpDEREF_HV
1815                               : OPpDEREF_SV);
1816             o->op_flags |= OPf_MOD;
1817         }
1818         break;
1819
1820     case OP_RV2AV:
1821     case OP_RV2HV:
1822         if (set_op_ref)
1823             o->op_flags |= OPf_REF;
1824         /* FALL THROUGH */
1825     case OP_RV2GV:
1826         if (type == OP_DEFINED)
1827             o->op_flags |= OPf_SPECIAL;         /* don't create GV */
1828         doref(cUNOPo->op_first, o->op_type, set_op_ref);
1829         break;
1830
1831     case OP_PADAV:
1832     case OP_PADHV:
1833         if (set_op_ref)
1834             o->op_flags |= OPf_REF;
1835         break;
1836
1837     case OP_SCALAR:
1838     case OP_NULL:
1839         if (!(o->op_flags & OPf_KIDS))
1840             break;
1841         doref(cBINOPo->op_first, type, set_op_ref);
1842         break;
1843     case OP_AELEM:
1844     case OP_HELEM:
1845         doref(cBINOPo->op_first, o->op_type, set_op_ref);
1846         if (type == OP_RV2SV || type == OP_RV2AV || type == OP_RV2HV) {
1847             o->op_private |= (type == OP_RV2AV ? OPpDEREF_AV
1848                               : type == OP_RV2HV ? OPpDEREF_HV
1849                               : OPpDEREF_SV);
1850             o->op_flags |= OPf_MOD;
1851         }
1852         break;
1853
1854     case OP_SCOPE:
1855     case OP_LEAVE:
1856         set_op_ref = FALSE;
1857         /* FALL THROUGH */
1858     case OP_ENTER:
1859     case OP_LIST:
1860         if (!(o->op_flags & OPf_KIDS))
1861             break;
1862         doref(cLISTOPo->op_last, type, set_op_ref);
1863         break;
1864     default:
1865         break;
1866     }
1867     return scalar(o);
1868
1869 }
1870
1871 STATIC OP *
1872 S_dup_attrlist(pTHX_ OP *o)
1873 {
1874     dVAR;
1875     OP *rop;
1876
1877     PERL_ARGS_ASSERT_DUP_ATTRLIST;
1878
1879     /* An attrlist is either a simple OP_CONST or an OP_LIST with kids,
1880      * where the first kid is OP_PUSHMARK and the remaining ones
1881      * are OP_CONST.  We need to push the OP_CONST values.
1882      */
1883     if (o->op_type == OP_CONST)
1884         rop = newSVOP(OP_CONST, o->op_flags, SvREFCNT_inc_NN(cSVOPo->op_sv));
1885 #ifdef PERL_MAD
1886     else if (o->op_type == OP_NULL)
1887         rop = NULL;
1888 #endif
1889     else {
1890         assert((o->op_type == OP_LIST) && (o->op_flags & OPf_KIDS));
1891         rop = NULL;
1892         for (o = cLISTOPo->op_first; o; o=o->op_sibling) {
1893             if (o->op_type == OP_CONST)
1894                 rop = append_elem(OP_LIST, rop,
1895                                   newSVOP(OP_CONST, o->op_flags,
1896                                           SvREFCNT_inc_NN(cSVOPo->op_sv)));
1897         }
1898     }
1899     return rop;
1900 }
1901
1902 STATIC void
1903 S_apply_attrs(pTHX_ HV *stash, SV *target, OP *attrs, bool for_my)
1904 {
1905     dVAR;
1906     SV *stashsv;
1907
1908     PERL_ARGS_ASSERT_APPLY_ATTRS;
1909
1910     /* fake up C<use attributes $pkg,$rv,@attrs> */
1911     ENTER;              /* need to protect against side-effects of 'use' */
1912     stashsv = stash ? newSVhek(HvNAME_HEK(stash)) : &PL_sv_no;
1913
1914 #define ATTRSMODULE "attributes"
1915 #define ATTRSMODULE_PM "attributes.pm"
1916
1917     if (for_my) {
1918         /* Don't force the C<use> if we don't need it. */
1919         SV * const * const svp = hv_fetchs(GvHVn(PL_incgv), ATTRSMODULE_PM, FALSE);
1920         if (svp && *svp != &PL_sv_undef)
1921             NOOP;       /* already in %INC */
1922         else
1923             Perl_load_module(aTHX_ PERL_LOADMOD_NOIMPORT,
1924                              newSVpvs(ATTRSMODULE), NULL);
1925     }
1926     else {
1927         Perl_load_module(aTHX_ PERL_LOADMOD_IMPORT_OPS,
1928                          newSVpvs(ATTRSMODULE),
1929                          NULL,
1930                          prepend_elem(OP_LIST,
1931                                       newSVOP(OP_CONST, 0, stashsv),
1932                                       prepend_elem(OP_LIST,
1933                                                    newSVOP(OP_CONST, 0,
1934                                                            newRV(target)),
1935                                                    dup_attrlist(attrs))));
1936     }
1937     LEAVE;
1938 }
1939
1940 STATIC void
1941 S_apply_attrs_my(pTHX_ HV *stash, OP *target, OP *attrs, OP **imopsp)
1942 {
1943     dVAR;
1944     OP *pack, *imop, *arg;
1945     SV *meth, *stashsv;
1946
1947     PERL_ARGS_ASSERT_APPLY_ATTRS_MY;
1948
1949     if (!attrs)
1950         return;
1951
1952     assert(target->op_type == OP_PADSV ||
1953            target->op_type == OP_PADHV ||
1954            target->op_type == OP_PADAV);
1955
1956     /* Ensure that attributes.pm is loaded. */
1957     apply_attrs(stash, PAD_SV(target->op_targ), attrs, TRUE);
1958
1959     /* Need package name for method call. */
1960     pack = newSVOP(OP_CONST, 0, newSVpvs(ATTRSMODULE));
1961
1962     /* Build up the real arg-list. */
1963     stashsv = stash ? newSVhek(HvNAME_HEK(stash)) : &PL_sv_no;
1964
1965     arg = newOP(OP_PADSV, 0);
1966     arg->op_targ = target->op_targ;
1967     arg = prepend_elem(OP_LIST,
1968                        newSVOP(OP_CONST, 0, stashsv),
1969                        prepend_elem(OP_LIST,
1970                                     newUNOP(OP_REFGEN, 0,
1971                                             mod(arg, OP_REFGEN)),
1972                                     dup_attrlist(attrs)));
1973
1974     /* Fake up a method call to import */
1975     meth = newSVpvs_share("import");
1976     imop = convert(OP_ENTERSUB, OPf_STACKED|OPf_SPECIAL|OPf_WANT_VOID,
1977                    append_elem(OP_LIST,
1978                                prepend_elem(OP_LIST, pack, list(arg)),
1979                                newSVOP(OP_METHOD_NAMED, 0, meth)));
1980     imop->op_private |= OPpENTERSUB_NOMOD;
1981
1982     /* Combine the ops. */
1983     *imopsp = append_elem(OP_LIST, *imopsp, imop);
1984 }
1985
1986 /*
1987 =notfor apidoc apply_attrs_string
1988
1989 Attempts to apply a list of attributes specified by the C<attrstr> and
1990 C<len> arguments to the subroutine identified by the C<cv> argument which
1991 is expected to be associated with the package identified by the C<stashpv>
1992 argument (see L<attributes>).  It gets this wrong, though, in that it
1993 does not correctly identify the boundaries of the individual attribute
1994 specifications within C<attrstr>.  This is not really intended for the
1995 public API, but has to be listed here for systems such as AIX which
1996 need an explicit export list for symbols.  (It's called from XS code
1997 in support of the C<ATTRS:> keyword from F<xsubpp>.)  Patches to fix it
1998 to respect attribute syntax properly would be welcome.
1999
2000 =cut
2001 */
2002
2003 void
2004 Perl_apply_attrs_string(pTHX_ const char *stashpv, CV *cv,
2005                         const char *attrstr, STRLEN len)
2006 {
2007     OP *attrs = NULL;
2008
2009     PERL_ARGS_ASSERT_APPLY_ATTRS_STRING;
2010
2011     if (!len) {
2012         len = strlen(attrstr);
2013     }
2014
2015     while (len) {
2016         for (; isSPACE(*attrstr) && len; --len, ++attrstr) ;
2017         if (len) {
2018             const char * const sstr = attrstr;
2019             for (; !isSPACE(*attrstr) && len; --len, ++attrstr) ;
2020             attrs = append_elem(OP_LIST, attrs,
2021                                 newSVOP(OP_CONST, 0,
2022                                         newSVpvn(sstr, attrstr-sstr)));
2023         }
2024     }
2025
2026     Perl_load_module(aTHX_ PERL_LOADMOD_IMPORT_OPS,
2027                      newSVpvs(ATTRSMODULE),
2028                      NULL, prepend_elem(OP_LIST,
2029                                   newSVOP(OP_CONST, 0, newSVpv(stashpv,0)),
2030                                   prepend_elem(OP_LIST,
2031                                                newSVOP(OP_CONST, 0,
2032                                                        newRV(MUTABLE_SV(cv))),
2033                                                attrs)));
2034 }
2035
2036 STATIC OP *
2037 S_my_kid(pTHX_ OP *o, OP *attrs, OP **imopsp)
2038 {
2039     dVAR;
2040     I32 type;
2041
2042     PERL_ARGS_ASSERT_MY_KID;
2043
2044     if (!o || (PL_parser && PL_parser->error_count))
2045         return o;
2046
2047     type = o->op_type;
2048     if (PL_madskills && type == OP_NULL && o->op_flags & OPf_KIDS) {
2049         (void)my_kid(cUNOPo->op_first, attrs, imopsp);
2050         return o;
2051     }
2052
2053     if (type == OP_LIST) {
2054         OP *kid;
2055         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
2056             my_kid(kid, attrs, imopsp);
2057     } else if (type == OP_UNDEF
2058 #ifdef PERL_MAD
2059                || type == OP_STUB
2060 #endif
2061                ) {
2062         return o;
2063     } else if (type == OP_RV2SV ||      /* "our" declaration */
2064                type == OP_RV2AV ||
2065                type == OP_RV2HV) { /* XXX does this let anything illegal in? */
2066         if (cUNOPo->op_first->op_type != OP_GV) { /* MJD 20011224 */
2067             yyerror(Perl_form(aTHX_ "Can't declare %s in \"%s\"",
2068                         OP_DESC(o),
2069                         PL_parser->in_my == KEY_our
2070                             ? "our"
2071                             : PL_parser->in_my == KEY_state ? "state" : "my"));
2072         } else if (attrs) {
2073             GV * const gv = cGVOPx_gv(cUNOPo->op_first);
2074             PL_parser->in_my = FALSE;
2075             PL_parser->in_my_stash = NULL;
2076             apply_attrs(GvSTASH(gv),
2077                         (type == OP_RV2SV ? GvSV(gv) :
2078                          type == OP_RV2AV ? MUTABLE_SV(GvAV(gv)) :
2079                          type == OP_RV2HV ? MUTABLE_SV(GvHV(gv)) : MUTABLE_SV(gv)),
2080                         attrs, FALSE);
2081         }
2082         o->op_private |= OPpOUR_INTRO;
2083         return o;
2084     }
2085     else if (type != OP_PADSV &&
2086              type != OP_PADAV &&
2087              type != OP_PADHV &&
2088              type != OP_PUSHMARK)
2089     {
2090         yyerror(Perl_form(aTHX_ "Can't declare %s in \"%s\"",
2091                           OP_DESC(o),
2092                           PL_parser->in_my == KEY_our
2093                             ? "our"
2094                             : PL_parser->in_my == KEY_state ? "state" : "my"));
2095         return o;
2096     }
2097     else if (attrs && type != OP_PUSHMARK) {
2098         HV *stash;
2099
2100         PL_parser->in_my = FALSE;
2101         PL_parser->in_my_stash = NULL;
2102
2103         /* check for C<my Dog $spot> when deciding package */
2104         stash = PAD_COMPNAME_TYPE(o->op_targ);
2105         if (!stash)
2106             stash = PL_curstash;
2107         apply_attrs_my(stash, o, attrs, imopsp);
2108     }
2109     o->op_flags |= OPf_MOD;
2110     o->op_private |= OPpLVAL_INTRO;
2111     if (PL_parser->in_my == KEY_state)
2112         o->op_private |= OPpPAD_STATE;
2113     return o;
2114 }
2115
2116 OP *
2117 Perl_my_attrs(pTHX_ OP *o, OP *attrs)
2118 {
2119     dVAR;
2120     OP *rops;
2121     int maybe_scalar = 0;
2122
2123     PERL_ARGS_ASSERT_MY_ATTRS;
2124
2125 /* [perl #17376]: this appears to be premature, and results in code such as
2126    C< our(%x); > executing in list mode rather than void mode */
2127 #if 0
2128     if (o->op_flags & OPf_PARENS)
2129         list(o);
2130     else
2131         maybe_scalar = 1;
2132 #else
2133     maybe_scalar = 1;
2134 #endif
2135     if (attrs)
2136         SAVEFREEOP(attrs);
2137     rops = NULL;
2138     o = my_kid(o, attrs, &rops);
2139     if (rops) {
2140         if (maybe_scalar && o->op_type == OP_PADSV) {
2141             o = scalar(append_list(OP_LIST, (LISTOP*)rops, (LISTOP*)o));
2142             o->op_private |= OPpLVAL_INTRO;
2143         }
2144         else
2145             o = append_list(OP_LIST, (LISTOP*)o, (LISTOP*)rops);
2146     }
2147     PL_parser->in_my = FALSE;
2148     PL_parser->in_my_stash = NULL;
2149     return o;
2150 }
2151
2152 OP *
2153 Perl_sawparens(pTHX_ OP *o)
2154 {
2155     PERL_UNUSED_CONTEXT;
2156     if (o)
2157         o->op_flags |= OPf_PARENS;
2158     return o;
2159 }
2160
2161 OP *
2162 Perl_bind_match(pTHX_ I32 type, OP *left, OP *right)
2163 {
2164     OP *o;
2165     bool ismatchop = 0;
2166     const OPCODE ltype = left->op_type;
2167     const OPCODE rtype = right->op_type;
2168
2169     PERL_ARGS_ASSERT_BIND_MATCH;
2170
2171     if ( (ltype == OP_RV2AV || ltype == OP_RV2HV || ltype == OP_PADAV
2172           || ltype == OP_PADHV) && ckWARN(WARN_MISC))
2173     {
2174       const char * const desc
2175           = PL_op_desc[(rtype == OP_SUBST || rtype == OP_TRANS)
2176                        ? (int)rtype : OP_MATCH];
2177       const char * const sample = ((ltype == OP_RV2AV || ltype == OP_PADAV)
2178              ? "@array" : "%hash");
2179       Perl_warner(aTHX_ packWARN(WARN_MISC),
2180              "Applying %s to %s will act on scalar(%s)",
2181              desc, sample, sample);
2182     }
2183
2184     if (rtype == OP_CONST &&
2185         cSVOPx(right)->op_private & OPpCONST_BARE &&
2186         cSVOPx(right)->op_private & OPpCONST_STRICT)
2187     {
2188         no_bareword_allowed(right);
2189     }
2190
2191     ismatchop = rtype == OP_MATCH ||
2192                 rtype == OP_SUBST ||
2193                 rtype == OP_TRANS;
2194     if (ismatchop && right->op_private & OPpTARGET_MY) {
2195         right->op_targ = 0;
2196         right->op_private &= ~OPpTARGET_MY;
2197     }
2198     if (!(right->op_flags & OPf_STACKED) && ismatchop) {
2199         OP *newleft;
2200
2201         right->op_flags |= OPf_STACKED;
2202         if (rtype != OP_MATCH &&
2203             ! (rtype == OP_TRANS &&
2204                right->op_private & OPpTRANS_IDENTICAL))
2205             newleft = mod(left, rtype);
2206         else
2207             newleft = left;
2208         if (right->op_type == OP_TRANS)
2209             o = newBINOP(OP_NULL, OPf_STACKED, scalar(newleft), right);
2210         else
2211             o = prepend_elem(rtype, scalar(newleft), right);
2212         if (type == OP_NOT)
2213             return newUNOP(OP_NOT, 0, scalar(o));
2214         return o;
2215     }
2216     else
2217         return bind_match(type, left,
2218                 pmruntime(newPMOP(OP_MATCH, 0), right, 0));
2219 }
2220
2221 OP *
2222 Perl_invert(pTHX_ OP *o)
2223 {
2224     if (!o)
2225         return NULL;
2226     return newUNOP(OP_NOT, OPf_SPECIAL, scalar(o));
2227 }
2228
2229 OP *
2230 Perl_scope(pTHX_ OP *o)
2231 {
2232     dVAR;
2233     if (o) {
2234         if (o->op_flags & OPf_PARENS || PERLDB_NOOPT || PL_tainting) {
2235             o = prepend_elem(OP_LINESEQ, newOP(OP_ENTER, 0), o);
2236             o->op_type = OP_LEAVE;
2237             o->op_ppaddr = PL_ppaddr[OP_LEAVE];
2238         }
2239         else if (o->op_type == OP_LINESEQ) {
2240             OP *kid;
2241             o->op_type = OP_SCOPE;
2242             o->op_ppaddr = PL_ppaddr[OP_SCOPE];
2243             kid = ((LISTOP*)o)->op_first;
2244             if (kid->op_type == OP_NEXTSTATE || kid->op_type == OP_DBSTATE) {
2245                 op_null(kid);
2246
2247                 /* The following deals with things like 'do {1 for 1}' */
2248                 kid = kid->op_sibling;
2249                 if (kid &&
2250                     (kid->op_type == OP_NEXTSTATE || kid->op_type == OP_DBSTATE))
2251                     op_null(kid);
2252             }
2253         }
2254         else
2255             o = newLISTOP(OP_SCOPE, 0, o, NULL);
2256     }
2257     return o;
2258 }
2259         
2260 int
2261 Perl_block_start(pTHX_ int full)
2262 {
2263     dVAR;
2264     const int retval = PL_savestack_ix;
2265     pad_block_start(full);
2266     SAVEHINTS();
2267     PL_hints &= ~HINT_BLOCK_SCOPE;
2268     SAVECOMPILEWARNINGS();
2269     PL_compiling.cop_warnings = DUP_WARNINGS(PL_compiling.cop_warnings);
2270     return retval;
2271 }
2272
2273 OP*
2274 Perl_block_end(pTHX_ I32 floor, OP *seq)
2275 {
2276     dVAR;
2277     const int needblockscope = PL_hints & HINT_BLOCK_SCOPE;
2278     OP* const retval = scalarseq(seq);
2279     LEAVE_SCOPE(floor);
2280     CopHINTS_set(&PL_compiling, PL_hints);
2281     if (needblockscope)
2282         PL_hints |= HINT_BLOCK_SCOPE; /* propagate out */
2283     pad_leavemy();
2284     return retval;
2285 }
2286
2287 STATIC OP *
2288 S_newDEFSVOP(pTHX)
2289 {
2290     dVAR;
2291     const PADOFFSET offset = pad_findmy("$_");
2292     if (offset == NOT_IN_PAD || PAD_COMPNAME_FLAGS_isOUR(offset)) {
2293         return newSVREF(newGVOP(OP_GV, 0, PL_defgv));
2294     }
2295     else {
2296         OP * const o = newOP(OP_PADSV, 0);
2297         o->op_targ = offset;
2298         return o;
2299     }
2300 }
2301
2302 void
2303 Perl_newPROG(pTHX_ OP *o)
2304 {
2305     dVAR;
2306
2307     PERL_ARGS_ASSERT_NEWPROG;
2308
2309     if (PL_in_eval) {
2310         if (PL_eval_root)
2311                 return;
2312         PL_eval_root = newUNOP(OP_LEAVEEVAL,
2313                                ((PL_in_eval & EVAL_KEEPERR)
2314                                 ? OPf_SPECIAL : 0), o);
2315         PL_eval_start = linklist(PL_eval_root);
2316         PL_eval_root->op_private |= OPpREFCOUNTED;
2317         OpREFCNT_set(PL_eval_root, 1);
2318         PL_eval_root->op_next = 0;
2319         CALL_PEEP(PL_eval_start);
2320     }
2321     else {
2322         if (o->op_type == OP_STUB) {
2323             PL_comppad_name = 0;
2324             PL_compcv = 0;
2325             S_op_destroy(aTHX_ o);
2326             return;
2327         }
2328         PL_main_root = scope(sawparens(scalarvoid(o)));
2329         PL_curcop = &PL_compiling;
2330         PL_main_start = LINKLIST(PL_main_root);
2331         PL_main_root->op_private |= OPpREFCOUNTED;
2332         OpREFCNT_set(PL_main_root, 1);
2333         PL_main_root->op_next = 0;
2334         CALL_PEEP(PL_main_start);
2335         PL_compcv = 0;
2336
2337         /* Register with debugger */
2338         if (PERLDB_INTER) {
2339             CV * const cv = get_cvs("DB::postponed", 0);
2340             if (cv) {
2341                 dSP;
2342                 PUSHMARK(SP);
2343                 XPUSHs(MUTABLE_SV(CopFILEGV(&PL_compiling)));
2344                 PUTBACK;
2345                 call_sv(MUTABLE_SV(cv), G_DISCARD);
2346             }
2347         }
2348     }
2349 }
2350
2351 OP *
2352 Perl_localize(pTHX_ OP *o, I32 lex)
2353 {
2354     dVAR;
2355
2356     PERL_ARGS_ASSERT_LOCALIZE;
2357
2358     if (o->op_flags & OPf_PARENS)
2359 /* [perl #17376]: this appears to be premature, and results in code such as
2360    C< our(%x); > executing in list mode rather than void mode */
2361 #if 0
2362         list(o);
2363 #else
2364         NOOP;
2365 #endif
2366     else {
2367         if ( PL_parser->bufptr > PL_parser->oldbufptr
2368             && PL_parser->bufptr[-1] == ','
2369             && ckWARN(WARN_PARENTHESIS))
2370         {
2371             char *s = PL_parser->bufptr;
2372             bool sigil = FALSE;
2373
2374             /* some heuristics to detect a potential error */
2375             while (*s && (strchr(", \t\n", *s)))
2376                 s++;
2377
2378             while (1) {
2379                 if (*s && strchr("@$%*", *s) && *++s
2380                        && (isALNUM(*s) || UTF8_IS_CONTINUED(*s))) {
2381                     s++;
2382                     sigil = TRUE;
2383                     while (*s && (isALNUM(*s) || UTF8_IS_CONTINUED(*s)))
2384                         s++;
2385                     while (*s && (strchr(", \t\n", *s)))
2386                         s++;
2387                 }
2388                 else
2389                     break;
2390             }
2391             if (sigil && (*s == ';' || *s == '=')) {
2392                 Perl_warner(aTHX_ packWARN(WARN_PARENTHESIS),
2393                                 "Parentheses missing around \"%s\" list",
2394                                 lex
2395                                     ? (PL_parser->in_my == KEY_our
2396                                         ? "our"
2397                                         : PL_parser->in_my == KEY_state
2398                                             ? "state"
2399                                             : "my")
2400                                     : "local");
2401             }
2402         }
2403     }
2404     if (lex)
2405         o = my(o);
2406     else
2407         o = mod(o, OP_NULL);            /* a bit kludgey */
2408     PL_parser->in_my = FALSE;
2409     PL_parser->in_my_stash = NULL;
2410     return o;
2411 }
2412
2413 OP *
2414 Perl_jmaybe(pTHX_ OP *o)
2415 {
2416     PERL_ARGS_ASSERT_JMAYBE;
2417
2418     if (o->op_type == OP_LIST) {
2419         OP * const o2
2420             = newSVREF(newGVOP(OP_GV, 0, gv_fetchpvs(";", GV_ADD|GV_NOTQUAL, SVt_PV)));
2421         o = convert(OP_JOIN, 0, prepend_elem(OP_LIST, o2, o));
2422     }
2423     return o;
2424 }
2425
2426 static OP *
2427 S_fold_constants(pTHX_ register OP *o)
2428 {
2429     dVAR;
2430     register OP * VOL curop;
2431     OP *newop;
2432     VOL I32 type = o->op_type;
2433     SV * VOL sv = NULL;
2434     int ret = 0;
2435     I32 oldscope;
2436     OP *old_next;
2437     SV * const oldwarnhook = PL_warnhook;
2438     SV * const olddiehook  = PL_diehook;
2439     COP not_compiling;
2440     dJMPENV;
2441
2442     PERL_ARGS_ASSERT_FOLD_CONSTANTS;
2443
2444     if (PL_opargs[type] & OA_RETSCALAR)
2445         scalar(o);
2446     if (PL_opargs[type] & OA_TARGET && !o->op_targ)
2447         o->op_targ = pad_alloc(type, SVs_PADTMP);
2448
2449     /* integerize op, unless it happens to be C<-foo>.
2450      * XXX should pp_i_negate() do magic string negation instead? */
2451     if ((PL_opargs[type] & OA_OTHERINT) && (PL_hints & HINT_INTEGER)
2452         && !(type == OP_NEGATE && cUNOPo->op_first->op_type == OP_CONST
2453              && (cUNOPo->op_first->op_private & OPpCONST_BARE)))
2454     {
2455         o->op_ppaddr = PL_ppaddr[type = ++(o->op_type)];
2456     }
2457
2458     if (!(PL_opargs[type] & OA_FOLDCONST))
2459         goto nope;
2460
2461     switch (type) {
2462     case OP_NEGATE:
2463         /* XXX might want a ck_negate() for this */
2464         cUNOPo->op_first->op_private &= ~OPpCONST_STRICT;
2465         break;
2466     case OP_UCFIRST:
2467     case OP_LCFIRST:
2468     case OP_UC:
2469     case OP_LC:
2470     case OP_SLT:
2471     case OP_SGT:
2472     case OP_SLE:
2473     case OP_SGE:
2474     case OP_SCMP:
2475         /* XXX what about the numeric ops? */
2476         if (PL_hints & HINT_LOCALE)
2477             goto nope;
2478         break;
2479     }
2480
2481     if (PL_parser && PL_parser->error_count)
2482         goto nope;              /* Don't try to run w/ errors */
2483
2484     for (curop = LINKLIST(o); curop != o; curop = LINKLIST(curop)) {
2485         const OPCODE type = curop->op_type;
2486         if ((type != OP_CONST || (curop->op_private & OPpCONST_BARE)) &&
2487             type != OP_LIST &&
2488             type != OP_SCALAR &&
2489             type != OP_NULL &&
2490             type != OP_PUSHMARK)
2491         {
2492             goto nope;
2493         }
2494     }
2495
2496     curop = LINKLIST(o);
2497     old_next = o->op_next;
2498     o->op_next = 0;
2499     PL_op = curop;
2500
2501     oldscope = PL_scopestack_ix;
2502     create_eval_scope(G_FAKINGEVAL);
2503
2504     /* Verify that we don't need to save it:  */
2505     assert(PL_curcop == &PL_compiling);
2506     StructCopy(&PL_compiling, &not_compiling, COP);
2507     PL_curcop = &not_compiling;
2508     /* The above ensures that we run with all the correct hints of the
2509        currently compiling COP, but that IN_PERL_RUNTIME is not true. */
2510     assert(IN_PERL_RUNTIME);
2511     PL_warnhook = PERL_WARNHOOK_FATAL;
2512     PL_diehook  = NULL;
2513     JMPENV_PUSH(ret);
2514
2515     switch (ret) {
2516     case 0:
2517         CALLRUNOPS(aTHX);
2518         sv = *(PL_stack_sp--);
2519         if (o->op_targ && sv == PAD_SV(o->op_targ))     /* grab pad temp? */
2520             pad_swipe(o->op_targ,  FALSE);
2521         else if (SvTEMP(sv)) {                  /* grab mortal temp? */
2522             SvREFCNT_inc_simple_void(sv);
2523             SvTEMP_off(sv);
2524         }
2525         break;
2526     case 3:
2527         /* Something tried to die.  Abandon constant folding.  */
2528         /* Pretend the error never happened.  */
2529         CLEAR_ERRSV();
2530         o->op_next = old_next;
2531         break;
2532     default:
2533         JMPENV_POP;
2534         /* Don't expect 1 (setjmp failed) or 2 (something called my_exit)  */
2535         PL_warnhook = oldwarnhook;
2536         PL_diehook  = olddiehook;
2537         /* XXX note that this croak may fail as we've already blown away
2538          * the stack - eg any nested evals */
2539         Perl_croak(aTHX_ "panic: fold_constants JMPENV_PUSH returned %d", ret);
2540     }
2541     JMPENV_POP;
2542     PL_warnhook = oldwarnhook;
2543     PL_diehook  = olddiehook;
2544     PL_curcop = &PL_compiling;
2545
2546     if (PL_scopestack_ix > oldscope)
2547         delete_eval_scope();
2548
2549     if (ret)
2550         goto nope;
2551
2552 #ifndef PERL_MAD
2553     op_free(o);
2554 #endif
2555     assert(sv);
2556     if (type == OP_RV2GV)
2557         newop = newGVOP(OP_GV, 0, MUTABLE_GV(sv));
2558     else
2559         newop = newSVOP(OP_CONST, 0, MUTABLE_SV(sv));
2560     op_getmad(o,newop,'f');
2561     return newop;
2562
2563  nope:
2564     return o;
2565 }
2566
2567 static OP *
2568 S_gen_constant_list(pTHX_ register OP *o)
2569 {
2570     dVAR;
2571     register OP *curop;
2572     const I32 oldtmps_floor = PL_tmps_floor;
2573
2574     list(o);
2575     if (PL_parser && PL_parser->error_count)
2576         return o;               /* Don't attempt to run with errors */
2577
2578     PL_op = curop = LINKLIST(o);
2579     o->op_next = 0;
2580     CALL_PEEP(curop);
2581     pp_pushmark();
2582     CALLRUNOPS(aTHX);
2583     PL_op = curop;
2584     assert (!(curop->op_flags & OPf_SPECIAL));
2585     assert(curop->op_type == OP_RANGE);
2586     pp_anonlist();
2587     PL_tmps_floor = oldtmps_floor;
2588
2589     o->op_type = OP_RV2AV;
2590     o->op_ppaddr = PL_ppaddr[OP_RV2AV];
2591     o->op_flags &= ~OPf_REF;    /* treat \(1..2) like an ordinary list */
2592     o->op_flags |= OPf_PARENS;  /* and flatten \(1..2,3) */
2593     o->op_opt = 0;              /* needs to be revisited in peep() */
2594     curop = ((UNOP*)o)->op_first;
2595     ((UNOP*)o)->op_first = newSVOP(OP_CONST, 0, SvREFCNT_inc_NN(*PL_stack_sp--));
2596 #ifdef PERL_MAD
2597     op_getmad(curop,o,'O');
2598 #else
2599     op_free(curop);
2600 #endif
2601     linklist(o);
2602     return list(o);
2603 }
2604
2605 OP *
2606 Perl_convert(pTHX_ I32 type, I32 flags, OP *o)
2607 {
2608     dVAR;
2609     if (!o || o->op_type != OP_LIST)
2610         o = newLISTOP(OP_LIST, 0, o, NULL);
2611     else
2612         o->op_flags &= ~OPf_WANT;
2613
2614     if (!(PL_opargs[type] & OA_MARK))
2615         op_null(cLISTOPo->op_first);
2616
2617     o->op_type = (OPCODE)type;
2618     o->op_ppaddr = PL_ppaddr[type];
2619     o->op_flags |= flags;
2620
2621     o = CHECKOP(type, o);
2622     if (o->op_type != (unsigned)type)
2623         return o;
2624
2625     return fold_constants(o);
2626 }
2627
2628 /* List constructors */
2629
2630 OP *
2631 Perl_append_elem(pTHX_ I32 type, OP *first, OP *last)
2632 {
2633     if (!first)
2634         return last;
2635
2636     if (!last)
2637         return first;
2638
2639     if (first->op_type != (unsigned)type
2640         || (type == OP_LIST && (first->op_flags & OPf_PARENS)))
2641     {
2642         return newLISTOP(type, 0, first, last);
2643     }
2644
2645     if (first->op_flags & OPf_KIDS)
2646         ((LISTOP*)first)->op_last->op_sibling = last;
2647     else {
2648         first->op_flags |= OPf_KIDS;
2649         ((LISTOP*)first)->op_first = last;
2650     }
2651     ((LISTOP*)first)->op_last = last;
2652     return first;
2653 }
2654
2655 OP *
2656 Perl_append_list(pTHX_ I32 type, LISTOP *first, LISTOP *last)
2657 {
2658     if (!first)
2659         return (OP*)last;
2660
2661     if (!last)
2662         return (OP*)first;
2663
2664     if (first->op_type != (unsigned)type)
2665         return prepend_elem(type, (OP*)first, (OP*)last);
2666
2667     if (last->op_type != (unsigned)type)
2668         return append_elem(type, (OP*)first, (OP*)last);
2669
2670     first->op_last->op_sibling = last->op_first;
2671     first->op_last = last->op_last;
2672     first->op_flags |= (last->op_flags & OPf_KIDS);
2673
2674 #ifdef PERL_MAD
2675     if (last->op_first && first->op_madprop) {
2676         MADPROP *mp = last->op_first->op_madprop;
2677         if (mp) {
2678             while (mp->mad_next)
2679                 mp = mp->mad_next;
2680             mp->mad_next = first->op_madprop;
2681         }
2682         else {
2683             last->op_first->op_madprop = first->op_madprop;
2684         }
2685     }
2686     first->op_madprop = last->op_madprop;
2687     last->op_madprop = 0;
2688 #endif
2689
2690     S_op_destroy(aTHX_ (OP*)last);
2691
2692     return (OP*)first;
2693 }
2694
2695 OP *
2696 Perl_prepend_elem(pTHX_ I32 type, OP *first, OP *last)
2697 {
2698     if (!first)
2699         return last;
2700
2701     if (!last)
2702         return first;
2703
2704     if (last->op_type == (unsigned)type) {
2705         if (type == OP_LIST) {  /* already a PUSHMARK there */
2706             first->op_sibling = ((LISTOP*)last)->op_first->op_sibling;
2707             ((LISTOP*)last)->op_first->op_sibling = first;
2708             if (!(first->op_flags & OPf_PARENS))
2709                 last->op_flags &= ~OPf_PARENS;
2710         }
2711         else {
2712             if (!(last->op_flags & OPf_KIDS)) {
2713                 ((LISTOP*)last)->op_last = first;
2714                 last->op_flags |= OPf_KIDS;
2715             }
2716             first->op_sibling = ((LISTOP*)last)->op_first;
2717             ((LISTOP*)last)->op_first = first;
2718         }
2719         last->op_flags |= OPf_KIDS;
2720         return last;
2721     }
2722
2723     return newLISTOP(type, 0, first, last);
2724 }
2725
2726 /* Constructors */
2727
2728 #ifdef PERL_MAD
2729  
2730 TOKEN *
2731 Perl_newTOKEN(pTHX_ I32 optype, YYSTYPE lval, MADPROP* madprop)
2732 {
2733     TOKEN *tk;
2734     Newxz(tk, 1, TOKEN);
2735     tk->tk_type = (OPCODE)optype;
2736     tk->tk_type = 12345;
2737     tk->tk_lval = lval;
2738     tk->tk_mad = madprop;
2739     return tk;
2740 }
2741
2742 void
2743 Perl_token_free(pTHX_ TOKEN* tk)
2744 {
2745     PERL_ARGS_ASSERT_TOKEN_FREE;
2746
2747     if (tk->tk_type != 12345)
2748         return;
2749     mad_free(tk->tk_mad);
2750     Safefree(tk);
2751 }
2752
2753 void
2754 Perl_token_getmad(pTHX_ TOKEN* tk, OP* o, char slot)
2755 {
2756     MADPROP* mp;
2757     MADPROP* tm;
2758
2759     PERL_ARGS_ASSERT_TOKEN_GETMAD;
2760
2761     if (tk->tk_type != 12345) {
2762         Perl_warner(aTHX_ packWARN(WARN_MISC),
2763              "Invalid TOKEN object ignored");
2764         return;
2765     }
2766     tm = tk->tk_mad;
2767     if (!tm)
2768         return;
2769
2770     /* faked up qw list? */
2771     if (slot == '(' &&
2772         tm->mad_type == MAD_SV &&
2773         SvPVX((const SV *)tm->mad_val)[0] == 'q')
2774             slot = 'x';
2775
2776     if (o) {
2777         mp = o->op_madprop;
2778         if (mp) {
2779             for (;;) {
2780                 /* pretend constant fold didn't happen? */
2781                 if (mp->mad_key == 'f' &&
2782                     (o->op_type == OP_CONST ||
2783                      o->op_type == OP_GV) )
2784                 {
2785                     token_getmad(tk,(OP*)mp->mad_val,slot);
2786                     return;
2787                 }
2788                 if (!mp->mad_next)
2789                     break;
2790                 mp = mp->mad_next;
2791             }
2792             mp->mad_next = tm;
2793             mp = mp->mad_next;
2794         }
2795         else {
2796             o->op_madprop = tm;
2797             mp = o->op_madprop;
2798         }
2799         if (mp->mad_key == 'X')
2800             mp->mad_key = slot; /* just change the first one */
2801
2802         tk->tk_mad = 0;
2803     }
2804     else
2805         mad_free(tm);
2806     Safefree(tk);
2807 }
2808
2809 void
2810 Perl_op_getmad_weak(pTHX_ OP* from, OP* o, char slot)
2811 {
2812     MADPROP* mp;
2813     if (!from)
2814         return;
2815     if (o) {
2816         mp = o->op_madprop;
2817         if (mp) {
2818             for (;;) {
2819                 /* pretend constant fold didn't happen? */
2820                 if (mp->mad_key == 'f' &&
2821                     (o->op_type == OP_CONST ||
2822                      o->op_type == OP_GV) )
2823                 {
2824                     op_getmad(from,(OP*)mp->mad_val,slot);
2825                     return;
2826                 }
2827                 if (!mp->mad_next)
2828                     break;
2829                 mp = mp->mad_next;
2830             }
2831             mp->mad_next = newMADPROP(slot,MAD_OP,from,0);
2832         }
2833         else {
2834             o->op_madprop = newMADPROP(slot,MAD_OP,from,0);
2835         }
2836     }
2837 }
2838
2839 void
2840 Perl_op_getmad(pTHX_ OP* from, OP* o, char slot)
2841 {
2842     MADPROP* mp;
2843     if (!from)
2844         return;
2845     if (o) {
2846         mp = o->op_madprop;
2847         if (mp) {
2848             for (;;) {
2849                 /* pretend constant fold didn't happen? */
2850                 if (mp->mad_key == 'f' &&
2851                     (o->op_type == OP_CONST ||
2852                      o->op_type == OP_GV) )
2853                 {
2854                     op_getmad(from,(OP*)mp->mad_val,slot);
2855                     return;
2856                 }
2857                 if (!mp->mad_next)
2858                     break;
2859                 mp = mp->mad_next;
2860             }
2861             mp->mad_next = newMADPROP(slot,MAD_OP,from,1);
2862         }
2863         else {
2864             o->op_madprop = newMADPROP(slot,MAD_OP,from,1);
2865         }
2866     }
2867     else {
2868         PerlIO_printf(PerlIO_stderr(),
2869                       "DESTROYING op = %0"UVxf"\n", PTR2UV(from));
2870         op_free(from);
2871     }
2872 }
2873
2874 void
2875 Perl_prepend_madprops(pTHX_ MADPROP* mp, OP* o, char slot)
2876 {
2877     MADPROP* tm;
2878     if (!mp || !o)
2879         return;
2880     if (slot)
2881         mp->mad_key = slot;
2882     tm = o->op_madprop;
2883     o->op_madprop = mp;
2884     for (;;) {
2885         if (!mp->mad_next)
2886             break;
2887         mp = mp->mad_next;
2888     }
2889     mp->mad_next = tm;
2890 }
2891
2892 void
2893 Perl_append_madprops(pTHX_ MADPROP* tm, OP* o, char slot)
2894 {
2895     if (!o)
2896         return;
2897     addmad(tm, &(o->op_madprop), slot);
2898 }
2899
2900 void
2901 Perl_addmad(pTHX_ MADPROP* tm, MADPROP** root, char slot)
2902 {
2903     MADPROP* mp;
2904     if (!tm || !root)
2905         return;
2906     if (slot)
2907         tm->mad_key = slot;
2908     mp = *root;
2909     if (!mp) {
2910         *root = tm;
2911         return;
2912     }
2913     for (;;) {
2914         if (!mp->mad_next)
2915             break;
2916         mp = mp->mad_next;
2917     }
2918     mp->mad_next = tm;
2919 }
2920
2921 MADPROP *
2922 Perl_newMADsv(pTHX_ char key, SV* sv)
2923 {
2924     PERL_ARGS_ASSERT_NEWMADSV;
2925
2926     return newMADPROP(key, MAD_SV, sv, 0);
2927 }
2928
2929 MADPROP *
2930 Perl_newMADPROP(pTHX_ char key, char type, const void* val, I32 vlen)
2931 {
2932     MADPROP *mp;
2933     Newxz(mp, 1, MADPROP);
2934     mp->mad_next = 0;
2935     mp->mad_key = key;
2936     mp->mad_vlen = vlen;
2937     mp->mad_type = type;
2938     mp->mad_val = val;
2939 /*    PerlIO_printf(PerlIO_stderr(), "NEW  mp = %0x\n", mp);  */
2940     return mp;
2941 }
2942
2943 void
2944 Perl_mad_free(pTHX_ MADPROP* mp)
2945 {
2946 /*    PerlIO_printf(PerlIO_stderr(), "FREE mp = %0x\n", mp); */
2947     if (!mp)
2948         return;
2949     if (mp->mad_next)
2950         mad_free(mp->mad_next);
2951 /*    if (PL_parser && PL_parser->lex_state != LEX_NOTPARSING && mp->mad_vlen)
2952         PerlIO_printf(PerlIO_stderr(), "DESTROYING '%c'=<%s>\n", mp->mad_key & 255, mp->mad_val); */
2953     switch (mp->mad_type) {
2954     case MAD_NULL:
2955         break;
2956     case MAD_PV:
2957         Safefree((char*)mp->mad_val);
2958         break;
2959     case MAD_OP:
2960         if (mp->mad_vlen)       /* vlen holds "strong/weak" boolean */
2961             op_free((OP*)mp->mad_val);
2962         break;
2963     case MAD_SV:
2964         sv_free(MUTABLE_SV(mp->mad_val));
2965         break;
2966     default:
2967         PerlIO_printf(PerlIO_stderr(), "Unrecognized mad\n");
2968         break;
2969     }
2970     Safefree(mp);
2971 }
2972
2973 #endif
2974
2975 OP *
2976 Perl_newNULLLIST(pTHX)
2977 {
2978     return newOP(OP_STUB, 0);
2979 }
2980
2981 static OP *
2982 S_force_list(pTHX_ OP *o)
2983 {
2984     if (!o || o->op_type != OP_LIST)
2985         o = newLISTOP(OP_LIST, 0, o, NULL);
2986     op_null(o);
2987     return o;
2988 }
2989
2990 OP *
2991 Perl_newLISTOP(pTHX_ I32 type, I32 flags, OP *first, OP *last)
2992 {
2993     dVAR;
2994     LISTOP *listop;
2995
2996     NewOp(1101, listop, 1, LISTOP);
2997
2998     listop->op_type = (OPCODE)type;
2999     listop->op_ppaddr = PL_ppaddr[type];
3000     if (first || last)
3001         flags |= OPf_KIDS;
3002     listop->op_flags = (U8)flags;
3003
3004     if (!last && first)
3005         last = first;
3006     else if (!first && last)
3007         first = last;
3008     else if (first)
3009         first->op_sibling = last;
3010     listop->op_first = first;
3011     listop->op_last = last;
3012     if (type == OP_LIST) {
3013         OP* const pushop = newOP(OP_PUSHMARK, 0);
3014         pushop->op_sibling = first;
3015         listop->op_first = pushop;
3016         listop->op_flags |= OPf_KIDS;
3017         if (!last)
3018             listop->op_last = pushop;
3019     }
3020
3021     return CHECKOP(type, listop);
3022 }
3023
3024 OP *
3025 Perl_newOP(pTHX_ I32 type, I32 flags)
3026 {
3027     dVAR;
3028     OP *o;
3029     NewOp(1101, o, 1, OP);
3030     o->op_type = (OPCODE)type;
3031     o->op_ppaddr = PL_ppaddr[type];
3032     o->op_flags = (U8)flags;
3033     o->op_latefree = 0;
3034     o->op_latefreed = 0;
3035     o->op_attached = 0;
3036
3037     o->op_next = o;
3038     o->op_private = (U8)(0 | (flags >> 8));
3039     if (PL_opargs[type] & OA_RETSCALAR)
3040         scalar(o);
3041     if (PL_opargs[type] & OA_TARGET)
3042         o->op_targ = pad_alloc(type, SVs_PADTMP);
3043     return CHECKOP(type, o);
3044 }
3045
3046 OP *
3047 Perl_newUNOP(pTHX_ I32 type, I32 flags, OP *first)
3048 {
3049     dVAR;
3050     UNOP *unop;
3051
3052     if (!first)
3053         first = newOP(OP_STUB, 0);
3054     if (PL_opargs[type] & OA_MARK)
3055         first = force_list(first);
3056
3057     NewOp(1101, unop, 1, UNOP);
3058     unop->op_type = (OPCODE)type;
3059     unop->op_ppaddr = PL_ppaddr[type];
3060     unop->op_first = first;
3061     unop->op_flags = (U8)(flags | OPf_KIDS);
3062     unop->op_private = (U8)(1 | (flags >> 8));
3063     unop = (UNOP*) CHECKOP(type, unop);
3064     if (unop->op_next)
3065         return (OP*)unop;
3066
3067     return fold_constants((OP *) unop);
3068 }
3069
3070 OP *
3071 Perl_newBINOP(pTHX_ I32 type, I32 flags, OP *first, OP *last)
3072 {
3073     dVAR;
3074     BINOP *binop;
3075     NewOp(1101, binop, 1, BINOP);
3076
3077     if (!first)
3078         first = newOP(OP_NULL, 0);
3079
3080     binop->op_type = (OPCODE)type;
3081     binop->op_ppaddr = PL_ppaddr[type];
3082     binop->op_first = first;
3083     binop->op_flags = (U8)(flags | OPf_KIDS);
3084     if (!last) {
3085         last = first;
3086         binop->op_private = (U8)(1 | (flags >> 8));
3087     }
3088     else {
3089         binop->op_private = (U8)(2 | (flags >> 8));
3090         first->op_sibling = last;
3091     }
3092
3093     binop = (BINOP*)CHECKOP(type, binop);
3094     if (binop->op_next || binop->op_type != (OPCODE)type)
3095         return (OP*)binop;
3096
3097     binop->op_last = binop->op_first->op_sibling;
3098
3099     return fold_constants((OP *)binop);
3100 }
3101
3102 static int uvcompare(const void *a, const void *b)
3103     __attribute__nonnull__(1)
3104     __attribute__nonnull__(2)
3105     __attribute__pure__;
3106 static int uvcompare(const void *a, const void *b)
3107 {
3108     if (*((const UV *)a) < (*(const UV *)b))
3109         return -1;
3110     if (*((const UV *)a) > (*(const UV *)b))
3111         return 1;
3112     if (*((const UV *)a+1) < (*(const UV *)b+1))
3113         return -1;
3114     if (*((const UV *)a+1) > (*(const UV *)b+1))
3115         return 1;
3116     return 0;
3117 }
3118
3119 static OP *
3120 S_pmtrans(pTHX_ OP *o, OP *expr, OP *repl)
3121 {
3122     dVAR;
3123     SV * const tstr = ((SVOP*)expr)->op_sv;
3124     SV * const rstr =
3125 #ifdef PERL_MAD
3126                         (repl->op_type == OP_NULL)
3127                             ? ((SVOP*)((LISTOP*)repl)->op_first)->op_sv :
3128 #endif
3129                               ((SVOP*)repl)->op_sv;
3130     STRLEN tlen;
3131     STRLEN rlen;
3132     const U8 *t = (U8*)SvPV_const(tstr, tlen);
3133     const U8 *r = (U8*)SvPV_const(rstr, rlen);
3134     register I32 i;
3135     register I32 j;
3136     I32 grows = 0;
3137     register short *tbl;
3138
3139     const I32 complement = o->op_private & OPpTRANS_COMPLEMENT;
3140     const I32 squash     = o->op_private & OPpTRANS_SQUASH;
3141     I32 del              = o->op_private & OPpTRANS_DELETE;
3142     SV* swash;
3143
3144     PERL_ARGS_ASSERT_PMTRANS;
3145
3146     PL_hints |= HINT_BLOCK_SCOPE;
3147
3148     if (SvUTF8(tstr))
3149         o->op_private |= OPpTRANS_FROM_UTF;
3150
3151     if (SvUTF8(rstr))
3152         o->op_private |= OPpTRANS_TO_UTF;
3153
3154     if (o->op_private & (OPpTRANS_FROM_UTF|OPpTRANS_TO_UTF)) {
3155         SV* const listsv = newSVpvs("# comment\n");
3156         SV* transv = NULL;
3157         const U8* tend = t + tlen;
3158         const U8* rend = r + rlen;
3159         STRLEN ulen;
3160         UV tfirst = 1;
3161         UV tlast = 0;
3162         IV tdiff;
3163         UV rfirst = 1;
3164         UV rlast = 0;
3165         IV rdiff;
3166         IV diff;
3167         I32 none = 0;
3168         U32 max = 0;
3169         I32 bits;
3170         I32 havefinal = 0;
3171         U32 final = 0;
3172         const I32 from_utf  = o->op_private & OPpTRANS_FROM_UTF;
3173         const I32 to_utf    = o->op_private & OPpTRANS_TO_UTF;
3174         U8* tsave = NULL;
3175         U8* rsave = NULL;
3176         const U32 flags = UTF8_ALLOW_DEFAULT;
3177
3178         if (!from_utf) {
3179             STRLEN len = tlen;
3180             t = tsave = bytes_to_utf8(t, &len);
3181             tend = t + len;
3182         }
3183         if (!to_utf && rlen) {
3184             STRLEN len = rlen;
3185             r = rsave = bytes_to_utf8(r, &len);
3186             rend = r + len;
3187         }
3188
3189 /* There are several snags with this code on EBCDIC:
3190    1. 0xFF is a legal UTF-EBCDIC byte (there are no illegal bytes).
3191    2. scan_const() in toke.c has encoded chars in native encoding which makes
3192       ranges at least in EBCDIC 0..255 range the bottom odd.
3193 */
3194
3195         if (complement) {
3196             U8 tmpbuf[UTF8_MAXBYTES+1];
3197             UV *cp;
3198             UV nextmin = 0;
3199             Newx(cp, 2*tlen, UV);
3200             i = 0;
3201             transv = newSVpvs("");
3202             while (t < tend) {
3203                 cp[2*i] = utf8n_to_uvuni(t, tend-t, &ulen, flags);
3204                 t += ulen;
3205                 if (t < tend && NATIVE_TO_UTF(*t) == 0xff) {
3206                     t++;
3207                     cp[2*i+1] = utf8n_to_uvuni(t, tend-t, &ulen, flags);
3208                     t += ulen;
3209                 }
3210                 else {
3211                  cp[2*i+1] = cp[2*i];
3212                 }
3213                 i++;
3214             }
3215             qsort(cp, i, 2*sizeof(UV), uvcompare);
3216             for (j = 0; j < i; j++) {
3217                 UV  val = cp[2*j];
3218                 diff = val - nextmin;
3219                 if (diff > 0) {
3220                     t = uvuni_to_utf8(tmpbuf,nextmin);
3221                     sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
3222                     if (diff > 1) {
3223                         U8  range_mark = UTF_TO_NATIVE(0xff);
3224                         t = uvuni_to_utf8(tmpbuf, val - 1);
3225                         sv_catpvn(transv, (char *)&range_mark, 1);
3226                         sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
3227                     }
3228                 }
3229                 val = cp[2*j+1];
3230                 if (val >= nextmin)
3231                     nextmin = val + 1;
3232             }
3233             t = uvuni_to_utf8(tmpbuf,nextmin);
3234             sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
3235             {
3236                 U8 range_mark = UTF_TO_NATIVE(0xff);
3237                 sv_catpvn(transv, (char *)&range_mark, 1);
3238             }
3239             t = uvuni_to_utf8_flags(tmpbuf, 0x7fffffff,
3240                                     UNICODE_ALLOW_SUPER);
3241             sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
3242             t = (const U8*)SvPVX_const(transv);
3243             tlen = SvCUR(transv);
3244             tend = t + tlen;
3245             Safefree(cp);
3246         }
3247         else if (!rlen && !del) {
3248             r = t; rlen = tlen; rend = tend;
3249         }
3250         if (!squash) {
3251                 if ((!rlen && !del) || t == r ||
3252                     (tlen == rlen && memEQ((char *)t, (char *)r, tlen)))
3253                 {
3254                     o->op_private |= OPpTRANS_IDENTICAL;
3255                 }
3256         }
3257
3258         while (t < tend || tfirst <= tlast) {
3259             /* see if we need more "t" chars */
3260             if (tfirst > tlast) {
3261                 tfirst = (I32)utf8n_to_uvuni(t, tend - t, &ulen, flags);
3262                 t += ulen;
3263                 if (t < tend && NATIVE_TO_UTF(*t) == 0xff) {    /* illegal utf8 val indicates range */
3264                     t++;
3265                     tlast = (I32)utf8n_to_uvuni(t, tend - t, &ulen, flags);
3266                     t += ulen;
3267                 }
3268                 else
3269                     tlast = tfirst;
3270             }
3271
3272             /* now see if we need more "r" chars */
3273             if (rfirst > rlast) {
3274                 if (r < rend) {
3275                     rfirst = (I32)utf8n_to_uvuni(r, rend - r, &ulen, flags);
3276                     r += ulen;
3277                     if (r < rend && NATIVE_TO_UTF(*r) == 0xff) {        /* illegal utf8 val indicates range */
3278                         r++;
3279                         rlast = (I32)utf8n_to_uvuni(r, rend - r, &ulen, flags);
3280                         r += ulen;
3281                     }
3282                     else
3283                         rlast = rfirst;
3284                 }
3285                 else {
3286                     if (!havefinal++)
3287                         final = rlast;
3288                     rfirst = rlast = 0xffffffff;
3289                 }
3290             }
3291
3292             /* now see which range will peter our first, if either. */
3293             tdiff = tlast - tfirst;
3294             rdiff = rlast - rfirst;
3295
3296             if (tdiff <= rdiff)
3297                 diff = tdiff;
3298             else
3299                 diff = rdiff;
3300
3301             if (rfirst == 0xffffffff) {
3302                 diff = tdiff;   /* oops, pretend rdiff is infinite */
3303                 if (diff > 0)
3304                     Perl_sv_catpvf(aTHX_ listsv, "%04lx\t%04lx\tXXXX\n",
3305                                    (long)tfirst, (long)tlast);
3306                 else
3307                     Perl_sv_catpvf(aTHX_ listsv, "%04lx\t\tXXXX\n", (long)tfirst);
3308             }
3309             else {
3310                 if (diff > 0)
3311                     Perl_sv_catpvf(aTHX_ listsv, "%04lx\t%04lx\t%04lx\n",
3312                                    (long)tfirst, (long)(tfirst + diff),
3313                                    (long)rfirst);
3314                 else
3315                     Perl_sv_catpvf(aTHX_ listsv, "%04lx\t\t%04lx\n",
3316                                    (long)tfirst, (long)rfirst);
3317
3318                 if (rfirst + diff > max)
3319                     max = rfirst + diff;
3320                 if (!grows)
3321                     grows = (tfirst < rfirst &&
3322                              UNISKIP(tfirst) < UNISKIP(rfirst + diff));
3323                 rfirst += diff + 1;
3324             }
3325             tfirst += diff + 1;
3326         }
3327
3328         none = ++max;
3329         if (del)
3330             del = ++max;
3331
3332         if (max > 0xffff)
3333             bits = 32;
3334         else if (max > 0xff)
3335             bits = 16;
3336         else
3337             bits = 8;
3338
3339         PerlMemShared_free(cPVOPo->op_pv);
3340         cPVOPo->op_pv = NULL;
3341
3342         swash = MUTABLE_SV(swash_init("utf8", "", listsv, bits, none));
3343 #ifdef USE_ITHREADS
3344         cPADOPo->op_padix = pad_alloc(OP_TRANS, SVs_PADTMP);
3345         SvREFCNT_dec(PAD_SVl(cPADOPo->op_padix));
3346         PAD_SETSV(cPADOPo->op_padix, swash);
3347         SvPADTMP_on(swash);
3348         SvREADONLY_on(swash);
3349 #else
3350         cSVOPo->op_sv = swash;
3351 #endif
3352         SvREFCNT_dec(listsv);
3353         SvREFCNT_dec(transv);
3354
3355         if (!del && havefinal && rlen)
3356             (void)hv_store(MUTABLE_HV(SvRV(swash)), "FINAL", 5,
3357                            newSVuv((UV)final), 0);
3358
3359         if (grows)
3360             o->op_private |= OPpTRANS_GROWS;
3361
3362         Safefree(tsave);
3363         Safefree(rsave);
3364
3365 #ifdef PERL_MAD
3366         op_getmad(expr,o,'e');
3367         op_getmad(repl,o,'r');
3368 #else
3369         op_free(expr);
3370         op_free(repl);
3371 #endif
3372         return o;
3373     }
3374
3375     tbl = (short*)cPVOPo->op_pv;
3376     if (complement) {
3377         Zero(tbl, 256, short);
3378         for (i = 0; i < (I32)tlen; i++)
3379             tbl[t[i]] = -1;
3380         for (i = 0, j = 0; i < 256; i++) {
3381             if (!tbl[i]) {
3382                 if (j >= (I32)rlen) {
3383                     if (del)
3384                         tbl[i] = -2;
3385                     else if (rlen)
3386                         tbl[i] = r[j-1];
3387                     else
3388                         tbl[i] = (short)i;
3389                 }
3390                 else {
3391                     if (i < 128 && r[j] >= 128)
3392                         grows = 1;
3393                     tbl[i] = r[j++];
3394                 }
3395             }
3396         }
3397         if (!del) {
3398             if (!rlen) {
3399                 j = rlen;
3400                 if (!squash)
3401                     o->op_private |= OPpTRANS_IDENTICAL;
3402             }
3403             else if (j >= (I32)rlen)
3404                 j = rlen - 1;
3405             else {
3406                 tbl = 
3407                     (short *)
3408                     PerlMemShared_realloc(tbl,
3409                                           (0x101+rlen-j) * sizeof(short));
3410                 cPVOPo->op_pv = (char*)tbl;
3411             }
3412             tbl[0x100] = (short)(rlen - j);
3413             for (i=0; i < (I32)rlen - j; i++)
3414                 tbl[0x101+i] = r[j+i];
3415         }
3416     }
3417     else {
3418         if (!rlen && !del) {
3419             r = t; rlen = tlen;
3420             if (!squash)
3421                 o->op_private |= OPpTRANS_IDENTICAL;
3422         }
3423         else if (!squash && rlen == tlen && memEQ((char*)t, (char*)r, tlen)) {
3424             o->op_private |= OPpTRANS_IDENTICAL;
3425         }
3426         for (i = 0; i < 256; i++)
3427             tbl[i] = -1;
3428         for (i = 0, j = 0; i < (I32)tlen; i++,j++) {
3429             if (j >= (I32)rlen) {
3430                 if (del) {
3431                     if (tbl[t[i]] == -1)
3432                         tbl[t[i]] = -2;
3433                     continue;
3434                 }
3435                 --j;
3436             }
3437             if (tbl[t[i]] == -1) {
3438                 if (t[i] < 128 && r[j] >= 128)
3439                     grows = 1;
3440                 tbl[t[i]] = r[j];
3441             }
3442         }
3443     }
3444
3445     if(ckWARN(WARN_MISC)) {
3446         if(del && rlen == tlen) {
3447             Perl_warner(aTHX_ packWARN(WARN_MISC), "Useless use of /d modifier in transliteration operator"); 
3448         } else if(rlen > tlen) {
3449             Perl_warner(aTHX_ packWARN(WARN_MISC), "Replacement list is longer than search list");
3450         } 
3451     }
3452
3453     if (grows)
3454         o->op_private |= OPpTRANS_GROWS;
3455 #ifdef PERL_MAD
3456     op_getmad(expr,o,'e');
3457     op_getmad(repl,o,'r');
3458 #else
3459     op_free(expr);
3460     op_free(repl);
3461 #endif
3462
3463     return o;
3464 }
3465
3466 OP *
3467 Perl_newPMOP(pTHX_ I32 type, I32 flags)
3468 {
3469     dVAR;
3470     PMOP *pmop;
3471
3472     NewOp(1101, pmop, 1, PMOP);
3473     pmop->op_type = (OPCODE)type;
3474     pmop->op_ppaddr = PL_ppaddr[type];
3475     pmop->op_flags = (U8)flags;
3476     pmop->op_private = (U8)(0 | (flags >> 8));
3477
3478     if (PL_hints & HINT_RE_TAINT)
3479         pmop->op_pmflags |= PMf_RETAINT;
3480     if (PL_hints & HINT_LOCALE)
3481         pmop->op_pmflags |= PMf_LOCALE;
3482
3483
3484 #ifdef USE_ITHREADS
3485     assert(SvPOK(PL_regex_pad[0]));
3486     if (SvCUR(PL_regex_pad[0])) {
3487         /* Pop off the "packed" IV from the end.  */
3488         SV *const repointer_list = PL_regex_pad[0];
3489         const char *p = SvEND(repointer_list) - sizeof(IV);
3490         const IV offset = *((IV*)p);
3491
3492         assert(SvCUR(repointer_list) % sizeof(IV) == 0);
3493
3494         SvEND_set(repointer_list, p);
3495
3496         pmop->op_pmoffset = offset;
3497         /* This slot should be free, so assert this:  */
3498         assert(PL_regex_pad[offset] == &PL_sv_undef);
3499     } else {
3500         SV * const repointer = &PL_sv_undef;
3501         av_push(PL_regex_padav, repointer);
3502         pmop->op_pmoffset = av_len(PL_regex_padav);
3503         PL_regex_pad = AvARRAY(PL_regex_padav);
3504     }
3505 #endif
3506
3507     return CHECKOP(type, pmop);
3508 }
3509
3510 /* Given some sort of match op o, and an expression expr containing a
3511  * pattern, either compile expr into a regex and attach it to o (if it's
3512  * constant), or convert expr into a runtime regcomp op sequence (if it's
3513  * not)
3514  *
3515  * isreg indicates that the pattern is part of a regex construct, eg
3516  * $x =~ /pattern/ or split /pattern/, as opposed to $x =~ $pattern or
3517  * split "pattern", which aren't. In the former case, expr will be a list
3518  * if the pattern contains more than one term (eg /a$b/) or if it contains
3519  * a replacement, ie s/// or tr///.
3520  */
3521
3522 OP *
3523 Perl_pmruntime(pTHX_ OP *o, OP *expr, bool isreg)
3524 {
3525     dVAR;
3526     PMOP *pm;
3527     LOGOP *rcop;
3528     I32 repl_has_vars = 0;
3529     OP* repl = NULL;
3530     bool reglist;
3531
3532     PERL_ARGS_ASSERT_PMRUNTIME;
3533
3534     if (o->op_type == OP_SUBST || o->op_type == OP_TRANS) {
3535         /* last element in list is the replacement; pop it */
3536         OP* kid;
3537         repl = cLISTOPx(expr)->op_last;
3538         kid = cLISTOPx(expr)->op_first;
3539         while (kid->op_sibling != repl)
3540             kid = kid->op_sibling;
3541         kid->op_sibling = NULL;
3542         cLISTOPx(expr)->op_last = kid;
3543     }
3544
3545     if (isreg && expr->op_type == OP_LIST &&
3546         cLISTOPx(expr)->op_first->op_sibling == cLISTOPx(expr)->op_last)
3547     {
3548         /* convert single element list to element */
3549         OP* const oe = expr;
3550         expr = cLISTOPx(oe)->op_first->op_sibling;
3551         cLISTOPx(oe)->op_first->op_sibling = NULL;
3552         cLISTOPx(oe)->op_last = NULL;
3553         op_free(oe);
3554     }
3555
3556     if (o->op_type == OP_TRANS) {
3557         return pmtrans(o, expr, repl);
3558     }
3559
3560     reglist = isreg && expr->op_type == OP_LIST;
3561     if (reglist)
3562         op_null(expr);
3563
3564     PL_hints |= HINT_BLOCK_SCOPE;
3565     pm = (PMOP*)o;
3566
3567     if (expr->op_type == OP_CONST) {
3568         SV *pat = ((SVOP*)expr)->op_sv;
3569         U32 pm_flags = pm->op_pmflags & PMf_COMPILETIME;
3570
3571         if (o->op_flags & OPf_SPECIAL)
3572             pm_flags |= RXf_SPLIT;
3573
3574         if (DO_UTF8(pat)) {
3575             assert (SvUTF8(pat));
3576         } else if (SvUTF8(pat)) {
3577             /* Not doing UTF-8, despite what the SV says. Is this only if we're
3578                trapped in use 'bytes'?  */
3579             /* Make a copy of the octet sequence, but without the flag on, as
3580                the compiler now honours the SvUTF8 flag on pat.  */
3581             STRLEN len;
3582             const char *const p = SvPV(pat, len);
3583             pat = newSVpvn_flags(p, len, SVs_TEMP);
3584         }
3585
3586         PM_SETRE(pm, CALLREGCOMP(pat, pm_flags));
3587
3588 #ifdef PERL_MAD
3589         op_getmad(expr,(OP*)pm,'e');
3590 #else
3591         op_free(expr);
3592 #endif
3593     }
3594     else {
3595         if (pm->op_pmflags & PMf_KEEP || !(PL_hints & HINT_RE_EVAL))
3596             expr = newUNOP((!(PL_hints & HINT_RE_EVAL)
3597                             ? OP_REGCRESET
3598                             : OP_REGCMAYBE),0,expr);
3599
3600         NewOp(1101, rcop, 1, LOGOP);
3601         rcop->op_type = OP_REGCOMP;
3602         rcop->op_ppaddr = PL_ppaddr[OP_REGCOMP];
3603         rcop->op_first = scalar(expr);
3604         rcop->op_flags |= OPf_KIDS
3605                             | ((PL_hints & HINT_RE_EVAL) ? OPf_SPECIAL : 0)
3606                             | (reglist ? OPf_STACKED : 0);
3607         rcop->op_private = 1;
3608         rcop->op_other = o;
3609         if (reglist)
3610             rcop->op_targ = pad_alloc(rcop->op_type, SVs_PADTMP);
3611
3612         /* /$x/ may cause an eval, since $x might be qr/(?{..})/  */
3613         PL_cv_has_eval = 1;
3614
3615         /* establish postfix order */
3616         if (pm->op_pmflags & PMf_KEEP || !(PL_hints & HINT_RE_EVAL)) {
3617             LINKLIST(expr);
3618             rcop->op_next = expr;
3619             ((UNOP*)expr)->op_first->op_next = (OP*)rcop;
3620         }
3621         else {
3622             rcop->op_next = LINKLIST(expr);
3623             expr->op_next = (OP*)rcop;
3624         }
3625
3626         prepend_elem(o->op_type, scalar((OP*)rcop), o);
3627     }
3628
3629     if (repl) {
3630         OP *curop;
3631         if (pm->op_pmflags & PMf_EVAL) {
3632             curop = NULL;
3633             if (CopLINE(PL_curcop) < (line_t)PL_parser->multi_end)
3634                 CopLINE_set(PL_curcop, (line_t)PL_parser->multi_end);
3635         }
3636         else if (repl->op_type == OP_CONST)
3637             curop = repl;
3638         else {
3639             OP *lastop = NULL;
3640             for (curop = LINKLIST(repl); curop!=repl; curop = LINKLIST(curop)) {
3641                 if (curop->op_type == OP_SCOPE
3642                         || curop->op_type == OP_LEAVE
3643                         || (PL_opargs[curop->op_type] & OA_DANGEROUS)) {
3644                     if (curop->op_type == OP_GV) {
3645                         GV * const gv = cGVOPx_gv(curop);
3646                         repl_has_vars = 1;
3647                         if (strchr("&`'123456789+-\016\022", *GvENAME(gv)))
3648                             break;
3649                     }
3650                     else if (curop->op_type == OP_RV2CV)
3651                         break;
3652                     else if (curop->op_type == OP_RV2SV ||
3653                              curop->op_type == OP_RV2AV ||
3654                              curop->op_type == OP_RV2HV ||
3655                              curop->op_type == OP_RV2GV) {
3656                         if (lastop && lastop->op_type != OP_GV) /*funny deref?*/
3657                             break;
3658                     }
3659                     else if (curop->op_type == OP_PADSV ||
3660                              curop->op_type == OP_PADAV ||
3661                              curop->op_type == OP_PADHV ||
3662                              curop->op_type == OP_PADANY)
3663                     {
3664                         repl_has_vars = 1;
3665                     }
3666                     else if (curop->op_type == OP_PUSHRE)
3667                         NOOP; /* Okay here, dangerous in newASSIGNOP */
3668                     else
3669                         break;
3670                 }
3671                 lastop = curop;
3672             }
3673         }
3674         if (curop == repl
3675             && !(repl_has_vars
3676                  && (!PM_GETRE(pm)
3677                      || RX_EXTFLAGS(PM_GETRE(pm)) & RXf_EVAL_SEEN)))
3678         {
3679             pm->op_pmflags |= PMf_CONST;        /* const for long enough */
3680             prepend_elem(o->op_type, scalar(repl), o);
3681         }
3682         else {
3683             if (curop == repl && !PM_GETRE(pm)) { /* Has variables. */
3684                 pm->op_pmflags |= PMf_MAYBE_CONST;
3685             }
3686             NewOp(1101, rcop, 1, LOGOP);
3687             rcop->op_type = OP_SUBSTCONT;
3688             rcop->op_ppaddr = PL_ppaddr[OP_SUBSTCONT];
3689             rcop->op_first = scalar(repl);
3690             rcop->op_flags |= OPf_KIDS;
3691             rcop->op_private = 1;
3692             rcop->op_other = o;
3693
3694             /* establish postfix order */
3695             rcop->op_next = LINKLIST(repl);
3696             repl->op_next = (OP*)rcop;
3697
3698             pm->op_pmreplrootu.op_pmreplroot = scalar((OP*)rcop);
3699             assert(!(pm->op_pmflags & PMf_ONCE));
3700             pm->op_pmstashstartu.op_pmreplstart = LINKLIST(rcop);
3701             rcop->op_next = 0;
3702         }
3703     }
3704
3705     return (OP*)pm;
3706 }
3707
3708 OP *
3709 Perl_newSVOP(pTHX_ I32 type, I32 flags, SV *sv)
3710 {
3711     dVAR;
3712     SVOP *svop;
3713
3714     PERL_ARGS_ASSERT_NEWSVOP;
3715
3716     NewOp(1101, svop, 1, SVOP);
3717     svop->op_type = (OPCODE)type;
3718     svop->op_ppaddr = PL_ppaddr[type];
3719     svop->op_sv = sv;
3720     svop->op_next = (OP*)svop;
3721     svop->op_flags = (U8)flags;
3722     if (PL_opargs[type] & OA_RETSCALAR)
3723         scalar((OP*)svop);
3724     if (PL_opargs[type] & OA_TARGET)
3725         svop->op_targ = pad_alloc(type, SVs_PADTMP);
3726     return CHECKOP(type, svop);
3727 }
3728
3729 #ifdef USE_ITHREADS
3730 OP *
3731 Perl_newPADOP(pTHX_ I32 type, I32 flags, SV *sv)
3732 {
3733     dVAR;
3734     PADOP *padop;
3735
3736     PERL_ARGS_ASSERT_NEWPADOP;
3737
3738     NewOp(1101, padop, 1, PADOP);
3739     padop->op_type = (OPCODE)type;
3740     padop->op_ppaddr = PL_ppaddr[type];
3741     padop->op_padix = pad_alloc(type, SVs_PADTMP);
3742     SvREFCNT_dec(PAD_SVl(padop->op_padix));
3743     PAD_SETSV(padop->op_padix, sv);
3744     assert(sv);
3745     SvPADTMP_on(sv);
3746     padop->op_next = (OP*)padop;
3747     padop->op_flags = (U8)flags;
3748     if (PL_opargs[type] & OA_RETSCALAR)
3749         scalar((OP*)padop);
3750     if (PL_opargs[type] & OA_TARGET)
3751         padop->op_targ = pad_alloc(type, SVs_PADTMP);
3752     return CHECKOP(type, padop);
3753 }
3754 #endif
3755
3756 OP *
3757 Perl_newGVOP(pTHX_ I32 type, I32 flags, GV *gv)
3758 {
3759     dVAR;
3760
3761     PERL_ARGS_ASSERT_NEWGVOP;
3762
3763 #ifdef USE_ITHREADS
3764     GvIN_PAD_on(gv);
3765     return newPADOP(type, flags, SvREFCNT_inc_simple_NN(gv));
3766 #else
3767     return newSVOP(type, flags, SvREFCNT_inc_simple_NN(gv));
3768 #endif
3769 }
3770
3771 OP *
3772 Perl_newPVOP(pTHX_ I32 type, I32 flags, char *pv)
3773 {
3774     dVAR;
3775     PVOP *pvop;
3776     NewOp(1101, pvop, 1, PVOP);
3777     pvop->op_type = (OPCODE)type;
3778     pvop->op_ppaddr = PL_ppaddr[type];
3779     pvop->op_pv = pv;
3780     pvop->op_next = (OP*)pvop;
3781     pvop->op_flags = (U8)flags;
3782     if (PL_opargs[type] & OA_RETSCALAR)
3783         scalar((OP*)pvop);
3784     if (PL_opargs[type] & OA_TARGET)
3785         pvop->op_targ = pad_alloc(type, SVs_PADTMP);
3786     return CHECKOP(type, pvop);
3787 }
3788
3789 #ifdef PERL_MAD
3790 OP*
3791 #else
3792 void
3793 #endif
3794 Perl_package(pTHX_ OP *o)
3795 {
3796     dVAR;
3797     SV *const sv = cSVOPo->op_sv;
3798 #ifdef PERL_MAD
3799     OP *pegop;
3800 #endif
3801
3802     PERL_ARGS_ASSERT_PACKAGE;
3803
3804     save_hptr(&PL_curstash);
3805     save_item(PL_curstname);
3806
3807     PL_curstash = gv_stashsv(sv, GV_ADD);
3808
3809     sv_setsv(PL_curstname, sv);
3810
3811     PL_hints |= HINT_BLOCK_SCOPE;
3812     PL_parser->copline = NOLINE;
3813     PL_parser->expect = XSTATE;
3814
3815 #ifndef PERL_MAD
3816     op_free(o);
3817 #else
3818     if (!PL_madskills) {
3819         op_free(o);
3820         return NULL;
3821     }
3822
3823     pegop = newOP(OP_NULL,0);
3824     op_getmad(o,pegop,'P');
3825     return pegop;
3826 #endif
3827 }
3828
3829 #ifdef PERL_MAD
3830 OP*
3831 #else
3832 void
3833 #endif
3834 Perl_utilize(pTHX_ int aver, I32 floor, OP *version, OP *idop, OP *arg)
3835 {
3836     dVAR;
3837     OP *pack;
3838     OP *imop;
3839     OP *veop;
3840 #ifdef PERL_MAD
3841     OP *pegop = newOP(OP_NULL,0);
3842 #endif
3843
3844     PERL_ARGS_ASSERT_UTILIZE;
3845
3846     if (idop->op_type != OP_CONST)
3847         Perl_croak(aTHX_ "Module name must be constant");
3848
3849     if (PL_madskills)
3850         op_getmad(idop,pegop,'U');
3851
3852     veop = NULL;
3853
3854     if (version) {
3855         SV * const vesv = ((SVOP*)version)->op_sv;
3856
3857         if (PL_madskills)
3858             op_getmad(version,pegop,'V');
3859         if (!arg && !SvNIOKp(vesv)) {
3860             arg = version;
3861         }
3862         else {
3863             OP *pack;
3864             SV *meth;
3865
3866             if (version->op_type != OP_CONST || !SvNIOKp(vesv))
3867                 Perl_croak(aTHX_ "Version number must be a constant number");
3868
3869             /* Make copy of idop so we don't free it twice */
3870             pack = newSVOP(OP_CONST, 0, newSVsv(((SVOP*)idop)->op_sv));
3871
3872             /* Fake up a method call to VERSION */
3873             meth = newSVpvs_share("VERSION");
3874             veop = convert(OP_ENTERSUB, OPf_STACKED|OPf_SPECIAL,
3875                             append_elem(OP_LIST,
3876                                         prepend_elem(OP_LIST, pack, list(version)),
3877                                         newSVOP(OP_METHOD_NAMED, 0, meth)));
3878         }
3879     }
3880
3881     /* Fake up an import/unimport */
3882     if (arg && arg->op_type == OP_STUB) {
3883         if (PL_madskills)
3884             op_getmad(arg,pegop,'S');
3885         imop = arg;             /* no import on explicit () */
3886     }
3887     else if (SvNIOKp(((SVOP*)idop)->op_sv)) {
3888         imop = NULL;            /* use 5.0; */
3889         if (!aver)
3890             idop->op_private |= OPpCONST_NOVER;
3891     }
3892     else {
3893         SV *meth;
3894
3895         if (PL_madskills)
3896             op_getmad(arg,pegop,'A');
3897
3898         /* Make copy of idop so we don't free it twice */
3899         pack = newSVOP(OP_CONST, 0, newSVsv(((SVOP*)idop)->op_sv));
3900
3901         /* Fake up a method call to import/unimport */
3902         meth = aver
3903             ? newSVpvs_share("import") : newSVpvs_share("unimport");
3904         imop = convert(OP_ENTERSUB, OPf_STACKED|OPf_SPECIAL,
3905                        append_elem(OP_LIST,
3906                                    prepend_elem(OP_LIST, pack, list(arg)),
3907                                    newSVOP(OP_METHOD_NAMED, 0, meth)));
3908     }
3909
3910     /* Fake up the BEGIN {}, which does its thing immediately. */
3911     newATTRSUB(floor,
3912         newSVOP(OP_CONST, 0, newSVpvs_share("BEGIN")),
3913         NULL,
3914         NULL,
3915         append_elem(OP_LINESEQ,
3916             append_elem(OP_LINESEQ,
3917                 newSTATEOP(0, NULL, newUNOP(OP_REQUIRE, 0, idop)),
3918                 newSTATEOP(0, NULL, veop)),
3919             newSTATEOP(0, NULL, imop) ));
3920
3921     /* The "did you use incorrect case?" warning used to be here.
3922      * The problem is that on case-insensitive filesystems one
3923      * might get false positives for "use" (and "require"):
3924      * "use Strict" or "require CARP" will work.  This causes
3925      * portability problems for the script: in case-strict
3926      * filesystems the script will stop working.
3927      *
3928      * The "incorrect case" warning checked whether "use Foo"
3929      * imported "Foo" to your namespace, but that is wrong, too:
3930      * there is no requirement nor promise in the language that
3931      * a Foo.pm should or would contain anything in package "Foo".
3932      *
3933      * There is very little Configure-wise that can be done, either:
3934      * the case-sensitivity of the build filesystem of Perl does not
3935      * help in guessing the case-sensitivity of the runtime environment.
3936      */
3937
3938     PL_hints |= HINT_BLOCK_SCOPE;
3939     PL_parser->copline = NOLINE;
3940     PL_parser->expect = XSTATE;
3941     PL_cop_seqmax++; /* Purely for B::*'s benefit */
3942
3943 #ifdef PERL_MAD
3944     if (!PL_madskills) {
3945         /* FIXME - don't allocate pegop if !PL_madskills */
3946         op_free(pegop);
3947         return NULL;
3948     }
3949     return pegop;
3950 #endif
3951 }
3952
3953 /*
3954 =head1 Embedding Functions
3955
3956 =for apidoc load_module
3957
3958 Loads the module whose name is pointed to by the string part of name.
3959 Note that the actual module name, not its filename, should be given.
3960 Eg, "Foo::Bar" instead of "Foo/Bar.pm".  flags can be any of
3961 PERL_LOADMOD_DENY, PERL_LOADMOD_NOIMPORT, or PERL_LOADMOD_IMPORT_OPS
3962 (or 0 for no flags). ver, if specified, provides version semantics
3963 similar to C<use Foo::Bar VERSION>.  The optional trailing SV*
3964 arguments can be used to specify arguments to the module's import()
3965 method, similar to C<use Foo::Bar VERSION LIST>.
3966
3967 =cut */
3968
3969 void
3970 Perl_load_module(pTHX_ U32 flags, SV *name, SV *ver, ...)
3971 {
3972     va_list args;
3973
3974     PERL_ARGS_ASSERT_LOAD_MODULE;
3975
3976     va_start(args, ver);
3977     vload_module(flags, name, ver, &args);
3978     va_end(args);
3979 }
3980
3981 #ifdef PERL_IMPLICIT_CONTEXT
3982 void
3983 Perl_load_module_nocontext(U32 flags, SV *name, SV *ver, ...)
3984 {
3985     dTHX;
3986     va_list args;
3987     PERL_ARGS_ASSERT_LOAD_MODULE_NOCONTEXT;
3988     va_start(args, ver);
3989     vload_module(flags, name, ver, &args);
3990     va_end(args);
3991 }
3992 #endif
3993
3994 void
3995 Perl_vload_module(pTHX_ U32 flags, SV *name, SV *ver, va_list *args)
3996 {
3997     dVAR;
3998     OP *veop, *imop;
3999     OP * const modname = newSVOP(OP_CONST, 0, name);
4000
4001     PERL_ARGS_ASSERT_VLOAD_MODULE;
4002
4003     modname->op_private |= OPpCONST_BARE;
4004     if (ver) {
4005         veop = newSVOP(OP_CONST, 0, ver);
4006     }
4007     else
4008         veop = NULL;
4009     if (flags & PERL_LOADMOD_NOIMPORT) {
4010         imop = sawparens(newNULLLIST());
4011     }
4012     else if (flags & PERL_LOADMOD_IMPORT_OPS) {
4013         imop = va_arg(*args, OP*);
4014     }
4015     else {
4016         SV *sv;
4017         imop = NULL;
4018         sv = va_arg(*args, SV*);
4019         while (sv) {
4020             imop = append_elem(OP_LIST, imop, newSVOP(OP_CONST, 0, sv));
4021             sv = va_arg(*args, SV*);
4022         }
4023     }
4024
4025     /* utilize() fakes up a BEGIN { require ..; import ... }, so make sure
4026      * that it has a PL_parser to play with while doing that, and also
4027      * that it doesn't mess with any existing parser, by creating a tmp
4028      * new parser with lex_start(). This won't actually be used for much,
4029      * since pp_require() will create another parser for the real work. */
4030
4031     ENTER;
4032     SAVEVPTR(PL_curcop);
4033     lex_start(NULL, NULL, FALSE);
4034     utilize(!(flags & PERL_LOADMOD_DENY), start_subparse(FALSE, 0),
4035             veop, modname, imop);
4036     LEAVE;
4037 }
4038
4039 OP *
4040 Perl_dofile(pTHX_ OP *term, I32 force_builtin)
4041 {
4042     dVAR;
4043     OP *doop;
4044     GV *gv = NULL;
4045
4046     PERL_ARGS_ASSERT_DOFILE;
4047
4048     if (!force_builtin) {
4049         gv = gv_fetchpvs("do", GV_NOTQUAL, SVt_PVCV);
4050         if (!(gv && GvCVu(gv) && GvIMPORTED_CV(gv))) {
4051             GV * const * const gvp = (GV**)hv_fetchs(PL_globalstash, "do", FALSE);
4052             gv = gvp ? *gvp : NULL;
4053         }
4054     }
4055
4056     if (gv && GvCVu(gv) && GvIMPORTED_CV(gv)) {
4057         doop = ck_subr(newUNOP(OP_ENTERSUB, OPf_STACKED,
4058                                append_elem(OP_LIST, term,
4059                                            scalar(newUNOP(OP_RV2CV, 0,
4060                                                           newGVOP(OP_GV, 0, gv))))));
4061     }
4062     else {
4063         doop = newUNOP(OP_DOFILE, 0, scalar(term));
4064     }
4065     return doop;
4066 }
4067
4068 OP *
4069 Perl_newSLICEOP(pTHX_ I32 flags, OP *subscript, OP *listval)
4070 {
4071     return newBINOP(OP_LSLICE, flags,
4072             list(force_list(subscript)),
4073             list(force_list(listval)) );
4074 }
4075
4076 STATIC I32
4077 S_is_list_assignment(pTHX_ register const OP *o)
4078 {
4079     unsigned type;
4080     U8 flags;
4081
4082     if (!o)
4083         return TRUE;
4084
4085     if ((o->op_type == OP_NULL) && (o->op_flags & OPf_KIDS))
4086         o = cUNOPo->op_first;
4087
4088     flags = o->op_flags;
4089     type = o->op_type;
4090     if (type == OP_COND_EXPR) {
4091         const I32 t = is_list_assignment(cLOGOPo->op_first->op_sibling);
4092         const I32 f = is_list_assignment(cLOGOPo->op_first->op_sibling->op_sibling);
4093
4094         if (t && f)
4095             return TRUE;
4096         if (t || f)
4097             yyerror("Assignment to both a list and a scalar");
4098         return FALSE;
4099     }
4100
4101     if (type == OP_LIST &&
4102         (flags & OPf_WANT) == OPf_WANT_SCALAR &&
4103         o->op_private & OPpLVAL_INTRO)
4104         return FALSE;
4105
4106     if (type == OP_LIST || flags & OPf_PARENS ||
4107         type == OP_RV2AV || type == OP_RV2HV ||
4108         type == OP_ASLICE || type == OP_HSLICE)
4109         return TRUE;
4110
4111     if (type == OP_PADAV || type == OP_PADHV)
4112         return TRUE;
4113
4114     if (type == OP_RV2SV)
4115         return FALSE;
4116
4117     return FALSE;
4118 }
4119
4120 OP *
4121 Perl_newASSIGNOP(pTHX_ I32 flags, OP *left, I32 optype, OP *right)
4122 {
4123     dVAR;
4124     OP *o;
4125
4126     if (optype) {
4127         if (optype == OP_ANDASSIGN || optype == OP_ORASSIGN || optype == OP_DORASSIGN) {
4128             return newLOGOP(optype, 0,
4129                 mod(scalar(left), optype),
4130                 newUNOP(OP_SASSIGN, 0, scalar(right)));
4131         }
4132         else {
4133             return newBINOP(optype, OPf_STACKED,
4134                 mod(scalar(left), optype), scalar(right));
4135         }
4136     }
4137
4138     if (is_list_assignment(left)) {
4139         static const char no_list_state[] = "Initialization of state variables"
4140             " in list context currently forbidden";
4141         OP *curop;
4142         bool maybe_common_vars = TRUE;
4143
4144         PL_modcount = 0;
4145         /* Grandfathering $[ assignment here.  Bletch.*/
4146         /* Only simple assignments like C<< ($[) = 1 >> are allowed */
4147         PL_eval_start = (left->op_type == OP_CONST) ? right : NULL;
4148         left = mod(left, OP_AASSIGN);
4149         if (PL_eval_start)
4150             PL_eval_start = 0;
4151         else if (left->op_type == OP_CONST) {
4152             /* FIXME for MAD */
4153             /* Result of assignment is always 1 (or we'd be dead already) */
4154             return newSVOP(OP_CONST, 0, newSViv(1));
4155         }
4156         curop = list(force_list(left));
4157         o = newBINOP(OP_AASSIGN, flags, list(force_list(right)), curop);
4158         o->op_private = (U8)(0 | (flags >> 8));
4159
4160         if ((left->op_type == OP_LIST
4161              || (left->op_type == OP_NULL && left->op_targ == OP_LIST)))
4162         {
4163             OP* lop = ((LISTOP*)left)->op_first;
4164             maybe_common_vars = FALSE;
4165             while (lop) {
4166                 if (lop->op_type == OP_PADSV ||
4167                     lop->op_type == OP_PADAV ||
4168                     lop->op_type == OP_PADHV ||
4169                     lop->op_type == OP_PADANY) {
4170                     if (!(lop->op_private & OPpLVAL_INTRO))
4171                         maybe_common_vars = TRUE;
4172
4173                     if (lop->op_private & OPpPAD_STATE) {
4174                         if (left->op_private & OPpLVAL_INTRO) {
4175                             /* Each variable in state($a, $b, $c) = ... */
4176                         }
4177                         else {
4178                             /* Each state variable in
4179                                (state $a, my $b, our $c, $d, undef) = ... */
4180                         }
4181                         yyerror(no_list_state);
4182                     } else {
4183                         /* Each my variable in
4184                            (state $a, my $b, our $c, $d, undef) = ... */
4185                     }
4186                 } else if (lop->op_type == OP_UNDEF ||
4187                            lop->op_type == OP_PUSHMARK) {
4188                     /* undef may be interesting in
4189                        (state $a, undef, state $c) */
4190                 } else {
4191                     /* Other ops in the list. */
4192                     maybe_common_vars = TRUE;
4193                 }
4194                 lop = lop->op_sibling;
4195             }
4196         }
4197         else if ((left->op_private & OPpLVAL_INTRO)
4198                 && (   left->op_type == OP_PADSV
4199                     || left->op_type == OP_PADAV
4200                     || left->op_type == OP_PADHV
4201                     || left->op_type == OP_PADANY))
4202         {
4203             maybe_common_vars = FALSE;
4204             if (left->op_private & OPpPAD_STATE) {
4205                 /* All single variable list context state assignments, hence
4206                    state ($a) = ...
4207                    (state $a) = ...
4208                    state @a = ...
4209                    state (@a) = ...
4210                    (state @a) = ...
4211                    state %a = ...
4212                    state (%a) = ...
4213                    (state %a) = ...
4214                 */
4215                 yyerror(no_list_state);
4216             }
4217         }
4218
4219         /* PL_generation sorcery:
4220          * an assignment like ($a,$b) = ($c,$d) is easier than
4221          * ($a,$b) = ($c,$a), since there is no need for temporary vars.
4222          * To detect whether there are common vars, the global var
4223          * PL_generation is incremented for each assign op we compile.
4224          * Then, while compiling the assign op, we run through all the
4225          * variables on both sides of the assignment, setting a spare slot
4226          * in each of them to PL_generation. If any of them already have
4227          * that value, we know we've got commonality.  We could use a
4228          * single bit marker, but then we'd have to make 2 passes, first
4229          * to clear the flag, then to test and set it.  To find somewhere
4230          * to store these values, evil chicanery is done with SvUVX().
4231          */
4232
4233         if (maybe_common_vars) {
4234             OP *lastop = o;
4235             PL_generation++;
4236             for (curop = LINKLIST(o); curop != o; curop = LINKLIST(curop)) {
4237                 if (PL_opargs[curop->op_type] & OA_DANGEROUS) {
4238                     if (curop->op_type == OP_GV) {
4239                         GV *gv = cGVOPx_gv(curop);
4240                         if (gv == PL_defgv
4241                             || (int)GvASSIGN_GENERATION(gv) == PL_generation)
4242                             break;
4243                         GvASSIGN_GENERATION_set(gv, PL_generation);
4244                     }
4245                     else if (curop->op_type == OP_PADSV ||
4246                              curop->op_type == OP_PADAV ||
4247                              curop->op_type == OP_PADHV ||
4248                              curop->op_type == OP_PADANY)
4249                     {
4250                         if (PAD_COMPNAME_GEN(curop->op_targ)
4251                                                     == (STRLEN)PL_generation)
4252                             break;
4253                         PAD_COMPNAME_GEN_set(curop->op_targ, PL_generation);
4254
4255                     }
4256                     else if (curop->op_type == OP_RV2CV)
4257                         break;
4258                     else if (curop->op_type == OP_RV2SV ||
4259                              curop->op_type == OP_RV2AV ||
4260                              curop->op_type == OP_RV2HV ||
4261                              curop->op_type == OP_RV2GV) {
4262                         if (lastop->op_type != OP_GV)   /* funny deref? */
4263                             break;
4264                     }
4265                     else if (curop->op_type == OP_PUSHRE) {
4266 #ifdef USE_ITHREADS
4267                         if (((PMOP*)curop)->op_pmreplrootu.op_pmtargetoff) {
4268                             GV *const gv = MUTABLE_GV(PAD_SVl(((PMOP*)curop)->op_pmreplrootu.op_pmtargetoff));
4269                             if (gv == PL_defgv
4270                                 || (int)GvASSIGN_GENERATION(gv) == PL_generation)
4271                                 break;
4272                             GvASSIGN_GENERATION_set(gv, PL_generation);
4273                         }
4274 #else
4275                         GV *const gv
4276                             = ((PMOP*)curop)->op_pmreplrootu.op_pmtargetgv;
4277                         if (gv) {
4278                             if (gv == PL_defgv
4279                                 || (int)GvASSIGN_GENERATION(gv) == PL_generation)
4280                                 break;
4281                             GvASSIGN_GENERATION_set(gv, PL_generation);
4282                         }
4283 #endif
4284                     }
4285                     else
4286                         break;
4287                 }
4288                 lastop = curop;
4289             }
4290             if (curop != o)
4291                 o->op_private |= OPpASSIGN_COMMON;
4292         }
4293
4294         if (right && right->op_type == OP_SPLIT && !PL_madskills) {
4295             OP* tmpop = ((LISTOP*)right)->op_first;
4296             if (tmpop && (tmpop->op_type == OP_PUSHRE)) {
4297                 PMOP * const pm = (PMOP*)tmpop;
4298                 if (left->op_type == OP_RV2AV &&
4299                     !(left->op_private & OPpLVAL_INTRO) &&
4300                     !(o->op_private & OPpASSIGN_COMMON) )
4301                 {
4302                     tmpop = ((UNOP*)left)->op_first;
4303                     if (tmpop->op_type == OP_GV
4304 #ifdef USE_ITHREADS
4305                         && !pm->op_pmreplrootu.op_pmtargetoff
4306 #else
4307                         && !pm->op_pmreplrootu.op_pmtargetgv
4308 #endif
4309                         ) {
4310 #ifdef USE_ITHREADS
4311                         pm->op_pmreplrootu.op_pmtargetoff
4312                             = cPADOPx(tmpop)->op_padix;
4313                         cPADOPx(tmpop)->op_padix = 0;   /* steal it */
4314 #else
4315                         pm->op_pmreplrootu.op_pmtargetgv
4316                             = MUTABLE_GV(cSVOPx(tmpop)->op_sv);
4317                         cSVOPx(tmpop)->op_sv = NULL;    /* steal it */
4318 #endif
4319                         pm->op_pmflags |= PMf_ONCE;
4320                         tmpop = cUNOPo->op_first;       /* to list (nulled) */
4321                         tmpop = ((UNOP*)tmpop)->op_first; /* to pushmark */
4322                         tmpop->op_sibling = NULL;       /* don't free split */
4323                         right->op_next = tmpop->op_next;  /* fix starting loc */
4324                         op_free(o);                     /* blow off assign */
4325                         right->op_flags &= ~OPf_WANT;
4326                                 /* "I don't know and I don't care." */
4327                         return right;
4328                     }
4329                 }
4330                 else {
4331                    if (PL_modcount < RETURN_UNLIMITED_NUMBER &&
4332                       ((LISTOP*)right)->op_last->op_type == OP_CONST)
4333                     {
4334                         SV *sv = ((SVOP*)((LISTOP*)right)->op_last)->op_sv;
4335                         if (SvIOK(sv) && SvIVX(sv) == 0)
4336                             sv_setiv(sv, PL_modcount+1);
4337                     }
4338                 }
4339             }
4340         }
4341         return o;
4342     }
4343     if (!right)
4344         right = newOP(OP_UNDEF, 0);
4345     if (right->op_type == OP_READLINE) {
4346         right->op_flags |= OPf_STACKED;
4347         return newBINOP(OP_NULL, flags, mod(scalar(left), OP_SASSIGN), scalar(right));
4348     }
4349     else {
4350         PL_eval_start = right;  /* Grandfathering $[ assignment here.  Bletch.*/
4351         o = newBINOP(OP_SASSIGN, flags,
4352             scalar(right), mod(scalar(left), OP_SASSIGN) );
4353         if (PL_eval_start)
4354             PL_eval_start = 0;
4355         else {
4356             if (!PL_madskills) { /* assignment to $[ is ignored when making a mad dump */
4357                 deprecate("assignment to $[");
4358                 op_free(o);
4359                 o = newSVOP(OP_CONST, 0, newSViv(CopARYBASE_get(&PL_compiling)));
4360                 o->op_private |= OPpCONST_ARYBASE;
4361             }
4362         }
4363     }
4364     return o;
4365 }
4366
4367 OP *
4368 Perl_newSTATEOP(pTHX_ I32 flags, char *label, OP *o)
4369 {
4370     dVAR;
4371     const U32 seq = intro_my();
4372     register COP *cop;
4373
4374     NewOp(1101, cop, 1, COP);
4375     if (PERLDB_LINE && CopLINE(PL_curcop) && PL_curstash != PL_debstash) {
4376         cop->op_type = OP_DBSTATE;
4377         cop->op_ppaddr = PL_ppaddr[ OP_DBSTATE ];
4378     }
4379     else {
4380         cop->op_type = OP_NEXTSTATE;
4381         cop->op_ppaddr = PL_ppaddr[ OP_NEXTSTATE ];
4382     }
4383     cop->op_flags = (U8)flags;
4384     CopHINTS_set(cop, PL_hints);
4385 #ifdef NATIVE_HINTS
4386     cop->op_private |= NATIVE_HINTS;
4387 #endif
4388     CopHINTS_set(&PL_compiling, CopHINTS_get(cop));
4389     cop->op_next = (OP*)cop;
4390
4391     cop->cop_seq = seq;
4392     /* CopARYBASE is now "virtual", in that it's stored as a flag bit in
4393        CopHINTS and a possible value in cop_hints_hash, so no need to copy it.
4394     */
4395     cop->cop_warnings = DUP_WARNINGS(PL_curcop->cop_warnings);
4396     cop->cop_hints_hash = PL_curcop->cop_hints_hash;
4397     if (cop->cop_hints_hash) {
4398         HINTS_REFCNT_LOCK;
4399         cop->cop_hints_hash->refcounted_he_refcnt++;
4400         HINTS_REFCNT_UNLOCK;
4401     }
4402     if (label) {
4403         cop->cop_hints_hash
4404             = Perl_store_cop_label(aTHX_ cop->cop_hints_hash, label);
4405                                                      
4406         PL_hints |= HINT_BLOCK_SCOPE;
4407         /* It seems that we need to defer freeing this pointer, as other parts
4408            of the grammar end up wanting to copy it after this op has been
4409            created. */
4410         SAVEFREEPV(label);
4411     }
4412
4413     if (PL_parser && PL_parser->copline == NOLINE)
4414         CopLINE_set(cop, CopLINE(PL_curcop));
4415     else {
4416         CopLINE_set(cop, PL_parser->copline);
4417         if (PL_parser)
4418             PL_parser->copline = NOLINE;
4419     }
4420 #ifdef USE_ITHREADS
4421     CopFILE_set(cop, CopFILE(PL_curcop));       /* XXX share in a pvtable? */
4422 #else
4423     CopFILEGV_set(cop, CopFILEGV(PL_curcop));
4424 #endif
4425     CopSTASH_set(cop, PL_curstash);
4426
4427     if ((PERLDB_LINE || PERLDB_SAVESRC) && PL_curstash != PL_debstash) {
4428         /* this line can have a breakpoint - store the cop in IV */
4429         AV *av = CopFILEAVx(PL_curcop);
4430         if (av) {
4431             SV * const * const svp = av_fetch(av, (I32)CopLINE(cop), FALSE);
4432             if (svp && *svp != &PL_sv_undef ) {
4433                 (void)SvIOK_on(*svp);
4434                 SvIV_set(*svp, PTR2IV(cop));
4435             }
4436         }
4437     }
4438
4439     if (flags & OPf_SPECIAL)
4440         op_null((OP*)cop);
4441     return prepend_elem(OP_LINESEQ, (OP*)cop, o);
4442 }
4443
4444
4445 OP *
4446 Perl_newLOGOP(pTHX_ I32 type, I32 flags, OP *first, OP *other)
4447 {
4448     dVAR;
4449
4450     PERL_ARGS_ASSERT_NEWLOGOP;
4451
4452     return new_logop(type, flags, &first, &other);
4453 }
4454
4455 STATIC OP *
4456 S_search_const(pTHX_ OP *o)
4457 {
4458     PERL_ARGS_ASSERT_SEARCH_CONST;
4459
4460     switch (o->op_type) {
4461         case OP_CONST:
4462             return o;
4463         case OP_NULL:
4464             if (o->op_flags & OPf_KIDS)
4465                 return search_const(cUNOPo->op_first);
4466             break;
4467         case OP_LEAVE:
4468         case OP_SCOPE:
4469         case OP_LINESEQ:
4470         {
4471             OP *kid;
4472             if (!(o->op_flags & OPf_KIDS))
4473                 return NULL;
4474             kid = cLISTOPo->op_first;
4475             do {
4476                 switch (kid->op_type) {
4477                     case OP_ENTER:
4478                     case OP_NULL:
4479                     case OP_NEXTSTATE:
4480                         kid = kid->op_sibling;
4481                         break;
4482                     default:
4483                         if (kid != cLISTOPo->op_last)
4484                             return NULL;
4485                         goto last;
4486                 }
4487             } while (kid);
4488             if (!kid)
4489                 kid = cLISTOPo->op_last;
4490 last:
4491             return search_const(kid);
4492         }
4493     }
4494
4495     return NULL;
4496 }
4497
4498 STATIC OP *
4499 S_new_logop(pTHX_ I32 type, I32 flags, OP** firstp, OP** otherp)
4500 {
4501     dVAR;
4502     LOGOP *logop;
4503     OP *o;
4504     OP *first;
4505     OP *other;
4506     OP *cstop = NULL;
4507     int prepend_not = 0;
4508
4509     PERL_ARGS_ASSERT_NEW_LOGOP;
4510
4511     first = *firstp;
4512     other = *otherp;
4513
4514     if (type == OP_XOR)         /* Not short circuit, but here by precedence. */
4515         return newBINOP(type, flags, scalar(first), scalar(other));
4516
4517     scalarboolean(first);
4518     /* optimize AND and OR ops that have NOTs as children */
4519     if (first->op_type == OP_NOT
4520         && (first->op_flags & OPf_KIDS)
4521         && ((first->op_flags & OPf_SPECIAL) /* unless ($x) { } */
4522             || (other->op_type == OP_NOT))  /* if (!$x && !$y) { } */
4523         && !PL_madskills) {
4524         if (type == OP_AND || type == OP_OR) {
4525             if (type == OP_AND)
4526                 type = OP_OR;
4527             else
4528                 type = OP_AND;
4529             op_null(first);
4530             if (other->op_type == OP_NOT) { /* !a AND|OR !b => !(a OR|AND b) */
4531                 op_null(other);
4532                 prepend_not = 1; /* prepend a NOT op later */
4533             }
4534         }
4535     }
4536     /* search for a constant op that could let us fold the test */
4537     if ((cstop = search_const(first))) {
4538         if (cstop->op_private & OPpCONST_STRICT)
4539             no_bareword_allowed(cstop);
4540         else if ((cstop->op_private & OPpCONST_BARE) && ckWARN(WARN_BAREWORD))
4541                 Perl_warner(aTHX_ packWARN(WARN_BAREWORD), "Bareword found in conditional");
4542         if ((type == OP_AND &&  SvTRUE(((SVOP*)cstop)->op_sv)) ||
4543             (type == OP_OR  && !SvTRUE(((SVOP*)cstop)->op_sv)) ||
4544             (type == OP_DOR && !SvOK(((SVOP*)cstop)->op_sv))) {
4545             *firstp = NULL;
4546             if (other->op_type == OP_CONST)
4547                 other->op_private |= OPpCONST_SHORTCIRCUIT;
4548             if (PL_madskills) {
4549                 OP *newop = newUNOP(OP_NULL, 0, other);
4550                 op_getmad(first, newop, '1');
4551                 newop->op_targ = type;  /* set "was" field */
4552                 return newop;
4553             }
4554             op_free(first);
4555             if (other->op_type == OP_LEAVE)
4556                 other = newUNOP(OP_NULL, OPf_SPECIAL, other);
4557             return other;
4558         }
4559         else {
4560             /* check for C<my $x if 0>, or C<my($x,$y) if 0> */
4561             const OP *o2 = other;
4562             if ( ! (o2->op_type == OP_LIST
4563                     && (( o2 = cUNOPx(o2)->op_first))
4564                     && o2->op_type == OP_PUSHMARK
4565                     && (( o2 = o2->op_sibling)) )
4566             )
4567                 o2 = other;
4568             if ((o2->op_type == OP_PADSV || o2->op_type == OP_PADAV
4569                         || o2->op_type == OP_PADHV)
4570                 && o2->op_private & OPpLVAL_INTRO
4571                 && !(o2->op_private & OPpPAD_STATE)
4572                 && ckWARN(WARN_DEPRECATED))
4573             {
4574                 Perl_warner(aTHX_ packWARN(WARN_DEPRECATED),
4575                             "Deprecated use of my() in false conditional");
4576             }
4577
4578             *otherp = NULL;
4579             if (first->op_type == OP_CONST)
4580                 first->op_private |= OPpCONST_SHORTCIRCUIT;
4581             if (PL_madskills) {
4582                 first = newUNOP(OP_NULL, 0, first);
4583                 op_getmad(other, first, '2');
4584                 first->op_targ = type;  /* set "was" field */
4585             }
4586             else
4587                 op_free(other);
4588             return first;
4589         }
4590     }
4591     else if ((first->op_flags & OPf_KIDS) && type != OP_DOR
4592         && ckWARN(WARN_MISC)) /* [#24076] Don't warn for <FH> err FOO. */
4593     {
4594         const OP * const k1 = ((UNOP*)first)->op_first;
4595         const OP * const k2 = k1->op_sibling;
4596         OPCODE warnop = 0;
4597         switch (first->op_type)
4598         {
4599         case OP_NULL:
4600             if (k2 && k2->op_type == OP_READLINE
4601                   && (k2->op_flags & OPf_STACKED)
4602                   && ((k1->op_flags & OPf_WANT) == OPf_WANT_SCALAR))
4603             {
4604                 warnop = k2->op_type;
4605             }
4606             break;
4607
4608         case OP_SASSIGN:
4609             if (k1->op_type == OP_READDIR
4610                   || k1->op_type == OP_GLOB
4611                   || (k1->op_type == OP_NULL && k1->op_targ == OP_GLOB)
4612                   || k1->op_type == OP_EACH)
4613             {
4614                 warnop = ((k1->op_type == OP_NULL)
4615                           ? (OPCODE)k1->op_targ : k1->op_type);
4616             }
4617             break;
4618         }
4619         if (warnop) {
4620             const line_t oldline = CopLINE(PL_curcop);
4621             CopLINE_set(PL_curcop, PL_parser->copline);
4622             Perl_warner(aTHX_ packWARN(WARN_MISC),
4623                  "Value of %s%s can be \"0\"; test with defined()",
4624                  PL_op_desc[warnop],
4625                  ((warnop == OP_READLINE || warnop == OP_GLOB)
4626                   ? " construct" : "() operator"));
4627             CopLINE_set(PL_curcop, oldline);
4628         }
4629     }
4630
4631     if (!other)
4632         return first;
4633
4634     if (type == OP_ANDASSIGN || type == OP_ORASSIGN || type == OP_DORASSIGN)
4635         other->op_private |= OPpASSIGN_BACKWARDS;  /* other is an OP_SASSIGN */
4636
4637     NewOp(1101, logop, 1, LOGOP);
4638
4639     logop->op_type = (OPCODE)type;
4640     logop->op_ppaddr = PL_ppaddr[type];
4641     logop->op_first = first;
4642     logop->op_flags = (U8)(flags | OPf_KIDS);
4643     logop->op_other = LINKLIST(other);
4644     logop->op_private = (U8)(1 | (flags >> 8));
4645
4646     /* establish postfix order */
4647     logop->op_next = LINKLIST(first);
4648     first->op_next = (OP*)logop;
4649     first->op_sibling = other;
4650
4651     CHECKOP(type,logop);
4652
4653     o = newUNOP(prepend_not ? OP_NOT : OP_NULL, 0, (OP*)logop);
4654     other->op_next = o;
4655
4656     return o;
4657 }
4658
4659 OP *
4660 Perl_newCONDOP(pTHX_ I32 flags, OP *first, OP *trueop, OP *falseop)
4661 {
4662     dVAR;
4663     LOGOP *logop;
4664     OP *start;
4665     OP *o;
4666     OP *cstop;
4667
4668     PERL_ARGS_ASSERT_NEWCONDOP;
4669
4670     if (!falseop)
4671         return newLOGOP(OP_AND, 0, first, trueop);
4672     if (!trueop)
4673         return newLOGOP(OP_OR, 0, first, falseop);
4674
4675     scalarboolean(first);
4676     if ((cstop = search_const(first))) {
4677         /* Left or right arm of the conditional?  */
4678         const bool left = SvTRUE(((SVOP*)cstop)->op_sv);
4679         OP *live = left ? trueop : falseop;
4680         OP *const dead = left ? falseop : trueop;
4681         if (cstop->op_private & OPpCONST_BARE &&
4682             cstop->op_private & OPpCONST_STRICT) {
4683             no_bareword_allowed(cstop);
4684         }
4685         if (PL_madskills) {
4686             /* This is all dead code when PERL_MAD is not defined.  */
4687             live = newUNOP(OP_NULL, 0, live);
4688             op_getmad(first, live, 'C');
4689             op_getmad(dead, live, left ? 'e' : 't');
4690         } else {
4691             op_free(first);
4692             op_free(dead);
4693         }
4694         if (live->op_type == OP_LEAVE)
4695             live = newUNOP(OP_NULL, OPf_SPECIAL, live);
4696         return live;
4697     }
4698     NewOp(1101, logop, 1, LOGOP);
4699     logop->op_type = OP_COND_EXPR;
4700     logop->op_ppaddr = PL_ppaddr[OP_COND_EXPR];
4701     logop->op_first = first;
4702     logop->op_flags = (U8)(flags | OPf_KIDS);
4703     logop->op_private = (U8)(1 | (flags >> 8));
4704     logop->op_other = LINKLIST(trueop);
4705     logop->op_next = LINKLIST(falseop);
4706
4707     CHECKOP(OP_COND_EXPR, /* that's logop->op_type */
4708             logop);
4709
4710     /* establish postfix order */
4711     start = LINKLIST(first);
4712     first->op_next = (OP*)logop;
4713
4714     first->op_sibling = trueop;
4715     trueop->op_sibling = falseop;
4716     o = newUNOP(OP_NULL, 0, (OP*)logop);
4717
4718     trueop->op_next = falseop->op_next = o;
4719
4720     o->op_next = start;
4721     return o;
4722 }
4723
4724 OP *
4725 Perl_newRANGE(pTHX_ I32 flags, OP *left, OP *right)
4726 {
4727     dVAR;
4728     LOGOP *range;
4729     OP *flip;
4730     OP *flop;
4731     OP *leftstart;
4732     OP *o;
4733
4734     PERL_ARGS_ASSERT_NEWRANGE;
4735
4736     NewOp(1101, range, 1, LOGOP);
4737
4738     range->op_type = OP_RANGE;
4739     range->op_ppaddr = PL_ppaddr[OP_RANGE];
4740     range->op_first = left;
4741     range->op_flags = OPf_KIDS;
4742     leftstart = LINKLIST(left);
4743     range->op_other = LINKLIST(right);
4744     range->op_private = (U8)(1 | (flags >> 8));
4745
4746     left->op_sibling = right;
4747
4748     range->op_next = (OP*)range;
4749     flip = newUNOP(OP_FLIP, flags, (OP*)range);
4750     flop = newUNOP(OP_FLOP, 0, flip);
4751     o = newUNOP(OP_NULL, 0, flop);
4752     linklist(flop);
4753     range->op_next = leftstart;
4754
4755     left->op_next = flip;
4756     right->op_next = flop;
4757
4758     range->op_targ = pad_alloc(OP_RANGE, SVs_PADMY);
4759     sv_upgrade(PAD_SV(range->op_targ), SVt_PVNV);
4760     flip->op_targ = pad_alloc(OP_RANGE, SVs_PADMY);
4761     sv_upgrade(PAD_SV(flip->op_targ), SVt_PVNV);
4762
4763     flip->op_private =  left->op_type == OP_CONST ? OPpFLIP_LINENUM : 0;
4764     flop->op_private = right->op_type == OP_CONST ? OPpFLIP_LINENUM : 0;
4765
4766     flip->op_next = o;
4767     if (!flip->op_private || !flop->op_private)
4768         linklist(o);            /* blow off optimizer unless constant */
4769
4770     return o;
4771 }
4772
4773 OP *
4774 Perl_newLOOPOP(pTHX_ I32 flags, I32 debuggable, OP *expr, OP *block)
4775 {
4776     dVAR;
4777     OP* listop;
4778     OP* o;
4779     const bool once = block && block->op_flags & OPf_SPECIAL &&
4780       (block->op_type == OP_ENTERSUB || block->op_type == OP_NULL);
4781
4782     PERL_UNUSED_ARG(debuggable);
4783
4784     if (expr) {
4785         if (once && expr->op_type == OP_CONST && !SvTRUE(((SVOP*)expr)->op_sv))
4786             return block;       /* do {} while 0 does once */
4787         if (expr->op_type == OP_READLINE || expr->op_type == OP_GLOB
4788             || (expr->op_type == OP_NULL && expr->op_targ == OP_GLOB)) {
4789             expr = newUNOP(OP_DEFINED, 0,
4790                 newASSIGNOP(0, newDEFSVOP(), 0, expr) );
4791         } else if (expr->op_flags & OPf_KIDS) {
4792             const OP * const k1 = ((UNOP*)expr)->op_first;
4793             const OP * const k2 = k1 ? k1->op_sibling : NULL;
4794             switch (expr->op_type) {
4795               case OP_NULL:
4796                 if (k2 && k2->op_type == OP_READLINE
4797                       && (k2->op_flags & OPf_STACKED)
4798                       && ((k1->op_flags & OPf_WANT) == OPf_WANT_SCALAR))
4799                     expr = newUNOP(OP_DEFINED, 0, expr);
4800                 break;
4801
4802               case OP_SASSIGN:
4803                 if (k1 && (k1->op_type == OP_READDIR
4804                       || k1->op_type == OP_GLOB
4805                       || (k1->op_type == OP_NULL && k1->op_targ == OP_GLOB)
4806                       || k1->op_type == OP_EACH))
4807                     expr = newUNOP(OP_DEFINED, 0, expr);
4808                 break;
4809             }
4810         }
4811     }
4812
4813     /* if block is null, the next append_elem() would put UNSTACK, a scalar
4814      * op, in listop. This is wrong. [perl #27024] */
4815     if (!block)
4816         block = newOP(OP_NULL, 0);
4817     listop = append_elem(OP_LINESEQ, block, newOP(OP_UNSTACK, 0));
4818     o = new_logop(OP_AND, 0, &expr, &listop);
4819
4820     if (listop)
4821         ((LISTOP*)listop)->op_last->op_next = LINKLIST(o);
4822
4823     if (once && o != listop)
4824         o->op_next = ((LOGOP*)cUNOPo->op_first)->op_other;
4825
4826     if (o == listop)
4827         o = newUNOP(OP_NULL, 0, o);     /* or do {} while 1 loses outer block */
4828
4829     o->op_flags |= flags;
4830     o = scope(o);
4831     o->op_flags |= OPf_SPECIAL; /* suppress POPBLOCK curpm restoration*/
4832     return o;
4833 }
4834
4835 OP *
4836 Perl_newWHILEOP(pTHX_ I32 flags, I32 debuggable, LOOP *loop, I32
4837 whileline, OP *expr, OP *block, OP *cont, I32 has_my)
4838 {
4839     dVAR;
4840     OP *redo;
4841     OP *next = NULL;
4842     OP *listop;
4843     OP *o;
4844     U8 loopflags = 0;
4845
4846     PERL_UNUSED_ARG(debuggable);
4847
4848     if (expr) {
4849         if (expr->op_type == OP_READLINE || expr->op_type == OP_GLOB
4850                      || (expr->op_type == OP_NULL && expr->op_targ == OP_GLOB)) {
4851             expr = newUNOP(OP_DEFINED, 0,
4852                 newASSIGNOP(0, newDEFSVOP(), 0, expr) );
4853         } else if (expr->op_flags & OPf_KIDS) {
4854             const OP * const k1 = ((UNOP*)expr)->op_first;
4855             const OP * const k2 = (k1) ? k1->op_sibling : NULL;
4856             switch (expr->op_type) {
4857               case OP_NULL:
4858                 if (k2 && k2->op_type == OP_READLINE
4859                       && (k2->op_flags & OPf_STACKED)
4860                       && ((k1->op_flags & OPf_WANT) == OPf_WANT_SCALAR))
4861                     expr = newUNOP(OP_DEFINED, 0, expr);
4862                 break;
4863
4864               case OP_SASSIGN:
4865                 if (k1 && (k1->op_type == OP_READDIR
4866                       || k1->op_type == OP_GLOB
4867                       || (k1->op_type == OP_NULL && k1->op_targ == OP_GLOB)
4868                       || k1->op_type == OP_EACH))
4869                     expr = newUNOP(OP_DEFINED, 0, expr);
4870                 break;
4871             }
4872         }
4873     }
4874
4875     if (!block)
4876         block = newOP(OP_NULL, 0);
4877     else if (cont || has_my) {
4878         block = scope(block);
4879     }
4880
4881     if (cont) {
4882         next = LINKLIST(cont);
4883     }
4884     if (expr) {
4885         OP * const unstack = newOP(OP_UNSTACK, 0);
4886         if (!next)
4887             next = unstack;
4888         cont = append_elem(OP_LINESEQ, cont, unstack);
4889     }
4890
4891     assert(block);
4892     listop = append_list(OP_LINESEQ, (LISTOP*)block, (LISTOP*)cont);
4893     assert(listop);
4894     redo = LINKLIST(listop);
4895
4896     if (expr) {
4897         PL_parser->copline = (line_t)whileline;
4898         scalar(listop);
4899         o = new_logop(OP_AND, 0, &expr, &listop);
4900         if (o == expr && o->op_type == OP_CONST && !SvTRUE(cSVOPo->op_sv)) {
4901             op_free(expr);              /* oops, it's a while (0) */
4902             op_free((OP*)loop);
4903             return NULL;                /* listop already freed by new_logop */
4904         }
4905         if (listop)
4906             ((LISTOP*)listop)->op_last->op_next =
4907                 (o == listop ? redo : LINKLIST(o));
4908     }
4909     else
4910         o = listop;
4911
4912     if (!loop) {
4913         NewOp(1101,loop,1,LOOP);
4914         loop->op_type = OP_ENTERLOOP;
4915         loop->op_ppaddr = PL_ppaddr[OP_ENTERLOOP];
4916         loop->op_private = 0;
4917         loop->op_next = (OP*)loop;
4918     }
4919
4920     o = newBINOP(OP_LEAVELOOP, 0, (OP*)loop, o);
4921
4922     loop->op_redoop = redo;
4923     loop->op_lastop = o;
4924     o->op_private |= loopflags;
4925
4926     if (next)
4927         loop->op_nextop = next;
4928     else
4929         loop->op_nextop = o;
4930
4931     o->op_flags |= flags;
4932     o->op_private |= (flags >> 8);
4933     return o;
4934 }
4935
4936 OP *
4937 Perl_newFOROP(pTHX_ I32 flags, char *label, line_t forline, OP *sv, OP *expr, OP *block, OP *cont)
4938 {
4939     dVAR;
4940     LOOP *loop;
4941     OP *wop;
4942     PADOFFSET padoff = 0;
4943     I32 iterflags = 0;
4944     I32 iterpflags = 0;
4945     OP *madsv = NULL;
4946
4947     PERL_ARGS_ASSERT_NEWFOROP;
4948
4949     if (sv) {
4950         if (sv->op_type == OP_RV2SV) {  /* symbol table variable */
4951             iterpflags = sv->op_private & OPpOUR_INTRO; /* for our $x () */
4952             sv->op_type = OP_RV2GV;
4953             sv->op_ppaddr = PL_ppaddr[OP_RV2GV];
4954
4955             /* The op_type check is needed to prevent a possible segfault
4956              * if the loop variable is undeclared and 'strict vars' is in
4957              * effect. This is illegal but is nonetheless parsed, so we
4958              * may reach this point with an OP_CONST where we're expecting
4959              * an OP_GV.
4960              */
4961             if (cUNOPx(sv)->op_first->op_type == OP_GV
4962              && cGVOPx_gv(cUNOPx(sv)->op_first) == PL_defgv)
4963                 iterpflags |= OPpITER_DEF;
4964         }
4965         else if (sv->op_type == OP_PADSV) { /* private variable */
4966             iterpflags = sv->op_private & OPpLVAL_INTRO; /* for my $x () */
4967             padoff = sv->op_targ;
4968             if (PL_madskills)
4969                 madsv = sv;
4970             else {
4971                 sv->op_targ = 0;
4972                 op_free(sv);
4973             }
4974             sv = NULL;
4975         }
4976         else
4977             Perl_croak(aTHX_ "Can't use %s for loop variable", PL_op_desc[sv->op_type]);
4978         if (padoff) {
4979             SV *const namesv = PAD_COMPNAME_SV(padoff);
4980             STRLEN len;
4981             const char *const name = SvPV_const(namesv, len);
4982
4983             if (len == 2 && name[0] == '$' && name[1] == '_')
4984                 iterpflags |= OPpITER_DEF;
4985         }
4986     }
4987     else {
4988         const PADOFFSET offset = pad_findmy("$_");
4989         if (offset == NOT_IN_PAD || PAD_COMPNAME_FLAGS_isOUR(offset)) {
4990             sv = newGVOP(OP_GV, 0, PL_defgv);
4991         }
4992         else {
4993             padoff = offset;
4994         }
4995         iterpflags |= OPpITER_DEF;
4996     }
4997     if (expr->op_type == OP_RV2AV || expr->op_type == OP_PADAV) {
4998         expr = mod(force_list(scalar(ref(expr, OP_ITER))), OP_GREPSTART);
4999         iterflags |= OPf_STACKED;
5000     }
5001     else if (expr->op_type == OP_NULL &&
5002              (expr->op_flags & OPf_KIDS) &&
5003              ((BINOP*)expr)->op_first->op_type == OP_FLOP)
5004     {
5005         /* Basically turn for($x..$y) into the same as for($x,$y), but we
5006          * set the STACKED flag to indicate that these values are to be
5007          * treated as min/max values by 'pp_iterinit'.
5008          */
5009         const UNOP* const flip = (UNOP*)((UNOP*)((BINOP*)expr)->op_first)->op_first;
5010         LOGOP* const range = (LOGOP*) flip->op_first;
5011         OP* const left  = range->op_first;
5012         OP* const right = left->op_sibling;
5013         LISTOP* listop;
5014
5015         range->op_flags &= ~OPf_KIDS;
5016         range->op_first = NULL;
5017
5018         listop = (LISTOP*)newLISTOP(OP_LIST, 0, left, right);
5019         listop->op_first->op_next = range->op_next;
5020         left->op_next = range->op_other;
5021         right->op_next = (OP*)listop;
5022         listop->op_next = listop->op_first;
5023
5024 #ifdef PERL_MAD
5025         op_getmad(expr,(OP*)listop,'O');
5026 #else
5027         op_free(expr);
5028 #endif
5029         expr = (OP*)(listop);
5030         op_null(expr);
5031         iterflags |= OPf_STACKED;
5032     }
5033     else {
5034         expr = mod(force_list(expr), OP_GREPSTART);
5035     }
5036
5037     loop = (LOOP*)list(convert(OP_ENTERITER, iterflags,
5038                                append_elem(OP_LIST, expr, scalar(sv))));
5039     assert(!loop->op_next);
5040     /* for my  $x () sets OPpLVAL_INTRO;
5041      * for our $x () sets OPpOUR_INTRO */
5042     loop->op_private = (U8)iterpflags;
5043 #ifdef PL_OP_SLAB_ALLOC
5044     {
5045         LOOP *tmp;
5046         NewOp(1234,tmp,1,LOOP);
5047         Copy(loop,tmp,1,LISTOP);
5048         S_op_destroy(aTHX_ (OP*)loop);
5049         loop = tmp;
5050     }
5051 #else
5052     loop = (LOOP*)PerlMemShared_realloc(loop, sizeof(LOOP));
5053 #endif
5054     loop->op_targ = padoff;
5055     wop = newWHILEOP(flags, 1, loop, forline, newOP(OP_ITER, 0), block, cont, 0);
5056     if (madsv)
5057         op_getmad(madsv, (OP*)loop, 'v');
5058     PL_parser->copline = forline;
5059     return newSTATEOP(0, label, wop);
5060 }
5061
5062 OP*
5063 Perl_newLOOPEX(pTHX_ I32 type, OP *label)
5064 {
5065     dVAR;
5066     OP *o;
5067
5068     PERL_ARGS_ASSERT_NEWLOOPEX;
5069
5070     if (type != OP_GOTO || label->op_type == OP_CONST) {
5071         /* "last()" means "last" */
5072         if (label->op_type == OP_STUB && (label->op_flags & OPf_PARENS))
5073             o = newOP(type, OPf_SPECIAL);
5074         else {
5075             o = newPVOP(type, 0, savesharedpv(label->op_type == OP_CONST
5076                                         ? SvPV_nolen_const(((SVOP*)label)->op_sv)
5077                                         : ""));
5078         }
5079 #ifdef PERL_MAD
5080         op_getmad(label,o,'L');
5081 #else
5082         op_free(label);
5083 #endif
5084     }
5085     else {
5086         /* Check whether it's going to be a goto &function */
5087         if (label->op_type == OP_ENTERSUB
5088                 && !(label->op_flags & OPf_STACKED))
5089             label = newUNOP(OP_REFGEN, 0, mod(label, OP_REFGEN));
5090         o = newUNOP(type, OPf_STACKED, label);
5091     }
5092     PL_hints |= HINT_BLOCK_SCOPE;
5093     return o;
5094 }
5095
5096 /* if the condition is a literal array or hash
5097    (or @{ ... } etc), make a reference to it.
5098  */
5099 STATIC OP *
5100 S_ref_array_or_hash(pTHX_ OP *cond)
5101 {
5102     if (cond
5103     && (cond->op_type == OP_RV2AV
5104     ||  cond->op_type == OP_PADAV
5105     ||  cond->op_type == OP_RV2HV
5106     ||  cond->op_type == OP_PADHV))
5107
5108         return newUNOP(OP_REFGEN,
5109             0, mod(cond, OP_REFGEN));
5110
5111     else
5112         return cond;
5113 }
5114
5115 /* These construct the optree fragments representing given()
5116    and when() blocks.
5117
5118    entergiven and enterwhen are LOGOPs; the op_other pointer
5119    points up to the associated leave op. We need this so we
5120    can put it in the context and make break/continue work.
5121    (Also, of course, pp_enterwhen will jump straight to
5122    op_other if the match fails.)
5123  */
5124
5125 STATIC OP *
5126 S_newGIVWHENOP(pTHX_ OP *cond, OP *block,
5127                    I32 enter_opcode, I32 leave_opcode,
5128                    PADOFFSET entertarg)
5129 {
5130     dVAR;
5131     LOGOP *enterop;
5132     OP *o;
5133
5134     PERL_ARGS_ASSERT_NEWGIVWHENOP;
5135
5136     NewOp(1101, enterop, 1, LOGOP);
5137     enterop->op_type = (Optype)enter_opcode;
5138     enterop->op_ppaddr = PL_ppaddr[enter_opcode];
5139     enterop->op_flags =  (U8) OPf_KIDS;
5140     enterop->op_targ = ((entertarg == NOT_IN_PAD) ? 0 : entertarg);
5141     enterop->op_private = 0;
5142
5143     o = newUNOP(leave_opcode, 0, (OP *) enterop);
5144
5145     if (cond) {
5146         enterop->op_first = scalar(cond);
5147         cond->op_sibling = block;
5148
5149         o->op_next = LINKLIST(cond);
5150         cond->op_next = (OP *) enterop;
5151     }
5152     else {
5153         /* This is a default {} block */
5154         enterop->op_first = block;
5155         enterop->op_flags |= OPf_SPECIAL;
5156
5157         o->op_next = (OP *) enterop;
5158     }
5159
5160     CHECKOP(enter_opcode, enterop); /* Currently does nothing, since
5161                                        entergiven and enterwhen both
5162                                        use ck_null() */
5163
5164     enterop->op_next = LINKLIST(block);
5165     block->op_next = enterop->op_other = o;
5166
5167     return o;
5168 }
5169
5170 /* Does this look like a boolean operation? For these purposes
5171    a boolean operation is:
5172      - a subroutine call [*]
5173      - a logical connective
5174      - a comparison operator
5175      - a filetest operator, with the exception of -s -M -A -C
5176      - defined(), exists() or eof()
5177      - /$re/ or $foo =~ /$re/
5178    
5179    [*] possibly surprising
5180  */
5181 STATIC bool
5182 S_looks_like_bool(pTHX_ const OP *o)
5183 {
5184     dVAR;
5185
5186     PERL_ARGS_ASSERT_LOOKS_LIKE_BOOL;
5187
5188     switch(o->op_type) {
5189         case OP_OR:
5190         case OP_DOR:
5191             return looks_like_bool(cLOGOPo->op_first);
5192
5193         case OP_AND:
5194             return (
5195                 looks_like_bool(cLOGOPo->op_first)
5196              && looks_like_bool(cLOGOPo->op_first->op_sibling));
5197
5198         case OP_NULL:
5199             return (
5200                 o->op_flags & OPf_KIDS
5201             && looks_like_bool(cUNOPo->op_first));
5202
5203         case OP_ENTERSUB:
5204
5205         case OP_NOT:    case OP_XOR:
5206
5207         case OP_EQ:     case OP_NE:     case OP_LT:
5208         case OP_GT:     case OP_LE:     case OP_GE:
5209
5210         case OP_I_EQ:   case OP_I_NE:   case OP_I_LT:
5211         case OP_I_GT:   case OP_I_LE:   case OP_I_GE:
5212
5213         case OP_SEQ:    case OP_SNE:    case OP_SLT:
5214         case OP_SGT:    case OP_SLE:    case OP_SGE:
5215         
5216         case OP_SMARTMATCH:
5217         
5218         case OP_FTRREAD:  case OP_FTRWRITE: case OP_FTREXEC:
5219         case OP_FTEREAD:  case OP_FTEWRITE: case OP_FTEEXEC:
5220         case OP_FTIS:     case OP_FTEOWNED: case OP_FTROWNED:
5221         case OP_FTZERO:   case OP_FTSOCK:   case OP_FTCHR:
5222         case OP_FTBLK:    case OP_FTFILE:   case OP_FTDIR:
5223         case OP_FTPIPE:   case OP_FTLINK:   case OP_FTSUID:
5224         case OP_FTSGID:   case OP_FTSVTX:   case OP_FTTTY:
5225         case OP_FTTEXT:   case OP_FTBINARY:
5226         
5227         case OP_DEFINED: case OP_EXISTS:
5228         case OP_MATCH:   case OP_EOF:
5229
5230         case OP_FLOP:
5231
5232             return TRUE;
5233         
5234         case OP_CONST:
5235             /* Detect comparisons that have been optimized away */
5236             if (cSVOPo->op_sv == &PL_sv_yes
5237             ||  cSVOPo->op_sv == &PL_sv_no)
5238             
5239                 return TRUE;
5240             else
5241                 return FALSE;
5242
5243         /* FALL THROUGH */
5244         default:
5245             return FALSE;
5246     }
5247 }
5248
5249 OP *
5250 Perl_newGIVENOP(pTHX_ OP *cond, OP *block, PADOFFSET defsv_off)
5251 {
5252     dVAR;
5253     PERL_ARGS_ASSERT_NEWGIVENOP;
5254     return newGIVWHENOP(
5255         ref_array_or_hash(cond),
5256         block,
5257         OP_ENTERGIVEN, OP_LEAVEGIVEN,
5258         defsv_off);
5259 }
5260
5261 /* If cond is null, this is a default {} block */
5262 OP *
5263 Perl_newWHENOP(pTHX_ OP *cond, OP *block)
5264 {
5265     const bool cond_llb = (!cond || looks_like_bool(cond));
5266     OP *cond_op;
5267
5268     PERL_ARGS_ASSERT_NEWWHENOP;
5269
5270     if (cond_llb)
5271         cond_op = cond;
5272     else {
5273         cond_op = newBINOP(OP_SMARTMATCH, OPf_SPECIAL,
5274                 newDEFSVOP(),
5275                 scalar(ref_array_or_hash(cond)));
5276     }
5277     
5278     return newGIVWHENOP(
5279         cond_op,
5280         append_elem(block->op_type, block, newOP(OP_BREAK, OPf_SPECIAL)),
5281         OP_ENTERWHEN, OP_LEAVEWHEN, 0);
5282 }
5283
5284 /*
5285 =for apidoc cv_undef
5286
5287 Clear out all the active components of a CV. This can happen either
5288 by an explicit C<undef &foo>, or by the reference count going to zero.
5289 In the former case, we keep the CvOUTSIDE pointer, so that any anonymous
5290 children can still follow the full lexical scope chain.
5291
5292 =cut
5293 */
5294
5295 void
5296 Perl_cv_undef(pTHX_ CV *cv)
5297 {
5298     dVAR;
5299
5300     PERL_ARGS_ASSERT_CV_UNDEF;
5301
5302     DEBUG_X(PerlIO_printf(Perl_debug_log,
5303           "CV undef: cv=0x%"UVxf" comppad=0x%"UVxf"\n",
5304             PTR2UV(cv), PTR2UV(PL_comppad))
5305     );
5306
5307 #ifdef USE_ITHREADS
5308     if (CvFILE(cv) && !CvISXSUB(cv)) {
5309         /* for XSUBs CvFILE point directly to static memory; __FILE__ */
5310         Safefree(CvFILE(cv));
5311     }
5312     CvFILE(cv) = NULL;
5313 #endif
5314
5315     if (!CvISXSUB(cv) && CvROOT(cv)) {
5316         if (SvTYPE(cv) == SVt_PVCV && CvDEPTH(cv))
5317             Perl_croak(aTHX_ "Can't undef active subroutine");
5318         ENTER;
5319
5320         PAD_SAVE_SETNULLPAD();
5321
5322         op_free(CvROOT(cv));
5323         CvROOT(cv) = NULL;
5324         CvSTART(cv) = NULL;
5325         LEAVE;
5326     }
5327     SvPOK_off(MUTABLE_SV(cv));          /* forget prototype */
5328     CvGV(cv) = NULL;
5329
5330     pad_undef(cv);
5331
5332     /* remove CvOUTSIDE unless this is an undef rather than a free */
5333     if (!SvREFCNT(cv) && CvOUTSIDE(cv)) {
5334         if (!CvWEAKOUTSIDE(cv))
5335             SvREFCNT_dec(CvOUTSIDE(cv));
5336         CvOUTSIDE(cv) = NULL;
5337     }
5338     if (CvCONST(cv)) {
5339         SvREFCNT_dec(MUTABLE_SV(CvXSUBANY(cv).any_ptr));
5340         CvCONST_off(cv);
5341     }
5342     if (CvISXSUB(cv) && CvXSUB(cv)) {
5343         CvXSUB(cv) = NULL;
5344     }
5345     /* delete all flags except WEAKOUTSIDE */
5346     CvFLAGS(cv) &= CVf_WEAKOUTSIDE;
5347 }
5348
5349 void
5350 Perl_cv_ckproto_len(pTHX_ const CV *cv, const GV *gv, const char *p,
5351                     const STRLEN len)
5352 {
5353     PERL_ARGS_ASSERT_CV_CKPROTO_LEN;
5354
5355     /* Can't just use a strcmp on the prototype, as CONSTSUBs "cheat" by
5356        relying on SvCUR, and doubling up the buffer to hold CvFILE().  */
5357     if (((!p != !SvPOK(cv)) /* One has prototype, one has not.  */
5358          || (p && (len != SvCUR(cv) /* Not the same length.  */
5359                    || memNE(p, SvPVX_const(cv), len))))
5360          && ckWARN_d(WARN_PROTOTYPE)) {
5361         SV* const msg = sv_newmortal();
5362         SV* name = NULL;
5363
5364         if (gv)
5365             gv_efullname3(name = sv_newmortal(), gv, NULL);
5366         sv_setpvs(msg, "Prototype mismatch:");
5367         if (name)
5368             Perl_sv_catpvf(aTHX_ msg, " sub %"SVf, SVfARG(name));
5369         if (SvPOK(cv))
5370             Perl_sv_catpvf(aTHX_ msg, " (%"SVf")", SVfARG(cv));
5371         else
5372             sv_catpvs(msg, ": none");
5373         sv_catpvs(msg, " vs ");
5374         if (p)
5375             Perl_sv_catpvf(aTHX_ msg, "(%.*s)", (int) len, p);
5376         else
5377             sv_catpvs(msg, "none");
5378         Perl_warner(aTHX_ packWARN(WARN_PROTOTYPE), "%"SVf, SVfARG(msg));
5379     }
5380 }
5381
5382 static void const_sv_xsub(pTHX_ CV* cv);
5383
5384 /*
5385
5386 =head1 Optree Manipulation Functions
5387
5388 =for apidoc cv_const_sv
5389
5390 If C<cv> is a constant sub eligible for inlining. returns the constant
5391 value returned by the sub.  Otherwise, returns NULL.
5392
5393 Constant subs can be created with C<newCONSTSUB> or as described in
5394 L<perlsub/"Constant Functions">.
5395
5396 =cut
5397 */
5398 SV *
5399 Perl_cv_const_sv(pTHX_ const CV *const cv)
5400 {
5401     PERL_UNUSED_CONTEXT;
5402     if (!cv)
5403         return NULL;
5404     if (!(SvTYPE(cv) == SVt_PVCV || SvTYPE(cv) == SVt_PVFM))
5405         return NULL;
5406     return CvCONST(cv) ? MUTABLE_SV(CvXSUBANY(cv).any_ptr) : NULL;
5407 }
5408
5409 /* op_const_sv:  examine an optree to determine whether it's in-lineable.
5410  * Can be called in 3 ways:
5411  *
5412  * !cv
5413  *      look for a single OP_CONST with attached value: return the value
5414  *
5415  * cv && CvCLONE(cv) && !CvCONST(cv)
5416  *
5417  *      examine the clone prototype, and if contains only a single
5418  *      OP_CONST referencing a pad const, or a single PADSV referencing
5419  *      an outer lexical, return a non-zero value to indicate the CV is
5420  *      a candidate for "constizing" at clone time
5421  *
5422  * cv && CvCONST(cv)
5423  *
5424  *      We have just cloned an anon prototype that was marked as a const
5425  *      candidiate. Try to grab the current value, and in the case of
5426  *      PADSV, ignore it if it has multiple references. Return the value.
5427  */
5428
5429 SV *
5430 Perl_op_const_sv(pTHX_ const OP *o, CV *cv)
5431 {
5432     dVAR;
5433     SV *sv = NULL;
5434
5435     if (PL_madskills)
5436         return NULL;
5437
5438     if (!o)
5439         return NULL;
5440
5441     if (o->op_type == OP_LINESEQ && cLISTOPo->op_first)
5442         o = cLISTOPo->op_first->op_sibling;
5443
5444     for (; o; o = o->op_next) {
5445         const OPCODE type = o->op_type;
5446
5447         if (sv && o->op_next == o)
5448             return sv;
5449         if (o->op_next != o) {
5450             if (type == OP_NEXTSTATE || type == OP_NULL || type == OP_PUSHMARK)
5451                 continue;
5452             if (type == OP_DBSTATE)
5453                 continue;
5454         }
5455         if (type == OP_LEAVESUB || type == OP_RETURN)
5456             break;
5457         if (sv)
5458             return NULL;
5459         if (type == OP_CONST && cSVOPo->op_sv)
5460             sv = cSVOPo->op_sv;
5461         else if (cv && type == OP_CONST) {
5462             sv = PAD_BASE_SV(CvPADLIST(cv), o->op_targ);
5463             if (!sv)
5464                 return NULL;
5465         }
5466         else if (cv && type == OP_PADSV) {
5467             if (CvCONST(cv)) { /* newly cloned anon */
5468                 sv = PAD_BASE_SV(CvPADLIST(cv), o->op_targ);
5469                 /* the candidate should have 1 ref from this pad and 1 ref
5470                  * from the parent */
5471                 if (!sv || SvREFCNT(sv) != 2)
5472                     return NULL;
5473                 sv = newSVsv(sv);
5474                 SvREADONLY_on(sv);
5475                 return sv;
5476             }
5477             else {
5478                 if (PAD_COMPNAME_FLAGS(o->op_targ) & SVf_FAKE)
5479                     sv = &PL_sv_undef; /* an arbitrary non-null value */
5480             }
5481         }
5482         else {
5483             return NULL;
5484         }
5485     }
5486     return sv;
5487 }
5488
5489 #ifdef PERL_MAD
5490 OP *
5491 #else
5492 void
5493 #endif
5494 Perl_newMYSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *attrs, OP *block)
5495 {
5496 #if 0
5497     /* This would be the return value, but the return cannot be reached.  */
5498     OP* pegop = newOP(OP_NULL, 0);
5499 #endif
5500
5501     PERL_UNUSED_ARG(floor);
5502
5503     if (o)
5504         SAVEFREEOP(o);
5505     if (proto)
5506         SAVEFREEOP(proto);
5507     if (attrs)
5508         SAVEFREEOP(attrs);
5509     if (block)
5510         SAVEFREEOP(block);
5511     Perl_croak(aTHX_ "\"my sub\" not yet implemented");
5512 #ifdef PERL_MAD
5513     NORETURN_FUNCTION_END;
5514 #endif
5515 }
5516
5517 CV *
5518 Perl_newSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *block)
5519 {
5520     return Perl_newATTRSUB(aTHX_ floor, o, proto, NULL, block);
5521 }
5522
5523 CV *
5524 Perl_newATTRSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *attrs, OP *block)
5525 {
5526     dVAR;
5527     const char *aname;
5528     GV *gv;
5529     const char *ps;
5530     STRLEN ps_len;
5531     register CV *cv = NULL;
5532     SV *const_sv;
5533     /* If the subroutine has no body, no attributes, and no builtin attributes
5534        then it's just a sub declaration, and we may be able to get away with
5535        storing with a placeholder scalar in the symbol table, rather than a
5536        full GV and CV.  If anything is present then it will take a full CV to
5537        store it.  */
5538     const I32 gv_fetch_flags
5539         = (block || attrs || (CvFLAGS(PL_compcv) & CVf_BUILTIN_ATTRS)
5540            || PL_madskills)
5541         ? GV_ADDMULTI : GV_ADDMULTI | GV_NOINIT;
5542     const char * const name = o ? SvPV_nolen_const(cSVOPo->op_sv) : NULL;
5543
5544     if (proto) {
5545         assert(proto->op_type == OP_CONST);
5546         ps = SvPV_const(((SVOP*)proto)->op_sv, ps_len);
5547     }
5548     else
5549         ps = NULL;
5550
5551     if (!name && PERLDB_NAMEANON && CopLINE(PL_curcop)) {
5552         SV * const sv = sv_newmortal();
5553         Perl_sv_setpvf(aTHX_ sv, "%s[%s:%"IVdf"]",
5554                        PL_curstash ? "__ANON__" : "__ANON__::__ANON__",
5555                        CopFILE(PL_curcop), (IV)CopLINE(PL_curcop));
5556         aname = SvPVX_const(sv);
5557     }
5558     else
5559         aname = NULL;
5560
5561     gv = name ? gv_fetchsv(cSVOPo->op_sv, gv_fetch_flags, SVt_PVCV)
5562         : gv_fetchpv(aname ? aname
5563                      : (PL_curstash ? "__ANON__" : "__ANON__::__ANON__"),
5564                      gv_fetch_flags, SVt_PVCV);
5565
5566     if (!PL_madskills) {
5567         if (o)
5568             SAVEFREEOP(o);
5569         if (proto)
5570             SAVEFREEOP(proto);
5571         if (attrs)
5572             SAVEFREEOP(attrs);
5573     }
5574
5575     if (SvTYPE(gv) != SVt_PVGV) {       /* Maybe prototype now, and had at
5576                                            maximum a prototype before. */
5577         if (SvTYPE(gv) > SVt_NULL) {
5578             if (!SvPOK((const SV *)gv)
5579                 && !(SvIOK((const SV *)gv) && SvIVX((const SV *)gv) == -1)
5580                 && ckWARN_d(WARN_PROTOTYPE))
5581             {
5582                 Perl_warner(aTHX_ packWARN(WARN_PROTOTYPE), "Runaway prototype");
5583             }
5584             cv_ckproto_len((const CV *)gv, NULL, ps, ps_len);
5585         }
5586         if (ps)
5587             sv_setpvn(MUTABLE_SV(gv), ps, ps_len);
5588         else
5589             sv_setiv(MUTABLE_SV(gv), -1);
5590
5591         SvREFCNT_dec(PL_compcv);
5592         cv = PL_compcv = NULL;
5593         goto done;
5594     }
5595
5596     cv = (!name || GvCVGEN(gv)) ? NULL : GvCV(gv);
5597
5598     if (!block || !ps || *ps || attrs
5599         || (CvFLAGS(PL_compcv) & CVf_BUILTIN_ATTRS)
5600 #ifdef PERL_MAD
5601         || block->op_type == OP_NULL
5602 #endif
5603         )
5604         const_sv = NULL;
5605     else
5606         const_sv = op_const_sv(block, NULL);
5607
5608     if (cv) {
5609         const bool exists = CvROOT(cv) || CvXSUB(cv);
5610
5611         /* if the subroutine doesn't exist and wasn't pre-declared
5612          * with a prototype, assume it will be AUTOLOADed,
5613          * skipping the prototype check
5614          */
5615         if (exists || SvPOK(cv))
5616             cv_ckproto_len(cv, gv, ps, ps_len);
5617         /* already defined (or promised)? */
5618         if (exists || GvASSUMECV(gv)) {
5619             if ((!block
5620 #ifdef PERL_MAD
5621                  || block->op_type == OP_NULL
5622 #endif
5623                  )&& !attrs) {
5624                 if (CvFLAGS(PL_compcv)) {
5625                     /* might have had built-in attrs applied */
5626                     CvFLAGS(cv) |= (CvFLAGS(PL_compcv) & CVf_BUILTIN_ATTRS);
5627                 }
5628                 /* just a "sub foo;" when &foo is already defined */
5629                 SAVEFREESV(PL_compcv);
5630                 goto done;
5631             }
5632             if (block
5633 #ifdef PERL_MAD
5634                 && block->op_type != OP_NULL
5635 #endif
5636                 ) {
5637                 if (ckWARN(WARN_REDEFINE)
5638                     || (CvCONST(cv)
5639                         && (!const_sv || sv_cmp(cv_const_sv(cv), const_sv))))
5640                 {
5641                     const line_t oldline = CopLINE(PL_curcop);
5642                     if (PL_parser && PL_parser->copline != NOLINE)
5643                         CopLINE_set(PL_curcop, PL_parser->copline);
5644                     Perl_warner(aTHX_ packWARN(WARN_REDEFINE),
5645                         CvCONST(cv) ? "Constant subroutine %s redefined"
5646                                     : "Subroutine %s redefined", name);
5647                     CopLINE_set(PL_curcop, oldline);
5648                 }
5649 #ifdef PERL_MAD
5650                 if (!PL_minus_c)        /* keep old one around for madskills */
5651 #endif
5652                     {
5653                         /* (PL_madskills unset in used file.) */
5654                         SvREFCNT_dec(cv);
5655                     }
5656                 cv = NULL;
5657             }
5658         }
5659     }
5660     if (const_sv) {
5661         SvREFCNT_inc_simple_void_NN(const_sv);
5662         if (cv) {
5663             assert(!CvROOT(cv) && !CvCONST(cv));
5664             sv_setpvs(MUTABLE_SV(cv), "");  /* prototype is "" */
5665             CvXSUBANY(cv).any_ptr = const_sv;
5666             CvXSUB(cv) = const_sv_xsub;
5667             CvCONST_on(cv);
5668             CvISXSUB_on(cv);
5669         }
5670         else {
5671             GvCV(gv) = NULL;
5672             cv = newCONSTSUB(NULL, name, const_sv);
5673         }
5674         mro_method_changed_in( /* sub Foo::Bar () { 123 } */
5675             (CvGV(cv) && GvSTASH(CvGV(cv)))
5676                 ? GvSTASH(CvGV(cv))
5677                 : CvSTASH(cv)
5678                     ? CvSTASH(cv)
5679                     : PL_curstash
5680         );
5681         if (PL_madskills)
5682             goto install_block;
5683         op_free(block);
5684         SvREFCNT_dec(PL_compcv);
5685         PL_compcv = NULL;
5686         goto done;
5687     }
5688     if (attrs) {
5689         HV *stash;
5690         SV *rcv;
5691
5692         /* Need to do a C<use attributes $stash_of_cv,\&cv,@attrs>
5693          * before we clobber PL_compcv.
5694          */
5695         if (cv && (!block
5696 #ifdef PERL_MAD
5697                     || block->op_type == OP_NULL
5698 #endif
5699                     )) {
5700             rcv = MUTABLE_SV(cv);
5701             /* Might have had built-in attributes applied -- propagate them. */
5702             CvFLAGS(cv) |= (CvFLAGS(PL_compcv) & CVf_BUILTIN_ATTRS);
5703             if (CvGV(cv) && GvSTASH(CvGV(cv)))
5704                 stash = GvSTASH(CvGV(cv));
5705             else if (CvSTASH(cv))
5706                 stash = CvSTASH(cv);
5707             else
5708                 stash = PL_curstash;
5709         }
5710         else {
5711             /* possibly about to re-define existing subr -- ignore old cv */
5712             rcv = MUTABLE_SV(PL_compcv);
5713             if (name && GvSTASH(gv))
5714                 stash = GvSTASH(gv);
5715             else
5716                 stash = PL_curstash;
5717         }
5718         apply_attrs(stash, rcv, attrs, FALSE);
5719     }
5720     if (cv) {                           /* must reuse cv if autoloaded */
5721         if (
5722 #ifdef PERL_MAD
5723             (
5724 #endif
5725              !block
5726 #ifdef PERL_MAD
5727              || block->op_type == OP_NULL) && !PL_madskills
5728 #endif
5729              ) {
5730             /* got here with just attrs -- work done, so bug out */
5731             SAVEFREESV(PL_compcv);
5732             goto done;
5733         }
5734         /* transfer PL_compcv to cv */
5735         cv_undef(cv);
5736         CvFLAGS(cv) = CvFLAGS(PL_compcv);
5737         if (!CvWEAKOUTSIDE(cv))
5738             SvREFCNT_dec(CvOUTSIDE(cv));
5739         CvOUTSIDE(cv) = CvOUTSIDE(PL_compcv);
5740         CvOUTSIDE_SEQ(cv) = CvOUTSIDE_SEQ(PL_compcv);
5741         CvOUTSIDE(PL_compcv) = 0;
5742         CvPADLIST(cv) = CvPADLIST(PL_compcv);
5743         CvPADLIST(PL_compcv) = 0;
5744         /* inner references to PL_compcv must be fixed up ... */
5745         pad_fixup_inner_anons(CvPADLIST(cv), PL_compcv, cv);
5746         /* ... before we throw it away */
5747         SvREFCNT_dec(PL_compcv);
5748         PL_compcv = cv;
5749         if (PERLDB_INTER)/* Advice debugger on the new sub. */
5750           ++PL_sub_generation;
5751     }
5752     else {
5753         cv = PL_compcv;
5754         if (name) {
5755             GvCV(gv) = cv;
5756             if (PL_madskills) {
5757                 if (strEQ(name, "import")) {
5758                     PL_formfeed = MUTABLE_SV(cv);
5759                     Perl_warner(aTHX_ packWARN(WARN_VOID), "%lx\n", (long)cv);
5760                 }
5761             }
5762             GvCVGEN(gv) = 0;
5763             mro_method_changed_in(GvSTASH(gv)); /* sub Foo::bar { (shift)+1 } */
5764         }
5765     }
5766     CvGV(cv) = gv;
5767     CvFILE_set_from_cop(cv, PL_curcop);
5768     CvSTASH(cv) = PL_curstash;
5769
5770     if (ps)
5771         sv_setpvn(MUTABLE_SV(cv), ps, ps_len);
5772
5773     if (PL_parser && PL_parser->error_count) {
5774         op_free(block);
5775         block = NULL;
5776         if (name) {
5777             const char *s = strrchr(name, ':');
5778             s = s ? s+1 : name;
5779             if (strEQ(s, "BEGIN")) {
5780                 const char not_safe[] =
5781                     "BEGIN not safe after errors--compilation aborted";
5782                 if (PL_in_eval & EVAL_KEEPERR)
5783                     Perl_croak(aTHX_ not_safe);
5784                 else {
5785                     /* force display of errors found but not reported */
5786                     sv_catpv(ERRSV, not_safe);
5787                     Perl_croak(aTHX_ "%"SVf, SVfARG(ERRSV));
5788                 }
5789             }
5790         }
5791     }
5792  install_block:
5793     if (!block)
5794         goto done;
5795
5796     /* If we assign an optree to a PVCV, then we've defined a subroutine that
5797        the debugger could be able to set a breakpoint in, so signal to
5798        pp_entereval that it should not throw away any saved lines at scope
5799        exit.  */
5800        
5801     PL_breakable_sub_gen++;
5802     if (CvLVALUE(cv)) {
5803         CvROOT(cv) = newUNOP(OP_LEAVESUBLV, 0,
5804                              mod(scalarseq(block), OP_LEAVESUBLV));
5805         block->op_attached = 1;
5806     }
5807     else {
5808         /* This makes sub {}; work as expected.  */
5809         if (block->op_type == OP_STUB) {
5810             OP* const newblock = newSTATEOP(0, NULL, 0);
5811 #ifdef PERL_MAD
5812             op_getmad(block,newblock,'B');
5813 #else
5814             op_free(block);
5815 #endif
5816             block = newblock;
5817         }
5818         else
5819             block->op_attached = 1;
5820         CvROOT(cv) = newUNOP(OP_LEAVESUB, 0, scalarseq(block));
5821     }
5822     CvROOT(cv)->op_private |= OPpREFCOUNTED;
5823     OpREFCNT_set(CvROOT(cv), 1);
5824     CvSTART(cv) = LINKLIST(CvROOT(cv));
5825     CvROOT(cv)->op_next = 0;
5826     CALL_PEEP(CvSTART(cv));
5827
5828     /* now that optimizer has done its work, adjust pad values */
5829
5830     pad_tidy(CvCLONE(cv) ? padtidy_SUBCLONE : padtidy_SUB);
5831
5832     if (CvCLONE(cv)) {
5833         assert(!CvCONST(cv));
5834         if (ps && !*ps && op_const_sv(block, cv))
5835             CvCONST_on(cv);
5836     }
5837
5838     if (name || aname) {
5839         if (PERLDB_SUBLINE && PL_curstash != PL_debstash) {
5840             SV * const sv = newSV(0);
5841             SV * const tmpstr = sv_newmortal();
5842             GV * const db_postponed = gv_fetchpvs("DB::postponed",
5843                                                   GV_ADDMULTI, SVt_PVHV);
5844             HV *hv;
5845
5846             Perl_sv_setpvf(aTHX_ sv, "%s:%ld-%ld",
5847                            CopFILE(PL_curcop),
5848                            (long)PL_subline, (long)CopLINE(PL_curcop));
5849             gv_efullname3(tmpstr, gv, NULL);
5850             (void)hv_store(GvHV(PL_DBsub), SvPVX_const(tmpstr),
5851                     SvCUR(tmpstr), sv, 0);
5852             hv = GvHVn(db_postponed);
5853             if (HvFILL(hv) > 0 && hv_exists(hv, SvPVX_const(tmpstr), SvCUR(tmpstr))) {
5854                 CV * const pcv = GvCV(db_postponed);
5855                 if (pcv) {
5856                     dSP;
5857                     PUSHMARK(SP);
5858                     XPUSHs(tmpstr);
5859                     PUTBACK;
5860                     call_sv(MUTABLE_SV(pcv), G_DISCARD);
5861                 }
5862             }
5863         }
5864
5865         if (name && ! (PL_parser && PL_parser->error_count))
5866             process_special_blocks(name, gv, cv);
5867     }
5868
5869   done:
5870     if (PL_parser)
5871         PL_parser->copline = NOLINE;
5872     LEAVE_SCOPE(floor);
5873     return cv;
5874 }
5875
5876 STATIC void
5877 S_process_special_blocks(pTHX_ const char *const fullname, GV *const gv,
5878                          CV *const cv)
5879 {
5880     const char *const colon = strrchr(fullname,':');
5881     const char *const name = colon ? colon + 1 : fullname;
5882
5883     PERL_ARGS_ASSERT_PROCESS_SPECIAL_BLOCKS;
5884
5885     if (*name == 'B') {
5886         if (strEQ(name, "BEGIN")) {
5887             const I32 oldscope = PL_scopestack_ix;
5888             ENTER;
5889             SAVECOPFILE(&PL_compiling);
5890             SAVECOPLINE(&PL_compiling);
5891
5892             DEBUG_x( dump_sub(gv) );
5893             Perl_av_create_and_push(aTHX_ &PL_beginav, MUTABLE_SV(cv));
5894             GvCV(gv) = 0;               /* cv has been hijacked */
5895             call_list(oldscope, PL_beginav);
5896
5897             PL_curcop = &PL_compiling;
5898             CopHINTS_set(&PL_compiling, PL_hints);
5899             LEAVE;
5900         }
5901         else
5902             return;
5903     } else {
5904         if (*name == 'E') {
5905             if strEQ(name, "END") {
5906                 DEBUG_x( dump_sub(gv) );
5907                 Perl_av_create_and_unshift_one(aTHX_ &PL_endav, MUTABLE_SV(cv));
5908             } else
5909                 return;
5910         } else if (*name == 'U') {
5911             if (strEQ(name, "UNITCHECK")) {
5912                 /* It's never too late to run a unitcheck block */
5913                 Perl_av_create_and_unshift_one(aTHX_ &PL_unitcheckav, MUTABLE_SV(cv));
5914             }
5915             else
5916                 return;
5917         } else if (*name == 'C') {
5918             if (strEQ(name, "CHECK")) {
5919                 if (PL_main_start && ckWARN(WARN_VOID))
5920                     Perl_warner(aTHX_ packWARN(WARN_VOID),
5921                                 "Too late to run CHECK block");
5922                 Perl_av_create_and_unshift_one(aTHX_ &PL_checkav, MUTABLE_SV(cv));
5923             }
5924             else
5925                 return;
5926         } else if (*name == 'I') {
5927             if (strEQ(name, "INIT")) {
5928                 if (PL_main_start && ckWARN(WARN_VOID))
5929                     Perl_warner(aTHX_ packWARN(WARN_VOID),
5930                                 "Too late to run INIT block");
5931                 Perl_av_create_and_push(aTHX_ &PL_initav, MUTABLE_SV(cv));
5932             }
5933             else
5934                 return;
5935         } else
5936             return;
5937         DEBUG_x( dump_sub(gv) );
5938         GvCV(gv) = 0;           /* cv has been hijacked */
5939     }
5940 }
5941
5942 /*
5943 =for apidoc newCONSTSUB
5944
5945 Creates a constant sub equivalent to Perl C<sub FOO () { 123 }> which is
5946 eligible for inlining at compile-time.
5947
5948 Passing NULL for SV creates a constant sub equivalent to C<sub BAR () {}>,
5949 which won't be called if used as a destructor, but will suppress the overhead
5950 of a call to C<AUTOLOAD>.  (This form, however, isn't eligible for inlining at
5951 compile time.)
5952
5953 =cut
5954 */
5955
5956 CV *
5957 Perl_newCONSTSUB(pTHX_ HV *stash, const char *name, SV *sv)
5958 {
5959     dVAR;
5960     CV* cv;
5961 #ifdef USE_ITHREADS
5962     const char *const file = CopFILE(PL_curcop);
5963 #else
5964     SV *const temp_sv = CopFILESV(PL_curcop);
5965     const char *const file = temp_sv ? SvPV_nolen_const(temp_sv) : NULL;
5966 #endif
5967
5968     ENTER;
5969
5970     if (IN_PERL_RUNTIME) {
5971         /* at runtime, it's not safe to manipulate PL_curcop: it may be
5972          * an op shared between threads. Use a non-shared COP for our
5973          * dirty work */
5974          SAVEVPTR(PL_curcop);
5975          PL_curcop = &PL_compiling;
5976     }
5977     SAVECOPLINE(PL_curcop);
5978     CopLINE_set(PL_curcop, PL_parser ? PL_parser->copline : NOLINE);
5979
5980     SAVEHINTS();
5981     PL_hints &= ~HINT_BLOCK_SCOPE;
5982
5983     if (stash) {
5984         SAVESPTR(PL_curstash);
5985         SAVECOPSTASH(PL_curcop);
5986         PL_curstash = stash;
5987         CopSTASH_set(PL_curcop,stash);
5988     }
5989
5990     /* file becomes the CvFILE. For an XS, it's supposed to be static storage,
5991        and so doesn't get free()d.  (It's expected to be from the C pre-
5992        processor __FILE__ directive). But we need a dynamically allocated one,
5993        and we need it to get freed.  */
5994     cv = newXS_flags(name, const_sv_xsub, file ? file : "", "",
5995                      XS_DYNAMIC_FILENAME);
5996     CvXSUBANY(cv).any_ptr = sv;
5997     CvCONST_on(cv);
5998
5999 #ifdef USE_ITHREADS
6000     if (stash)
6001         CopSTASH_free(PL_curcop);
6002 #endif
6003     LEAVE;
6004
6005     return cv;
6006 }
6007
6008 CV *
6009 Perl_newXS_flags(pTHX_ const char *name, XSUBADDR_t subaddr,
6010                  const char *const filename, const char *const proto,
6011                  U32 flags)
6012 {
6013     CV *cv = newXS(name, subaddr, filename);
6014
6015     PERL_ARGS_ASSERT_NEWXS_FLAGS;
6016
6017     if (flags & XS_DYNAMIC_FILENAME) {
6018         /* We need to "make arrangements" (ie cheat) to ensure that the
6019            filename lasts as long as the PVCV we just created, but also doesn't
6020            leak  */
6021         STRLEN filename_len = strlen(filename);
6022         STRLEN proto_and_file_len = filename_len;
6023         char *proto_and_file;
6024         STRLEN proto_len;
6025
6026         if (proto) {
6027             proto_len = strlen(proto);
6028             proto_and_file_len += proto_len;
6029
6030             Newx(proto_and_file, proto_and_file_len + 1, char);
6031             Copy(proto, proto_and_file, proto_len, char);
6032             Copy(filename, proto_and_file + proto_len, filename_len + 1, char);
6033         } else {
6034             proto_len = 0;
6035             proto_and_file = savepvn(filename, filename_len);
6036         }
6037
6038         /* This gets free()d.  :-)  */
6039         sv_usepvn_flags(MUTABLE_SV(cv), proto_and_file, proto_and_file_len,
6040                         SV_HAS_TRAILING_NUL);
6041         if (proto) {
6042             /* This gives us the correct prototype, rather than one with the
6043                file name appended.  */
6044             SvCUR_set(cv, proto_len);
6045         } else {
6046             SvPOK_off(cv);
6047         }
6048         CvFILE(cv) = proto_and_file + proto_len;
6049     } else {
6050         sv_setpv(MUTABLE_SV(cv), proto);
6051     }
6052     return cv;
6053 }
6054
6055 /*
6056 =for apidoc U||newXS
6057
6058 Used by C<xsubpp> to hook up XSUBs as Perl subs.  I<filename> needs to be
6059 static storage, as it is used directly as CvFILE(), without a copy being made.
6060
6061 =cut
6062 */
6063
6064 CV *
6065 Perl_newXS(pTHX_ const char *name, XSUBADDR_t subaddr, const char *filename)
6066 {
6067     dVAR;
6068     GV * const gv = gv_fetchpv(name ? name :
6069                         (PL_curstash ? "__ANON__" : "__ANON__::__ANON__"),
6070                         GV_ADDMULTI, SVt_PVCV);
6071     register CV *cv;
6072
6073     PERL_ARGS_ASSERT_NEWXS;
6074
6075     if (!subaddr)
6076         Perl_croak(aTHX_ "panic: no address for '%s' in '%s'", name, filename);
6077
6078     if ((cv = (name ? GvCV(gv) : NULL))) {
6079         if (GvCVGEN(gv)) {
6080             /* just a cached method */
6081             SvREFCNT_dec(cv);
6082             cv = NULL;
6083         }
6084         else if (CvROOT(cv) || CvXSUB(cv) || GvASSUMECV(gv)) {
6085             /* already defined (or promised) */
6086             /* XXX It's possible for this HvNAME_get to return null, and get passed into strEQ */
6087             if (ckWARN(WARN_REDEFINE)) {
6088                 GV * const gvcv = CvGV(cv);
6089                 if (gvcv) {
6090                     HV * const stash = GvSTASH(gvcv);
6091                     if (stash) {
6092                         const char *redefined_name = HvNAME_get(stash);
6093                         if ( strEQ(redefined_name,"autouse") ) {
6094                             const line_t oldline = CopLINE(PL_curcop);
6095                             if (PL_parser && PL_parser->copline != NOLINE)
6096                                 CopLINE_set(PL_curcop, PL_parser->copline);
6097                             Perl_warner(aTHX_ packWARN(WARN_REDEFINE),
6098                                         CvCONST(cv) ? "Constant subroutine %s redefined"
6099                                                     : "Subroutine %s redefined"
6100                                         ,name);
6101                             CopLINE_set(PL_curcop, oldline);
6102                         }
6103                     }
6104                 }
6105             }
6106             SvREFCNT_dec(cv);
6107             cv = NULL;
6108         }
6109     }
6110
6111     if (cv)                             /* must reuse cv if autoloaded */
6112         cv_undef(cv);
6113     else {
6114         cv = MUTABLE_CV(newSV_type(SVt_PVCV));
6115         if (name) {
6116             GvCV(gv) = cv;
6117             GvCVGEN(gv) = 0;
6118             mro_method_changed_in(GvSTASH(gv)); /* newXS */
6119         }
6120     }
6121     CvGV(cv) = gv;
6122     (void)gv_fetchfile(filename);
6123     CvFILE(cv) = (char *)filename; /* NOTE: not copied, as it is expected to be
6124                                    an external constant string */
6125     CvISXSUB_on(cv);
6126     CvXSUB(cv) = subaddr;
6127
6128     if (name)
6129         process_special_blocks(name, gv, cv);
6130     else
6131         CvANON_on(cv);
6132
6133     return cv;
6134 }
6135
6136 #ifdef PERL_MAD
6137 OP *
6138 #else
6139 void
6140 #endif
6141 Perl_newFORM(pTHX_ I32 floor, OP *o, OP *block)
6142 {
6143     dVAR;
6144     register CV *cv;
6145 #ifdef PERL_MAD
6146     OP* pegop = newOP(OP_NULL, 0);
6147 #endif
6148
6149     GV * const gv = o
6150         ? gv_fetchsv(cSVOPo->op_sv, GV_ADD, SVt_PVFM)
6151         : gv_fetchpvs("STDOUT", GV_ADD|GV_NOTQUAL, SVt_PVFM);
6152
6153     GvMULTI_on(gv);
6154     if ((cv = GvFORM(gv))) {
6155         if (ckWARN(WARN_REDEFINE)) {
6156             const line_t oldline = CopLINE(PL_curcop);
6157             if (PL_parser && PL_parser->copline != NOLINE)
6158                 CopLINE_set(PL_curcop, PL_parser->copline);
6159             if (o) {
6160                 Perl_warner(aTHX_ packWARN(WARN_REDEFINE),
6161                             "Format %"SVf" redefined", SVfARG(cSVOPo->op_sv));
6162             } else {
6163                 Perl_warner(aTHX_ packWARN(WARN_REDEFINE),
6164                             "Format STDOUT redefined");
6165             }
6166             CopLINE_set(PL_curcop, oldline);
6167         }
6168         SvREFCNT_dec(cv);
6169     }
6170     cv = PL_compcv;
6171     GvFORM(gv) = cv;
6172     CvGV(cv) = gv;
6173     CvFILE_set_from_cop(cv, PL_curcop);
6174
6175
6176     pad_tidy(padtidy_FORMAT);
6177     CvROOT(cv) = newUNOP(OP_LEAVEWRITE, 0, scalarseq(block));
6178     CvROOT(cv)->op_private |= OPpREFCOUNTED;
6179     OpREFCNT_set(CvROOT(cv), 1);
6180     CvSTART(cv) = LINKLIST(CvROOT(cv));
6181     CvROOT(cv)->op_next = 0;
6182     CALL_PEEP(CvSTART(cv));
6183 #ifdef PERL_MAD
6184     op_getmad(o,pegop,'n');
6185     op_getmad_weak(block, pegop, 'b');
6186 #else
6187     op_free(o);
6188 #endif
6189     if (PL_parser)
6190         PL_parser->copline = NOLINE;
6191     LEAVE_SCOPE(floor);
6192 #ifdef PERL_MAD
6193     return pegop;
6194 #endif
6195 }
6196
6197 OP *
6198 Perl_newANONLIST(pTHX_ OP *o)
6199 {
6200     return convert(OP_ANONLIST, OPf_SPECIAL, o);
6201 }
6202
6203 OP *
6204 Perl_newANONHASH(pTHX_ OP *o)
6205 {
6206     return convert(OP_ANONHASH, OPf_SPECIAL, o);
6207 }
6208
6209 OP *
6210 Perl_newANONSUB(pTHX_ I32 floor, OP *proto, OP *block)
6211 {
6212     return newANONATTRSUB(floor, proto, NULL, block);
6213 }
6214
6215 OP *
6216 Perl_newANONATTRSUB(pTHX_ I32 floor, OP *proto, OP *attrs, OP *block)
6217 {
6218     return newUNOP(OP_REFGEN, 0,
6219         newSVOP(OP_ANONCODE, 0,
6220                 MUTABLE_SV(newATTRSUB(floor, 0, proto, attrs, block))));
6221 }
6222
6223 OP *
6224 Perl_oopsAV(pTHX_ OP *o)
6225 {
6226     dVAR;
6227
6228     PERL_ARGS_ASSERT_OOPSAV;
6229
6230     switch (o->op_type) {
6231     case OP_PADSV:
6232         o->op_type = OP_PADAV;
6233         o->op_ppaddr = PL_ppaddr[OP_PADAV];
6234         return ref(o, OP_RV2AV);
6235
6236     case OP_RV2SV:
6237         o->op_type = OP_RV2AV;
6238         o->op_ppaddr = PL_ppaddr[OP_RV2AV];
6239         ref(o, OP_RV2AV);
6240         break;
6241
6242     default:
6243         if (ckWARN_d(WARN_INTERNAL))
6244             Perl_warner(aTHX_ packWARN(WARN_INTERNAL), "oops: oopsAV");
6245         break;
6246     }
6247     return o;
6248 }
6249
6250 OP *
6251 Perl_oopsHV(pTHX_ OP *o)
6252 {
6253     dVAR;
6254
6255     PERL_ARGS_ASSERT_OOPSHV;
6256
6257     switch (o->op_type) {
6258     case OP_PADSV:
6259     case OP_PADAV:
6260         o->op_type = OP_PADHV;
6261         o->op_ppaddr = PL_ppaddr[OP_PADHV];
6262         return ref(o, OP_RV2HV);
6263
6264     case OP_RV2SV:
6265     case OP_RV2AV:
6266         o->op_type = OP_RV2HV;
6267         o->op_ppaddr = PL_ppaddr[OP_RV2HV];
6268         ref(o, OP_RV2HV);
6269         break;
6270
6271     default:
6272         if (ckWARN_d(WARN_INTERNAL))
6273             Perl_warner(aTHX_ packWARN(WARN_INTERNAL), "oops: oopsHV");
6274         break;
6275     }
6276     return o;
6277 }
6278
6279 OP *
6280 Perl_newAVREF(pTHX_ OP *o)
6281 {
6282     dVAR;
6283
6284     PERL_ARGS_ASSERT_NEWAVREF;
6285
6286     if (o->op_type == OP_PADANY) {
6287         o->op_type = OP_PADAV;
6288         o->op_ppaddr = PL_ppaddr[OP_PADAV];
6289         return o;
6290     }
6291     else if ((o->op_type == OP_RV2AV || o->op_type == OP_PADAV)
6292                 && ckWARN(WARN_DEPRECATED)) {
6293         Perl_warner(aTHX_ packWARN(WARN_DEPRECATED),
6294                 "Using an array as a reference is deprecated");
6295     }
6296     return newUNOP(OP_RV2AV, 0, scalar(o));
6297 }
6298
6299 OP *
6300 Perl_newGVREF(pTHX_ I32 type, OP *o)
6301 {
6302     if (type == OP_MAPSTART || type == OP_GREPSTART || type == OP_SORT)
6303         return newUNOP(OP_NULL, 0, o);
6304     return ref(newUNOP(OP_RV2GV, OPf_REF, o), type);
6305 }
6306
6307 OP *
6308 Perl_newHVREF(pTHX_ OP *o)
6309 {
6310     dVAR;
6311
6312     PERL_ARGS_ASSERT_NEWHVREF;
6313
6314     if (o->op_type == OP_PADANY) {
6315         o->op_type = OP_PADHV;
6316         o->op_ppaddr = PL_ppaddr[OP_PADHV];
6317         return o;
6318     }
6319     else if ((o->op_type == OP_RV2HV || o->op_type == OP_PADHV)
6320                 && ckWARN(WARN_DEPRECATED)) {
6321         Perl_warner(aTHX_ packWARN(WARN_DEPRECATED),
6322                 "Using a hash as a reference is deprecated");
6323     }
6324     return newUNOP(OP_RV2HV, 0, scalar(o));
6325 }
6326
6327 OP *
6328 Perl_newCVREF(pTHX_ I32 flags, OP *o)
6329 {
6330     return newUNOP(OP_RV2CV, flags, scalar(o));
6331 }
6332
6333 OP *
6334 Perl_newSVREF(pTHX_ OP *o)
6335 {
6336     dVAR;
6337
6338     PERL_ARGS_ASSERT_NEWSVREF;
6339
6340     if (o->op_type == OP_PADANY) {
6341         o->op_type = OP_PADSV;
6342         o->op_ppaddr = PL_ppaddr[OP_PADSV];
6343         return o;
6344     }
6345     return newUNOP(OP_RV2SV, 0, scalar(o));
6346 }
6347
6348 /* Check routines. See the comments at the top of this file for details
6349  * on when these are called */
6350
6351 OP *
6352 Perl_ck_anoncode(pTHX_ OP *o)
6353 {
6354     PERL_ARGS_ASSERT_CK_ANONCODE;
6355
6356     cSVOPo->op_targ = pad_add_anon(cSVOPo->op_sv, o->op_type);
6357     if (!PL_madskills)
6358         cSVOPo->op_sv = NULL;
6359     return o;
6360 }
6361
6362 OP *
6363 Perl_ck_bitop(pTHX_ OP *o)
6364 {
6365     dVAR;
6366
6367     PERL_ARGS_ASSERT_CK_BITOP;
6368
6369 #define OP_IS_NUMCOMPARE(op) \
6370         ((op) == OP_LT   || (op) == OP_I_LT || \
6371          (op) == OP_GT   || (op) == OP_I_GT || \
6372          (op) == OP_LE   || (op) == OP_I_LE || \
6373          (op) == OP_GE   || (op) == OP_I_GE || \
6374          (op) == OP_EQ   || (op) == OP_I_EQ || \
6375          (op) == OP_NE   || (op) == OP_I_NE || \
6376          (op) == OP_NCMP || (op) == OP_I_NCMP)
6377     o->op_private = (U8)(PL_hints & HINT_INTEGER);
6378     if (!(o->op_flags & OPf_STACKED) /* Not an assignment */
6379             && (o->op_type == OP_BIT_OR
6380              || o->op_type == OP_BIT_AND
6381              || o->op_type == OP_BIT_XOR))
6382     {
6383         const OP * const left = cBINOPo->op_first;
6384         const OP * const right = left->op_sibling;
6385         if ((OP_IS_NUMCOMPARE(left->op_type) &&
6386                 (left->op_flags & OPf_PARENS) == 0) ||
6387             (OP_IS_NUMCOMPARE(right->op_type) &&
6388                 (right->op_flags & OPf_PARENS) == 0))
6389             if (ckWARN(WARN_PRECEDENCE))
6390                 Perl_warner(aTHX_ packWARN(WARN_PRECEDENCE),
6391                         "Possible precedence problem on bitwise %c operator",
6392                         o->op_type == OP_BIT_OR ? '|'
6393                             : o->op_type == OP_BIT_AND ? '&' : '^'
6394                         );
6395     }
6396     return o;
6397 }
6398
6399 OP *
6400 Perl_ck_concat(pTHX_ OP *o)
6401 {
6402     const OP * const kid = cUNOPo->op_first;
6403
6404     PERL_ARGS_ASSERT_CK_CONCAT;
6405     PERL_UNUSED_CONTEXT;
6406
6407     if (kid->op_type == OP_CONCAT && !(kid->op_private & OPpTARGET_MY) &&
6408             !(kUNOP->op_first->op_flags & OPf_MOD))
6409         o->op_flags |= OPf_STACKED;
6410     return o;
6411 }
6412
6413 OP *
6414 Perl_ck_spair(pTHX_ OP *o)
6415 {
6416     dVAR;
6417
6418     PERL_ARGS_ASSERT_CK_SPAIR;
6419
6420     if (o->op_flags & OPf_KIDS) {
6421         OP* newop;
6422         OP* kid;
6423         const OPCODE type = o->op_type;
6424         o = modkids(ck_fun(o), type);
6425         kid = cUNOPo->op_first;
6426         newop = kUNOP->op_first->op_sibling;
6427         if (newop) {
6428             const OPCODE type = newop->op_type;
6429             if (newop->op_sibling || !(PL_opargs[type] & OA_RETSCALAR) ||
6430                     type == OP_PADAV || type == OP_PADHV ||
6431                     type == OP_RV2AV || type == OP_RV2HV)
6432                 return o;
6433         }
6434 #ifdef PERL_MAD
6435         op_getmad(kUNOP->op_first,newop,'K');
6436 #else
6437         op_free(kUNOP->op_first);
6438 #endif
6439         kUNOP->op_first = newop;
6440     }
6441     o->op_ppaddr = PL_ppaddr[++o->op_type];
6442     return ck_fun(o);
6443 }
6444
6445 OP *
6446 Perl_ck_delete(pTHX_ OP *o)
6447 {
6448     PERL_ARGS_ASSERT_CK_DELETE;
6449
6450     o = ck_fun(o);
6451     o->op_private = 0;
6452     if (o->op_flags & OPf_KIDS) {
6453         OP * const kid = cUNOPo->op_first;
6454         switch (kid->op_type) {
6455         case OP_ASLICE:
6456             o->op_flags |= OPf_SPECIAL;
6457             /* FALL THROUGH */
6458         case OP_HSLICE:
6459             o->op_private |= OPpSLICE;
6460             break;
6461         case OP_AELEM:
6462             o->op_flags |= OPf_SPECIAL;
6463             /* FALL THROUGH */
6464         case OP_HELEM:
6465             break;
6466         default:
6467             Perl_croak(aTHX_ "%s argument is not a HASH or ARRAY element or slice",
6468                   OP_DESC(o));
6469         }
6470         if (kid->op_private & OPpLVAL_INTRO)
6471             o->op_private |= OPpLVAL_INTRO;
6472         op_null(kid);
6473     }
6474     return o;
6475 }
6476
6477 OP *
6478 Perl_ck_die(pTHX_ OP *o)
6479 {
6480     PERL_ARGS_ASSERT_CK_DIE;
6481
6482 #ifdef VMS
6483     if (VMSISH_HUSHED) o->op_private |= OPpHUSH_VMSISH;
6484 #endif
6485     return ck_fun(o);
6486 }
6487
6488 OP *
6489 Perl_ck_eof(pTHX_ OP *o)
6490 {
6491     dVAR;
6492
6493     PERL_ARGS_ASSERT_CK_EOF;
6494
6495     if (o->op_flags & OPf_KIDS) {
6496         if (cLISTOPo->op_first->op_type == OP_STUB) {
6497             OP * const newop
6498                 = newUNOP(o->op_type, OPf_SPECIAL, newGVOP(OP_GV, 0, PL_argvgv));
6499 #ifdef PERL_MAD
6500             op_getmad(o,newop,'O');
6501 #else
6502             op_free(o);
6503 #endif
6504             o = newop;
6505         }
6506         return ck_fun(o);
6507     }
6508     return o;
6509 }
6510
6511 OP *
6512 Perl_ck_eval(pTHX_ OP *o)
6513 {
6514     dVAR;
6515
6516     PERL_ARGS_ASSERT_CK_EVAL;
6517
6518     PL_hints |= HINT_BLOCK_SCOPE;
6519     if (o->op_flags & OPf_KIDS) {
6520         SVOP * const kid = (SVOP*)cUNOPo->op_first;
6521
6522         if (!kid) {
6523             o->op_flags &= ~OPf_KIDS;
6524             op_null(o);
6525         }
6526         else if (kid->op_type == OP_LINESEQ || kid->op_type == OP_STUB) {
6527             LOGOP *enter;
6528 #ifdef PERL_MAD
6529             OP* const oldo = o;
6530 #endif
6531
6532             cUNOPo->op_first = 0;
6533 #ifndef PERL_MAD
6534             op_free(o);
6535 #endif
6536
6537             NewOp(1101, enter, 1, LOGOP);
6538             enter->op_type = OP_ENTERTRY;
6539             enter->op_ppaddr = PL_ppaddr[OP_ENTERTRY];
6540             enter->op_private = 0;
6541
6542             /* establish postfix order */
6543             enter->op_next = (OP*)enter;
6544
6545             CHECKOP(OP_ENTERTRY, enter);
6546
6547             o = prepend_elem(OP_LINESEQ, (OP*)enter, (OP*)kid);
6548             o->op_type = OP_LEAVETRY;
6549             o->op_ppaddr = PL_ppaddr[OP_LEAVETRY];
6550             enter->op_other = o;
6551             op_getmad(oldo,o,'O');
6552             return o;
6553         }
6554         else {
6555             scalar((OP*)kid);
6556             PL_cv_has_eval = 1;
6557         }
6558     }
6559     else {
6560 #ifdef PERL_MAD
6561         OP* const oldo = o;
6562 #else
6563         op_free(o);
6564 #endif
6565         o = newUNOP(OP_ENTEREVAL, 0, newDEFSVOP());
6566         op_getmad(oldo,o,'O');
6567     }
6568     o->op_targ = (PADOFFSET)PL_hints;
6569     if ((PL_hints & HINT_LOCALIZE_HH) != 0 && GvHV(PL_hintgv)) {
6570         /* Store a copy of %^H that pp_entereval can pick up. */
6571         OP *hhop = newSVOP(OP_HINTSEVAL, 0,
6572                            MUTABLE_SV(Perl_hv_copy_hints_hv(aTHX_ GvHV(PL_hintgv))));
6573         cUNOPo->op_first->op_sibling = hhop;
6574         o->op_private |= OPpEVAL_HAS_HH;
6575     }
6576     return o;
6577 }
6578
6579 OP *
6580 Perl_ck_exit(pTHX_ OP *o)
6581 {
6582     PERL_ARGS_ASSERT_CK_EXIT;
6583
6584 #ifdef VMS
6585     HV * const table = GvHV(PL_hintgv);
6586     if (table) {
6587        SV * const * const svp = hv_fetchs(table, "vmsish_exit", FALSE);
6588        if (svp && *svp && SvTRUE(*svp))
6589            o->op_private |= OPpEXIT_VMSISH;
6590     }
6591     if (VMSISH_HUSHED) o->op_private |= OPpHUSH_VMSISH;
6592 #endif
6593     return ck_fun(o);
6594 }
6595
6596 OP *
6597 Perl_ck_exec(pTHX_ OP *o)
6598 {
6599     PERL_ARGS_ASSERT_CK_EXEC;
6600
6601     if (o->op_flags & OPf_STACKED) {
6602         OP *kid;
6603         o = ck_fun(o);
6604         kid = cUNOPo->op_first->op_sibling;
6605         if (kid->op_type == OP_RV2GV)
6606             op_null(kid);
6607     }
6608     else
6609         o = listkids(o);
6610     return o;
6611 }
6612
6613 OP *
6614 Perl_ck_exists(pTHX_ OP *o)
6615 {
6616     dVAR;
6617
6618     PERL_ARGS_ASSERT_CK_EXISTS;
6619
6620     o = ck_fun(o);
6621     if (o->op_flags & OPf_KIDS) {
6622         OP * const kid = cUNOPo->op_first;
6623         if (kid->op_type == OP_ENTERSUB) {
6624             (void) ref(kid, o->op_type);
6625             if (kid->op_type != OP_RV2CV
6626                         && !(PL_parser && PL_parser->error_count))
6627                 Perl_croak(aTHX_ "%s argument is not a subroutine name",
6628                             OP_DESC(o));
6629             o->op_private |= OPpEXISTS_SUB;
6630         }
6631         else if (kid->op_type == OP_AELEM)
6632             o->op_flags |= OPf_SPECIAL;
6633         else if (kid->op_type != OP_HELEM)
6634             Perl_croak(aTHX_ "%s argument is not a HASH or ARRAY element or a subroutine",
6635                         OP_DESC(o));
6636         op_null(kid);
6637     }
6638     return o;
6639 }
6640
6641 OP *
6642 Perl_ck_rvconst(pTHX_ register OP *o)
6643 {
6644     dVAR;
6645     SVOP * const kid = (SVOP*)cUNOPo->op_first;
6646
6647     PERL_ARGS_ASSERT_CK_RVCONST;
6648
6649     o->op_private |= (PL_hints & HINT_STRICT_REFS);
6650     if (o->op_type == OP_RV2CV)
6651         o->op_private &= ~1;
6652
6653     if (kid->op_type == OP_CONST) {
6654         int iscv;
6655         GV *gv;
6656         SV * const kidsv = kid->op_sv;
6657
6658         /* Is it a constant from cv_const_sv()? */
6659         if (SvROK(kidsv) && SvREADONLY(kidsv)) {
6660             SV * const rsv = SvRV(kidsv);
6661             const svtype type = SvTYPE(rsv);
6662             const char *badtype = NULL;
6663
6664             switch (o->op_type) {
6665             case OP_RV2SV:
6666                 if (type > SVt_PVMG)
6667                     badtype = "a SCALAR";
6668                 break;
6669             case OP_RV2AV:
6670                 if (type != SVt_PVAV)
6671                     badtype = "an ARRAY";
6672                 break;
6673             case OP_RV2HV:
6674                 if (type != SVt_PVHV)
6675                     badtype = "a HASH";
6676                 break;
6677             case OP_RV2CV:
6678                 if (type != SVt_PVCV)
6679                     badtype = "a CODE";
6680                 break;
6681             }
6682             if (badtype)
6683                 Perl_croak(aTHX_ "Constant is not %s reference", badtype);
6684             return o;
6685         }
6686         else if ((o->op_type == OP_RV2HV || o->op_type == OP_RV2SV) &&
6687                 (PL_hints & HINT_STRICT_REFS) && SvPOK(kidsv)) {
6688             /* If this is an access to a stash, disable "strict refs", because
6689              * stashes aren't auto-vivified at compile-time (unless we store
6690              * symbols in them), and we don't want to produce a run-time
6691              * stricture error when auto-vivifying the stash. */
6692             const char *s = SvPV_nolen(kidsv);
6693             const STRLEN l = SvCUR(kidsv);
6694             if (l > 1 && s[l-1] == ':' && s[l-2] == ':')
6695                 o->op_private &= ~HINT_STRICT_REFS;
6696         }
6697         if ((o->op_private & HINT_STRICT_REFS) && (kid->op_private & OPpCONST_BARE)) {
6698             const char *badthing;
6699             switch (o->op_type) {
6700             case OP_RV2SV:
6701                 badthing = "a SCALAR";
6702                 break;
6703             case OP_RV2AV:
6704                 badthing = "an ARRAY";
6705                 break;
6706             case OP_RV2HV:
6707                 badthing = "a HASH";
6708                 break;
6709             default:
6710                 badthing = NULL;
6711                 break;
6712             }
6713             if (badthing)
6714                 Perl_croak(aTHX_
6715                            "Can't use bareword (\"%"SVf"\") as %s ref while \"strict refs\" in use",
6716                            SVfARG(kidsv), badthing);
6717         }
6718         /*
6719          * This is a little tricky.  We only want to add the symbol if we
6720          * didn't add it in the lexer.  Otherwise we get duplicate strict
6721          * warnings.  But if we didn't add it in the lexer, we must at
6722          * least pretend like we wanted to add it even if it existed before,
6723          * or we get possible typo warnings.  OPpCONST_ENTERED says
6724          * whether the lexer already added THIS instance of this symbol.
6725          */
6726         iscv = (o->op_type == OP_RV2CV) * 2;
6727         do {
6728             gv = gv_fetchsv(kidsv,
6729                 iscv | !(kid->op_private & OPpCONST_ENTERED),
6730                 iscv
6731                     ? SVt_PVCV
6732                     : o->op_type == OP_RV2SV
6733                         ? SVt_PV
6734                         : o->op_type == OP_RV2AV
6735                             ? SVt_PVAV
6736                             : o->op_type == OP_RV2HV
6737                                 ? SVt_PVHV
6738                                 : SVt_PVGV);
6739         } while (!gv && !(kid->op_private & OPpCONST_ENTERED) && !iscv++);
6740         if (gv) {
6741             kid->op_type = OP_GV;
6742             SvREFCNT_dec(kid->op_sv);
6743 #ifdef USE_ITHREADS
6744             /* XXX hack: dependence on sizeof(PADOP) <= sizeof(SVOP) */
6745             kPADOP->op_padix = pad_alloc(OP_GV, SVs_PADTMP);
6746             SvREFCNT_dec(PAD_SVl(kPADOP->op_padix));
6747             GvIN_PAD_on(gv);
6748             PAD_SETSV(kPADOP->op_padix, MUTABLE_SV(SvREFCNT_inc_simple_NN(gv)));
6749 #else
6750             kid->op_sv = SvREFCNT_inc_simple_NN(gv);
6751 #endif
6752             kid->op_private = 0;
6753             kid->op_ppaddr = PL_ppaddr[OP_GV];
6754         }
6755     }
6756     return o;
6757 }
6758
6759 OP *
6760 Perl_ck_ftst(pTHX_ OP *o)
6761 {
6762     dVAR;
6763     const I32 type = o->op_type;
6764
6765     PERL_ARGS_ASSERT_CK_FTST;
6766
6767     if (o->op_flags & OPf_REF) {
6768         NOOP;
6769     }
6770     else if (o->op_flags & OPf_KIDS && cUNOPo->op_first->op_type != OP_STUB) {
6771         SVOP * const kid = (SVOP*)cUNOPo->op_first;
6772         const OPCODE kidtype = kid->op_type;
6773
6774         if (kidtype == OP_CONST && (kid->op_private & OPpCONST_BARE)) {
6775             OP * const newop = newGVOP(type, OPf_REF,
6776                 gv_fetchsv(kid->op_sv, GV_ADD, SVt_PVIO));
6777 #ifdef PERL_MAD
6778             op_getmad(o,newop,'O');
6779 #else
6780             op_free(o);
6781 #endif
6782             return newop;
6783         }
6784         if ((PL_hints & HINT_FILETEST_ACCESS) && OP_IS_FILETEST_ACCESS(o->op_type))
6785             o->op_private |= OPpFT_ACCESS;
6786         if (PL_check[kidtype] == MEMBER_TO_FPTR(Perl_ck_ftst)
6787                 && kidtype != OP_STAT && kidtype != OP_LSTAT)
6788             o->op_private |= OPpFT_STACKED;
6789     }
6790     else {
6791 #ifdef PERL_MAD
6792         OP* const oldo = o;
6793 #else
6794         op_free(o);
6795 #endif
6796         if (type == OP_FTTTY)
6797             o = newGVOP(type, OPf_REF, PL_stdingv);
6798         else
6799             o = newUNOP(type, 0, newDEFSVOP());
6800         op_getmad(oldo,o,'O');
6801     }
6802     return o;
6803 }
6804
6805 OP *
6806 Perl_ck_fun(pTHX_ OP *o)
6807 {
6808     dVAR;
6809     const int type = o->op_type;
6810     register I32 oa = PL_opargs[type] >> OASHIFT;
6811
6812     PERL_ARGS_ASSERT_CK_FUN;
6813
6814     if (o->op_flags & OPf_STACKED) {
6815         if ((oa & OA_OPTIONAL) && (oa >> 4) && !((oa >> 4) & OA_OPTIONAL))
6816             oa &= ~OA_OPTIONAL;
6817         else
6818             return no_fh_allowed(o);
6819     }
6820
6821     if (o->op_flags & OPf_KIDS) {
6822         OP **tokid = &cLISTOPo->op_first;
6823         register OP *kid = cLISTOPo->op_first;
6824         OP *sibl;
6825         I32 numargs = 0;
6826
6827         if (kid->op_type == OP_PUSHMARK ||
6828             (kid->op_type == OP_NULL && kid->op_targ == OP_PUSHMARK))
6829         {
6830             tokid = &kid->op_sibling;
6831             kid = kid->op_sibling;
6832         }
6833         if (!kid && PL_opargs[type] & OA_DEFGV)
6834             *tokid = kid = newDEFSVOP();
6835
6836         while (oa && kid) {
6837             numargs++;
6838             sibl = kid->op_sibling;
6839 #ifdef PERL_MAD
6840             if (!sibl && kid->op_type == OP_STUB) {
6841                 numargs--;
6842                 break;
6843             }
6844 #endif
6845             switch (oa & 7) {
6846             case OA_SCALAR:
6847                 /* list seen where single (scalar) arg expected? */
6848                 if (numargs == 1 && !(oa >> 4)
6849                     && kid->op_type == OP_LIST && type != OP_SCALAR)
6850                 {
6851                     return too_many_arguments(o,PL_op_desc[type]);
6852                 }
6853                 scalar(kid);
6854                 break;
6855             case OA_LIST:
6856                 if (oa < 16) {
6857                     kid = 0;
6858                     continue;
6859                 }
6860                 else
6861                     list(kid);
6862                 break;
6863             case OA_AVREF:
6864                 if ((type == OP_PUSH || type == OP_UNSHIFT)
6865                     && !kid->op_sibling && ckWARN(WARN_SYNTAX))
6866                     Perl_warner(aTHX_ packWARN(WARN_SYNTAX),
6867                         "Useless use of %s with no values",
6868                         PL_op_desc[type]);
6869
6870                 if (kid->op_type == OP_CONST &&
6871                     (kid->op_private & OPpCONST_BARE))
6872                 {
6873                     OP * const newop = newAVREF(newGVOP(OP_GV, 0,
6874                         gv_fetchsv(((SVOP*)kid)->op_sv, GV_ADD, SVt_PVAV) ));
6875                     if (ckWARN2(WARN_DEPRECATED, WARN_SYNTAX))
6876                         Perl_warner(aTHX_ packWARN2(WARN_DEPRECATED, WARN_SYNTAX),
6877                             "Array @%"SVf" missing the @ in argument %"IVdf" of %s()",
6878                             SVfARG(((SVOP*)kid)->op_sv), (IV)numargs, PL_op_desc[type]);
6879 #ifdef PERL_MAD
6880                     op_getmad(kid,newop,'K');
6881 #else
6882                     op_free(kid);
6883 #endif
6884                     kid = newop;
6885                     kid->op_sibling = sibl;
6886                     *tokid = kid;
6887                 }
6888                 else if (kid->op_type != OP_RV2AV && kid->op_type != OP_PADAV)
6889                     bad_type(numargs, "array", PL_op_desc[type], kid);
6890                 mod(kid, type);
6891                 break;
6892             case OA_HVREF:
6893                 if (kid->op_type == OP_CONST &&
6894                     (kid->op_private & OPpCONST_BARE))
6895                 {
6896                     OP * const newop = newHVREF(newGVOP(OP_GV, 0,
6897                         gv_fetchsv(((SVOP*)kid)->op_sv, GV_ADD, SVt_PVHV) ));
6898                     if (ckWARN2(WARN_DEPRECATED, WARN_SYNTAX))
6899                         Perl_warner(aTHX_ packWARN2(WARN_DEPRECATED, WARN_SYNTAX),
6900                             "Hash %%%"SVf" missing the %% in argument %"IVdf" of %s()",
6901                             SVfARG(((SVOP*)kid)->op_sv), (IV)numargs, PL_op_desc[type]);
6902 #ifdef PERL_MAD
6903                     op_getmad(kid,newop,'K');
6904 #else
6905                     op_free(kid);
6906 #endif
6907                     kid = newop;
6908                     kid->op_sibling = sibl;
6909                     *tokid = kid;
6910                 }
6911                 else if (kid->op_type != OP_RV2HV && kid->op_type != OP_PADHV)
6912                     bad_type(numargs, "hash", PL_op_desc[type], kid);
6913                 mod(kid, type);
6914                 break;
6915             case OA_CVREF:
6916                 {
6917                     OP * const newop = newUNOP(OP_NULL, 0, kid);
6918                     kid->op_sibling = 0;
6919                     linklist(kid);
6920                     newop->op_next = newop;
6921                     kid = newop;
6922                     kid->op_sibling = sibl;
6923                     *tokid = kid;
6924                 }
6925                 break;
6926             case OA_FILEREF:
6927                 if (kid->op_type != OP_GV && kid->op_type != OP_RV2GV) {
6928                     if (kid->op_type == OP_CONST &&
6929                         (kid->op_private & OPpCONST_BARE))
6930                     {
6931                         OP * const newop = newGVOP(OP_GV, 0,
6932                             gv_fetchsv(((SVOP*)kid)->op_sv, GV_ADD, SVt_PVIO));
6933                         if (!(o->op_private & 1) && /* if not unop */
6934                             kid == cLISTOPo->op_last)
6935                             cLISTOPo->op_last = newop;
6936 #ifdef PERL_MAD
6937                         op_getmad(kid,newop,'K');
6938 #else
6939                         op_free(kid);
6940 #endif
6941                         kid = newop;
6942                     }
6943                     else if (kid->op_type == OP_READLINE) {
6944                         /* neophyte patrol: open(<FH>), close(<FH>) etc. */
6945                         bad_type(numargs, "HANDLE", OP_DESC(o), kid);
6946                     }
6947                     else {
6948                         I32 flags = OPf_SPECIAL;
6949                         I32 priv = 0;
6950                         PADOFFSET targ = 0;
6951
6952                         /* is this op a FH constructor? */
6953                         if (is_handle_constructor(o,numargs)) {
6954                             const char *name = NULL;
6955                             STRLEN len = 0;
6956
6957                             flags = 0;
6958                             /* Set a flag to tell rv2gv to vivify
6959                              * need to "prove" flag does not mean something
6960                              * else already - NI-S 1999/05/07
6961                              */
6962                             priv = OPpDEREF;
6963                             if (kid->op_type == OP_PADSV) {
6964                                 SV *const namesv
6965                                     = PAD_COMPNAME_SV(kid->op_targ);
6966                                 name = SvPV_const(namesv, len);
6967                             }
6968                             else if (kid->op_type == OP_RV2SV
6969                                      && kUNOP->op_first->op_type == OP_GV)
6970                             {
6971                                 GV * const gv = cGVOPx_gv(kUNOP->op_first);
6972                                 name = GvNAME(gv);
6973                                 len = GvNAMELEN(gv);
6974                             }
6975                             else if (kid->op_type == OP_AELEM
6976                                      || kid->op_type == OP_HELEM)
6977                             {
6978                                  OP *firstop;
6979                                  OP *op = ((BINOP*)kid)->op_first;
6980                                  name = NULL;
6981                                  if (op) {
6982                                       SV *tmpstr = NULL;
6983                                       const char * const a =
6984                                            kid->op_type == OP_AELEM ?
6985                                            "[]" : "{}";
6986                                       if (((op->op_type == OP_RV2AV) ||
6987                                            (op->op_type == OP_RV2HV)) &&
6988                                           (firstop = ((UNOP*)op)->op_first) &&
6989                                           (firstop->op_type == OP_GV)) {
6990                                            /* packagevar $a[] or $h{} */
6991                                            GV * const gv = cGVOPx_gv(firstop);
6992                                            if (gv)
6993                                                 tmpstr =
6994                                                      Perl_newSVpvf(aTHX_
6995                                                                    "%s%c...%c",
6996                                                                    GvNAME(gv),
6997                                                                    a[0], a[1]);
6998                                       }
6999                                       else if (op->op_type == OP_PADAV
7000                                                || op->op_type == OP_PADHV) {
7001                                            /* lexicalvar $a[] or $h{} */
7002                                            const char * const padname =
7003                                                 PAD_COMPNAME_PV(op->op_targ);
7004                                            if (padname)
7005                                                 tmpstr =
7006                                                      Perl_newSVpvf(aTHX_
7007                                                                    "%s%c...%c",
7008                                                                    padname + 1,
7009                                                                    a[0], a[1]);
7010                                       }
7011                                       if (tmpstr) {
7012                                            name = SvPV_const(tmpstr, len);
7013                                            sv_2mortal(tmpstr);
7014                                       }
7015                                  }
7016                                  if (!name) {
7017                                       name = "__ANONIO__";
7018                                       len = 10;
7019                                  }
7020                                  mod(kid, type);
7021                             }
7022                             if (name) {
7023                                 SV *namesv;
7024                                 targ = pad_alloc(OP_RV2GV, SVs_PADTMP);
7025                                 namesv = PAD_SVl(targ);
7026                                 SvUPGRADE(namesv, SVt_PV);
7027                                 if (*name != '$')
7028                                     sv_setpvs(namesv, "$");
7029                                 sv_catpvn(namesv, name, len);
7030                             }
7031                         }
7032                         kid->op_sibling = 0;
7033                         kid = newUNOP(OP_RV2GV, flags, scalar(kid));
7034                         kid->op_targ = targ;
7035                         kid->op_private |= priv;
7036                     }
7037                     kid->op_sibling = sibl;
7038                     *tokid = kid;
7039                 }
7040                 scalar(kid);
7041                 break;
7042             case OA_SCALARREF:
7043                 mod(scalar(kid), type);
7044                 break;
7045             }
7046             oa >>= 4;
7047             tokid = &kid->op_sibling;
7048             kid = kid->op_sibling;
7049         }
7050 #ifdef PERL_MAD
7051         if (kid && kid->op_type != OP_STUB)
7052             return too_many_arguments(o,OP_DESC(o));
7053         o->op_private |= numargs;
7054 #else
7055         /* FIXME - should the numargs move as for the PERL_MAD case?  */
7056         o->op_private |= numargs;
7057         if (kid)
7058             return too_many_arguments(o,OP_DESC(o));
7059 #endif
7060         listkids(o);
7061     }
7062     else if (PL_opargs[type] & OA_DEFGV) {
7063 #ifdef PERL_MAD
7064         OP *newop = newUNOP(type, 0, newDEFSVOP());
7065         op_getmad(o,newop,'O');
7066         return newop;
7067 #else
7068         /* Ordering of these two is important to keep f_map.t passing.  */
7069         op_free(o);
7070         return newUNOP(type, 0, newDEFSVOP());
7071 #endif
7072     }
7073
7074     if (oa) {
7075         while (oa & OA_OPTIONAL)
7076             oa >>= 4;
7077         if (oa && oa != OA_LIST)
7078             return too_few_arguments(o,OP_DESC(o));
7079     }
7080     return o;
7081 }
7082
7083 OP *
7084 Perl_ck_glob(pTHX_ OP *o)
7085 {
7086     dVAR;
7087     GV *gv;
7088
7089     PERL_ARGS_ASSERT_CK_GLOB;
7090
7091     o = ck_fun(o);
7092     if ((o->op_flags & OPf_KIDS) && !cLISTOPo->op_first->op_sibling)
7093         append_elem(OP_GLOB, o, newDEFSVOP());
7094
7095     if (!((gv = gv_fetchpvs("glob", GV_NOTQUAL, SVt_PVCV))
7096           && GvCVu(gv) && GvIMPORTED_CV(gv)))
7097     {
7098         gv = gv_fetchpvs("CORE::GLOBAL::glob", 0, SVt_PVCV);
7099     }
7100
7101 #if !defined(PERL_EXTERNAL_GLOB)
7102     /* XXX this can be tightened up and made more failsafe. */
7103     if (!(gv && GvCVu(gv) && GvIMPORTED_CV(gv))) {
7104         GV *glob_gv;
7105         ENTER;
7106         Perl_load_module(aTHX_ PERL_LOADMOD_NOIMPORT,
7107                 newSVpvs("File::Glob"), NULL, NULL, NULL);
7108         gv = gv_fetchpvs("CORE::GLOBAL::glob", 0, SVt_PVCV);
7109         glob_gv = gv_fetchpvs("File::Glob::csh_glob", 0, SVt_PVCV);
7110         GvCV(gv) = GvCV(glob_gv);
7111         SvREFCNT_inc_void(MUTABLE_SV(GvCV(gv)));
7112         GvIMPORTED_CV_on(gv);
7113         LEAVE;
7114     }
7115 #endif /* PERL_EXTERNAL_GLOB */
7116
7117     if (gv && GvCVu(gv) && GvIMPORTED_CV(gv)) {
7118         append_elem(OP_GLOB, o,
7119                     newSVOP(OP_CONST, 0, newSViv(PL_glob_index++)));
7120         o->op_type = OP_LIST;
7121         o->op_ppaddr = PL_ppaddr[OP_LIST];
7122         cLISTOPo->op_first->op_type = OP_PUSHMARK;
7123         cLISTOPo->op_first->op_ppaddr = PL_ppaddr[OP_PUSHMARK];
7124         cLISTOPo->op_first->op_targ = 0;
7125         o = newUNOP(OP_ENTERSUB, OPf_STACKED,
7126                     append_elem(OP_LIST, o,
7127                                 scalar(newUNOP(OP_RV2CV, 0,
7128                                                newGVOP(OP_GV, 0, gv)))));
7129         o = newUNOP(OP_NULL, 0, ck_subr(o));
7130         o->op_targ = OP_GLOB;           /* hint at what it used to be */
7131         return o;
7132     }
7133     gv = newGVgen("main");
7134     gv_IOadd(gv);
7135     append_elem(OP_GLOB, o, newGVOP(OP_GV, 0, gv));
7136     scalarkids(o);
7137     return o;
7138 }
7139
7140 OP *
7141 Perl_ck_grep(pTHX_ OP *o)
7142 {
7143     dVAR;
7144     LOGOP *gwop = NULL;
7145     OP *kid;
7146     const OPCODE type = o->op_type == OP_GREPSTART ? OP_GREPWHILE : OP_MAPWHILE;
7147     PADOFFSET offset;
7148
7149     PERL_ARGS_ASSERT_CK_GREP;
7150
7151     o->op_ppaddr = PL_ppaddr[OP_GREPSTART];
7152     /* don't allocate gwop here, as we may leak it if PL_parser->error_count > 0 */
7153
7154     if (o->op_flags & OPf_STACKED) {
7155         OP* k;
7156         o = ck_sort(o);
7157         kid = cLISTOPo->op_first->op_sibling;
7158         if (!cUNOPx(kid)->op_next)
7159             Perl_croak(aTHX_ "panic: ck_grep");
7160         for (k = cUNOPx(kid)->op_first; k; k = k->op_next) {
7161             kid = k;
7162         }
7163         NewOp(1101, gwop, 1, LOGOP);
7164         kid->op_next = (OP*)gwop;
7165         o->op_flags &= ~OPf_STACKED;
7166     }
7167     kid = cLISTOPo->op_first->op_sibling;
7168     if (type == OP_MAPWHILE)
7169         list(kid);
7170     else
7171         scalar(kid);
7172     o = ck_fun(o);
7173     if (PL_parser && PL_parser->error_count)
7174         return o;
7175     kid = cLISTOPo->op_first->op_sibling;
7176     if (kid->op_type != OP_NULL)
7177         Perl_croak(aTHX_ "panic: ck_grep");
7178     kid = kUNOP->op_first;
7179
7180     if (!gwop)
7181         NewOp(1101, gwop, 1, LOGOP);
7182     gwop->op_type = type;
7183     gwop->op_ppaddr = PL_ppaddr[type];
7184     gwop->op_first = listkids(o);
7185     gwop->op_flags |= OPf_KIDS;
7186     gwop->op_other = LINKLIST(kid);
7187     kid->op_next = (OP*)gwop;
7188     offset = pad_findmy("$_");
7189     if (offset == NOT_IN_PAD || PAD_COMPNAME_FLAGS_isOUR(offset)) {
7190         o->op_private = gwop->op_private = 0;
7191         gwop->op_targ = pad_alloc(type, SVs_PADTMP);
7192     }
7193     else {
7194         o->op_private = gwop->op_private = OPpGREP_LEX;
7195         gwop->op_targ = o->op_targ = offset;
7196     }
7197
7198     kid = cLISTOPo->op_first->op_sibling;
7199     if (!kid || !kid->op_sibling)
7200         return too_few_arguments(o,OP_DESC(o));
7201     for (kid = kid->op_sibling; kid; kid = kid->op_sibling)
7202         mod(kid, OP_GREPSTART);
7203
7204     return (OP*)gwop;
7205 }
7206
7207 OP *
7208 Perl_ck_index(pTHX_ OP *o)
7209 {
7210     PERL_ARGS_ASSERT_CK_INDEX;
7211
7212     if (o->op_flags & OPf_KIDS) {
7213         OP *kid = cLISTOPo->op_first->op_sibling;       /* get past pushmark */
7214         if (kid)
7215             kid = kid->op_sibling;                      /* get past "big" */
7216         if (kid && kid->op_type == OP_CONST)
7217             fbm_compile(((SVOP*)kid)->op_sv, 0);
7218     }
7219     return ck_fun(o);
7220 }
7221
7222 OP *
7223 Perl_ck_lfun(pTHX_ OP *o)
7224 {
7225     const OPCODE type = o->op_type;
7226
7227     PERL_ARGS_ASSERT_CK_LFUN;
7228
7229     return modkids(ck_fun(o), type);
7230 }
7231
7232 OP *
7233 Perl_ck_defined(pTHX_ OP *o)            /* 19990527 MJD */
7234 {
7235     PERL_ARGS_ASSERT_CK_DEFINED;
7236
7237     if ((o->op_flags & OPf_KIDS) && ckWARN2(WARN_DEPRECATED, WARN_SYNTAX)) {
7238         switch (cUNOPo->op_first->op_type) {
7239         case OP_RV2AV:
7240             /* This is needed for
7241                if (defined %stash::)
7242                to work.   Do not break Tk.
7243                */
7244             break;                      /* Globals via GV can be undef */
7245         case OP_PADAV:
7246         case OP_AASSIGN:                /* Is this a good idea? */
7247             Perl_warner(aTHX_ packWARN2(WARN_DEPRECATED, WARN_SYNTAX),
7248                         "defined(@array) is deprecated");
7249             Perl_warner(aTHX_ packWARN2(WARN_DEPRECATED, WARN_SYNTAX),
7250                         "\t(Maybe you should just omit the defined()?)\n");
7251         break;
7252         case OP_RV2HV:
7253             /* This is needed for
7254                if (defined %stash::)
7255                to work.   Do not break Tk.
7256                */
7257             break;                      /* Globals via GV can be undef */
7258         case OP_PADHV:
7259             Perl_warner(aTHX_ packWARN2(WARN_DEPRECATED, WARN_SYNTAX),
7260                         "defined(%%hash) is deprecated");
7261             Perl_warner(aTHX_ packWARN2(WARN_DEPRECATED, WARN_SYNTAX),
7262                         "\t(Maybe you should just omit the defined()?)\n");
7263             break;
7264         default:
7265             /* no warning */
7266             break;
7267         }
7268     }
7269     return ck_rfun(o);
7270 }
7271
7272 OP *
7273 Perl_ck_readline(pTHX_ OP *o)
7274 {
7275     PERL_ARGS_ASSERT_CK_READLINE;
7276
7277     if (!(o->op_flags & OPf_KIDS)) {
7278         OP * const newop
7279             = newUNOP(OP_READLINE, 0, newGVOP(OP_GV, 0, PL_argvgv));
7280 #ifdef PERL_MAD
7281         op_getmad(o,newop,'O');
7282 #else
7283         op_free(o);
7284 #endif
7285         return newop;
7286     }
7287     return o;
7288 }
7289
7290 OP *
7291 Perl_ck_rfun(pTHX_ OP *o)
7292 {
7293     const OPCODE type = o->op_type;
7294
7295     PERL_ARGS_ASSERT_CK_RFUN;
7296
7297     return refkids(ck_fun(o), type);
7298 }
7299
7300 OP *
7301 Perl_ck_listiob(pTHX_ OP *o)
7302 {
7303     register OP *kid;
7304
7305     PERL_ARGS_ASSERT_CK_LISTIOB;
7306
7307     kid = cLISTOPo->op_first;
7308     if (!kid) {
7309         o = force_list(o);
7310         kid = cLISTOPo->op_first;
7311     }
7312     if (kid->op_type == OP_PUSHMARK)
7313         kid = kid->op_sibling;
7314     if (kid && o->op_flags & OPf_STACKED)
7315         kid = kid->op_sibling;
7316     else if (kid && !kid->op_sibling) {         /* print HANDLE; */
7317         if (kid->op_type == OP_CONST && kid->op_private & OPpCONST_BARE) {
7318             o->op_flags |= OPf_STACKED; /* make it a filehandle */
7319             kid = newUNOP(OP_RV2GV, OPf_REF, scalar(kid));
7320             cLISTOPo->op_first->op_sibling = kid;
7321             cLISTOPo->op_last = kid;
7322             kid = kid->op_sibling;
7323         }
7324     }
7325
7326     if (!kid)
7327         append_elem(o->op_type, o, newDEFSVOP());
7328
7329     return listkids(o);
7330 }
7331
7332 OP *
7333 Perl_ck_smartmatch(pTHX_ OP *o)
7334 {
7335     dVAR;
7336     if (0 == (o->op_flags & OPf_SPECIAL)) {
7337         OP *first  = cBINOPo->op_first;
7338         OP *second = first->op_sibling;
7339         
7340         /* Implicitly take a reference to an array or hash */
7341         first->op_sibling = NULL;
7342         first = cBINOPo->op_first = ref_array_or_hash(first);
7343         second = first->op_sibling = ref_array_or_hash(second);
7344         
7345         /* Implicitly take a reference to a regular expression */
7346         if (first->op_type == OP_MATCH) {
7347             first->op_type = OP_QR;
7348             first->op_ppaddr = PL_ppaddr[OP_QR];
7349         }
7350         if (second->op_type == OP_MATCH) {
7351             second->op_type = OP_QR;
7352             second->op_ppaddr = PL_ppaddr[OP_QR];
7353         }
7354     }
7355     
7356     return o;
7357 }
7358
7359
7360 OP *
7361 Perl_ck_sassign(pTHX_ OP *o)
7362 {
7363     dVAR;
7364     OP * const kid = cLISTOPo->op_first;
7365
7366     PERL_ARGS_ASSERT_CK_SASSIGN;
7367
7368     /* has a disposable target? */
7369     if ((PL_opargs[kid->op_type] & OA_TARGLEX)
7370         && !(kid->op_flags & OPf_STACKED)
7371         /* Cannot steal the second time! */
7372         && !(kid->op_private & OPpTARGET_MY)
7373         /* Keep the full thing for madskills */
7374         && !PL_madskills
7375         )
7376     {
7377         OP * const kkid = kid->op_sibling;
7378
7379         /* Can just relocate the target. */
7380         if (kkid && kkid->op_type == OP_PADSV
7381             && !(kkid->op_private & OPpLVAL_INTRO))
7382         {
7383             kid->op_targ = kkid->op_targ;
7384             kkid->op_targ = 0;
7385             /* Now we do not need PADSV and SASSIGN. */
7386             kid->op_sibling = o->op_sibling;    /* NULL */
7387             cLISTOPo->op_first = NULL;
7388             op_free(o);
7389             op_free(kkid);
7390             kid->op_private |= OPpTARGET_MY;    /* Used for context settings */
7391             return kid;
7392         }
7393     }
7394     if (kid->op_sibling) {
7395         OP *kkid = kid->op_sibling;
7396         if (kkid->op_type == OP_PADSV
7397                 && (kkid->op_private & OPpLVAL_INTRO)
7398                 && SvPAD_STATE(*av_fetch(PL_comppad_name, kkid->op_targ, FALSE))) {
7399             const PADOFFSET target = kkid->op_targ;
7400             OP *const other = newOP(OP_PADSV,
7401                                     kkid->op_flags
7402                                     | ((kkid->op_private & ~OPpLVAL_INTRO) << 8));
7403             OP *const first = newOP(OP_NULL, 0);
7404             OP *const nullop = newCONDOP(0, first, o, other);
7405             OP *const condop = first->op_next;
7406             /* hijacking PADSTALE for uninitialized state variables */
7407             SvPADSTALE_on(PAD_SVl(target));
7408
7409             condop->op_type = OP_ONCE;
7410             condop->op_ppaddr = PL_ppaddr[OP_ONCE];
7411             condop->op_targ = target;
7412             other->op_targ = target;
7413
7414             /* Because we change the type of the op here, we will skip the
7415                assinment binop->op_last = binop->op_first->op_sibling; at the
7416                end of Perl_newBINOP(). So need to do it here. */
7417             cBINOPo->op_last = cBINOPo->op_first->op_sibling;
7418
7419             return nullop;
7420         }
7421     }
7422     return o;
7423 }
7424
7425 OP *
7426 Perl_ck_match(pTHX_ OP *o)
7427 {
7428     dVAR;
7429
7430     PERL_ARGS_ASSERT_CK_MATCH;
7431
7432     if (o->op_type != OP_QR && PL_compcv) {
7433         const PADOFFSET offset = pad_findmy("$_");
7434         if (offset != NOT_IN_PAD && !(PAD_COMPNAME_FLAGS_isOUR(offset))) {
7435             o->op_targ = offset;
7436             o->op_private |= OPpTARGET_MY;
7437         }
7438     }
7439     if (o->op_type == OP_MATCH || o->op_type == OP_QR)
7440         o->op_private |= OPpRUNTIME;
7441     return o;
7442 }
7443
7444 OP *
7445 Perl_ck_method(pTHX_ OP *o)
7446 {
7447     OP * const kid = cUNOPo->op_first;
7448
7449     PERL_ARGS_ASSERT_CK_METHOD;
7450
7451     if (kid->op_type == OP_CONST) {
7452         SV* sv = kSVOP->op_sv;
7453         const char * const method = SvPVX_const(sv);
7454         if (!(strchr(method, ':') || strchr(method, '\''))) {
7455             OP *cmop;
7456             if (!SvREADONLY(sv) || !SvFAKE(sv)) {
7457                 sv = newSVpvn_share(method, SvCUR(sv), 0);
7458             }
7459             else {
7460                 kSVOP->op_sv = NULL;
7461             }
7462             cmop = newSVOP(OP_METHOD_NAMED, 0, sv);
7463 #ifdef PERL_MAD
7464             op_getmad(o,cmop,'O');
7465 #else
7466             op_free(o);
7467 #endif
7468             return cmop;
7469         }
7470     }
7471     return o;
7472 }
7473
7474 OP *
7475 Perl_ck_null(pTHX_ OP *o)
7476 {
7477     PERL_ARGS_ASSERT_CK_NULL;
7478     PERL_UNUSED_CONTEXT;
7479     return o;
7480 }
7481
7482 OP *
7483 Perl_ck_open(pTHX_ OP *o)
7484 {
7485     dVAR;
7486     HV * const table = GvHV(PL_hintgv);
7487
7488     PERL_ARGS_ASSERT_CK_OPEN;
7489
7490     if (table) {
7491         SV **svp = hv_fetchs(table, "open_IN", FALSE);
7492         if (svp && *svp) {
7493             STRLEN len = 0;
7494             const char *d = SvPV_const(*svp, len);
7495             const I32 mode = mode_from_discipline(d, len);
7496             if (mode & O_BINARY)
7497                 o->op_private |= OPpOPEN_IN_RAW;
7498             else if (mode & O_TEXT)
7499                 o->op_private |= OPpOPEN_IN_CRLF;
7500         }
7501
7502         svp = hv_fetchs(table, "open_OUT", FALSE);
7503         if (svp && *svp) {
7504             STRLEN len = 0;
7505             const char *d = SvPV_const(*svp, len);
7506             const I32 mode = mode_from_discipline(d, len);
7507             if (mode & O_BINARY)
7508                 o->op_private |= OPpOPEN_OUT_RAW;
7509             else if (mode & O_TEXT)
7510                 o->op_private |= OPpOPEN_OUT_CRLF;
7511         }
7512     }
7513     if (o->op_type == OP_BACKTICK) {
7514         if (!(o->op_flags & OPf_KIDS)) {
7515             OP * const newop = newUNOP(OP_BACKTICK, 0, newDEFSVOP());
7516 #ifdef PERL_MAD
7517             op_getmad(o,newop,'O');
7518 #else
7519             op_free(o);
7520 #endif
7521             return newop;
7522         }
7523         return o;
7524     }
7525     {
7526          /* In case of three-arg dup open remove strictness
7527           * from the last arg if it is a bareword. */
7528          OP * const first = cLISTOPx(o)->op_first; /* The pushmark. */
7529          OP * const last  = cLISTOPx(o)->op_last;  /* The bareword. */
7530          OP *oa;
7531          const char *mode;
7532
7533          if ((last->op_type == OP_CONST) &&             /* The bareword. */
7534              (last->op_private & OPpCONST_BARE) &&
7535              (last->op_private & OPpCONST_STRICT) &&
7536              (oa = first->op_sibling) &&                /* The fh. */
7537              (oa = oa->op_sibling) &&                   /* The mode. */
7538              (oa->op_type == OP_CONST) &&
7539              SvPOK(((SVOP*)oa)->op_sv) &&
7540              (mode = SvPVX_const(((SVOP*)oa)->op_sv)) &&
7541              mode[0] == '>' && mode[1] == '&' &&        /* A dup open. */
7542              (last == oa->op_sibling))                  /* The bareword. */
7543               last->op_private &= ~OPpCONST_STRICT;
7544     }
7545     return ck_fun(o);
7546 }
7547
7548 OP *
7549 Perl_ck_repeat(pTHX_ OP *o)
7550 {
7551     PERL_ARGS_ASSERT_CK_REPEAT;
7552
7553     if (cBINOPo->op_first->op_flags & OPf_PARENS) {
7554         o->op_private |= OPpREPEAT_DOLIST;
7555         cBINOPo->op_first = force_list(cBINOPo->op_first);
7556     }
7557     else
7558         scalar(o);
7559     return o;
7560 }
7561
7562 OP *
7563 Perl_ck_require(pTHX_ OP *o)
7564 {
7565     dVAR;
7566     GV* gv = NULL;
7567
7568     PERL_ARGS_ASSERT_CK_REQUIRE;
7569
7570     if (o->op_flags & OPf_KIDS) {       /* Shall we supply missing .pm? */
7571         SVOP * const kid = (SVOP*)cUNOPo->op_first;
7572
7573         if (kid->op_type == OP_CONST && (kid->op_private & OPpCONST_BARE)) {
7574             SV * const sv = kid->op_sv;
7575             U32 was_readonly = SvREADONLY(sv);
7576             char *s;
7577             STRLEN len;
7578             const char *end;
7579
7580             if (was_readonly) {
7581                 if (SvFAKE(sv)) {
7582                     sv_force_normal_flags(sv, 0);
7583                     assert(!SvREADONLY(sv));
7584                     was_readonly = 0;
7585                 } else {
7586                     SvREADONLY_off(sv);
7587                 }
7588             }   
7589
7590             s = SvPVX(sv);
7591             len = SvCUR(sv);
7592             end = s + len;
7593             for (; s < end; s++) {
7594                 if (*s == ':' && s[1] == ':') {
7595                     *s = '/';
7596                     Move(s+2, s+1, end - s - 1, char);
7597                     --end;
7598                 }
7599             }
7600             SvEND_set(sv, end);
7601             sv_catpvs(sv, ".pm");
7602             SvFLAGS(sv) |= was_readonly;
7603         }
7604     }
7605
7606     if (!(o->op_flags & OPf_SPECIAL)) { /* Wasn't written as CORE::require */
7607         /* handle override, if any */
7608         gv = gv_fetchpvs("require", GV_NOTQUAL, SVt_PVCV);
7609         if (!(gv && GvCVu(gv) && GvIMPORTED_CV(gv))) {
7610             GV * const * const gvp = (GV**)hv_fetchs(PL_globalstash, "require", FALSE);
7611             gv = gvp ? *gvp : NULL;
7612         }
7613     }
7614
7615     if (gv && GvCVu(gv) && GvIMPORTED_CV(gv)) {
7616         OP * const kid = cUNOPo->op_first;
7617         OP * newop;
7618
7619         cUNOPo->op_first = 0;
7620 #ifndef PERL_MAD
7621         op_free(o);
7622 #endif
7623         newop = ck_subr(newUNOP(OP_ENTERSUB, OPf_STACKED,
7624                                 append_elem(OP_LIST, kid,
7625                                             scalar(newUNOP(OP_RV2CV, 0,
7626                                                            newGVOP(OP_GV, 0,
7627                                                                    gv))))));
7628         op_getmad(o,newop,'O');
7629         return newop;
7630     }
7631
7632     return ck_fun(o);
7633 }
7634
7635 OP *
7636 Perl_ck_return(pTHX_ OP *o)
7637 {
7638     dVAR;
7639     OP *kid;
7640
7641     PERL_ARGS_ASSERT_CK_RETURN;
7642
7643     kid = cLISTOPo->op_first->op_sibling;
7644     if (CvLVALUE(PL_compcv)) {
7645         for (; kid; kid = kid->op_sibling)
7646             mod(kid, OP_LEAVESUBLV);
7647     } else {
7648         for (; kid; kid = kid->op_sibling)
7649             if ((kid->op_type == OP_NULL)
7650                 && ((kid->op_flags & (OPf_SPECIAL|OPf_KIDS)) == (OPf_SPECIAL|OPf_KIDS))) {
7651                 /* This is a do block */
7652                 OP *op = kUNOP->op_first;
7653                 if (op->op_type == OP_LEAVE && op->op_flags & OPf_KIDS) {
7654                     op = cUNOPx(op)->op_first;
7655                     assert(op->op_type == OP_ENTER && !(op->op_flags & OPf_SPECIAL));
7656                     /* Force the use of the caller's context */
7657                     op->op_flags |= OPf_SPECIAL;
7658                 }
7659             }
7660     }
7661
7662     return o;
7663 }
7664
7665 OP *
7666 Perl_ck_select(pTHX_ OP *o)
7667 {
7668     dVAR;
7669     OP* kid;
7670
7671     PERL_ARGS_ASSERT_CK_SELECT;
7672
7673     if (o->op_flags & OPf_KIDS) {
7674         kid = cLISTOPo->op_first->op_sibling;   /* get past pushmark */
7675         if (kid && kid->op_sibling) {
7676             o->op_type = OP_SSELECT;
7677             o->op_ppaddr = PL_ppaddr[OP_SSELECT];
7678             o = ck_fun(o);
7679             return fold_constants(o);
7680         }
7681     }
7682     o = ck_fun(o);
7683     kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
7684     if (kid && kid->op_type == OP_RV2GV)
7685         kid->op_private &= ~HINT_STRICT_REFS;
7686     return o;
7687 }
7688
7689 OP *
7690 Perl_ck_shift(pTHX_ OP *o)
7691 {
7692     dVAR;
7693     const I32 type = o->op_type;
7694
7695     PERL_ARGS_ASSERT_CK_SHIFT;
7696
7697     if (!(o->op_flags & OPf_KIDS)) {
7698         OP *argop;
7699         /* FIXME - this can be refactored to reduce code in #ifdefs  */
7700 #ifdef PERL_MAD
7701         OP * const oldo = o;
7702 #else
7703         op_free(o);
7704 #endif
7705         argop = newUNOP(OP_RV2AV, 0,
7706             scalar(newGVOP(OP_GV, 0, CvUNIQUE(PL_compcv) ? PL_argvgv : PL_defgv)));
7707 #ifdef PERL_MAD
7708         o = newUNOP(type, 0, scalar(argop));
7709         op_getmad(oldo,o,'O');
7710         return o;
7711 #else
7712         return newUNOP(type, 0, scalar(argop));
7713 #endif
7714     }
7715     return scalar(modkids(ck_fun(o), type));
7716 }
7717
7718 OP *
7719 Perl_ck_sort(pTHX_ OP *o)
7720 {
7721     dVAR;
7722     OP *firstkid;
7723
7724     PERL_ARGS_ASSERT_CK_SORT;
7725
7726     if (o->op_type == OP_SORT && (PL_hints & HINT_LOCALIZE_HH) != 0) {
7727         HV * const hinthv = GvHV(PL_hintgv);
7728         if (hinthv) {
7729             SV ** const svp = hv_fetchs(hinthv, "sort", FALSE);
7730             if (svp) {
7731                 const I32 sorthints = (I32)SvIV(*svp);
7732                 if ((sorthints & HINT_SORT_QUICKSORT) != 0)
7733                     o->op_private |= OPpSORT_QSORT;
7734                 if ((sorthints & HINT_SORT_STABLE) != 0)
7735                     o->op_private |= OPpSORT_STABLE;
7736             }
7737         }
7738     }
7739
7740     if (o->op_type == OP_SORT && o->op_flags & OPf_STACKED)
7741         simplify_sort(o);
7742     firstkid = cLISTOPo->op_first->op_sibling;          /* get past pushmark */
7743     if (o->op_flags & OPf_STACKED) {                    /* may have been cleared */
7744         OP *k = NULL;
7745         OP *kid = cUNOPx(firstkid)->op_first;           /* get past null */
7746
7747         if (kid->op_type == OP_SCOPE || kid->op_type == OP_LEAVE) {
7748             linklist(kid);
7749             if (kid->op_type == OP_SCOPE) {
7750                 k = kid->op_next;
7751                 kid->op_next = 0;
7752             }
7753             else if (kid->op_type == OP_LEAVE) {
7754                 if (o->op_type == OP_SORT) {
7755                     op_null(kid);                       /* wipe out leave */
7756                     kid->op_next = kid;
7757
7758                     for (k = kLISTOP->op_first->op_next; k; k = k->op_next) {
7759                         if (k->op_next == kid)
7760                             k->op_next = 0;
7761                         /* don't descend into loops */
7762                         else if (k->op_type == OP_ENTERLOOP
7763                                  || k->op_type == OP_ENTERITER)
7764                         {
7765                             k = cLOOPx(k)->op_lastop;
7766                         }
7767                     }
7768                 }
7769                 else
7770                     kid->op_next = 0;           /* just disconnect the leave */
7771                 k = kLISTOP->op_first;
7772             }
7773             CALL_PEEP(k);
7774
7775             kid = firstkid;
7776             if (o->op_type == OP_SORT) {
7777                 /* provide scalar context for comparison function/block */
7778                 kid = scalar(kid);
7779                 kid->op_next = kid;
7780             }
7781             else
7782                 kid->op_next = k;
7783             o->op_flags |= OPf_SPECIAL;
7784         }
7785         else if (kid->op_type == OP_RV2SV || kid->op_type == OP_PADSV)
7786             op_null(firstkid);
7787
7788         firstkid = firstkid->op_sibling;
7789     }
7790
7791     /* provide list context for arguments */
7792     if (o->op_type == OP_SORT)
7793         list(firstkid);
7794
7795     return o;
7796 }
7797
7798 STATIC void
7799 S_simplify_sort(pTHX_ OP *o)
7800 {
7801     dVAR;
7802     register OP *kid = cLISTOPo->op_first->op_sibling;  /* get past pushmark */
7803     OP *k;
7804     int descending;
7805     GV *gv;
7806     const char *gvname;
7807
7808     PERL_ARGS_ASSERT_SIMPLIFY_SORT;
7809
7810     if (!(o->op_flags & OPf_STACKED))
7811         return;
7812     GvMULTI_on(gv_fetchpvs("a", GV_ADD|GV_NOTQUAL, SVt_PV));
7813     GvMULTI_on(gv_fetchpvs("b", GV_ADD|GV_NOTQUAL, SVt_PV));
7814     kid = kUNOP->op_first;                              /* get past null */
7815     if (kid->op_type != OP_SCOPE)
7816         return;
7817     kid = kLISTOP->op_last;                             /* get past scope */
7818     switch(kid->op_type) {
7819         case OP_NCMP:
7820         case OP_I_NCMP:
7821         case OP_SCMP:
7822             break;
7823         default:
7824             return;
7825     }
7826     k = kid;                                            /* remember this node*/
7827     if (kBINOP->op_first->op_type != OP_RV2SV)
7828         return;
7829     kid = kBINOP->op_first;                             /* get past cmp */
7830     if (kUNOP->op_first->op_type != OP_GV)
7831         return;
7832     kid = kUNOP->op_first;                              /* get past rv2sv */
7833     gv = kGVOP_gv;
7834     if (GvSTASH(gv) != PL_curstash)
7835         return;
7836     gvname = GvNAME(gv);
7837     if (*gvname == 'a' && gvname[1] == '\0')
7838         descending = 0;
7839     else if (*gvname == 'b' && gvname[1] == '\0')
7840         descending = 1;
7841     else
7842         return;
7843
7844     kid = k;                                            /* back to cmp */
7845     if (kBINOP->op_last->op_type != OP_RV2SV)
7846         return;
7847     kid = kBINOP->op_last;                              /* down to 2nd arg */
7848     if (kUNOP->op_first->op_type != OP_GV)
7849         return;
7850     kid = kUNOP->op_first;                              /* get past rv2sv */
7851     gv = kGVOP_gv;
7852     if (GvSTASH(gv) != PL_curstash)
7853         return;
7854     gvname = GvNAME(gv);
7855     if ( descending
7856          ? !(*gvname == 'a' && gvname[1] == '\0')
7857          : !(*gvname == 'b' && gvname[1] == '\0'))
7858         return;
7859     o->op_flags &= ~(OPf_STACKED | OPf_SPECIAL);
7860     if (descending)
7861         o->op_private |= OPpSORT_DESCEND;
7862     if (k->op_type == OP_NCMP)
7863         o->op_private |= OPpSORT_NUMERIC;
7864     if (k->op_type == OP_I_NCMP)
7865         o->op_private |= OPpSORT_NUMERIC | OPpSORT_INTEGER;
7866     kid = cLISTOPo->op_first->op_sibling;
7867     cLISTOPo->op_first->op_sibling = kid->op_sibling; /* bypass old block */
7868 #ifdef PERL_MAD
7869     op_getmad(kid,o,'S');                             /* then delete it */
7870 #else
7871     op_free(kid);                                     /* then delete it */
7872 #endif
7873 }
7874
7875 OP *
7876 Perl_ck_split(pTHX_ OP *o)
7877 {
7878     dVAR;
7879     register OP *kid;
7880
7881     PERL_ARGS_ASSERT_CK_SPLIT;
7882
7883     if (o->op_flags & OPf_STACKED)
7884         return no_fh_allowed(o);
7885
7886     kid = cLISTOPo->op_first;
7887     if (kid->op_type != OP_NULL)
7888         Perl_croak(aTHX_ "panic: ck_split");
7889     kid = kid->op_sibling;
7890     op_free(cLISTOPo->op_first);
7891     cLISTOPo->op_first = kid;
7892     if (!kid) {
7893         cLISTOPo->op_first = kid = newSVOP(OP_CONST, 0, newSVpvs(" "));
7894         cLISTOPo->op_last = kid; /* There was only one element previously */
7895     }
7896
7897     if (kid->op_type != OP_MATCH || kid->op_flags & OPf_STACKED) {
7898         OP * const sibl = kid->op_sibling;
7899         kid->op_sibling = 0;
7900         kid = pmruntime( newPMOP(OP_MATCH, OPf_SPECIAL), kid, 0);
7901         if (cLISTOPo->op_first == cLISTOPo->op_last)
7902             cLISTOPo->op_last = kid;
7903         cLISTOPo->op_first = kid;
7904         kid->op_sibling = sibl;
7905     }
7906
7907     kid->op_type = OP_PUSHRE;
7908     kid->op_ppaddr = PL_ppaddr[OP_PUSHRE];
7909     scalar(kid);
7910     if (((PMOP *)kid)->op_pmflags & PMf_GLOBAL && ckWARN(WARN_REGEXP)) {
7911       Perl_warner(aTHX_ packWARN(WARN_REGEXP),
7912                   "Use of /g modifier is meaningless in split");
7913     }
7914
7915     if (!kid->op_sibling)
7916         append_elem(OP_SPLIT, o, newDEFSVOP());
7917
7918     kid = kid->op_sibling;
7919     scalar(kid);
7920
7921     if (!kid->op_sibling)
7922         append_elem(OP_SPLIT, o, newSVOP(OP_CONST, 0, newSViv(0)));
7923     assert(kid->op_sibling);
7924
7925     kid = kid->op_sibling;
7926     scalar(kid);
7927
7928     if (kid->op_sibling)
7929         return too_many_arguments(o,OP_DESC(o));
7930
7931     return o;
7932 }
7933
7934 OP *
7935 Perl_ck_join(pTHX_ OP *o)
7936 {
7937     const OP * const kid = cLISTOPo->op_first->op_sibling;
7938
7939     PERL_ARGS_ASSERT_CK_JOIN;
7940
7941     if (kid && kid->op_type == OP_MATCH) {
7942         if (ckWARN(WARN_SYNTAX)) {
7943             const REGEXP *re = PM_GETRE(kPMOP);
7944             const char *pmstr = re ? RX_PRECOMP_const(re) : "STRING";
7945             const STRLEN len = re ? RX_PRELEN(re) : 6;
7946             Perl_warner(aTHX_ packWARN(WARN_SYNTAX),
7947                         "/%.*s/ should probably be written as \"%.*s\"",
7948                         (int)len, pmstr, (int)len, pmstr);
7949         }
7950     }
7951     return ck_fun(o);
7952 }
7953
7954 OP *
7955 Perl_ck_subr(pTHX_ OP *o)
7956 {
7957     dVAR;
7958     OP *prev = ((cUNOPo->op_first->op_sibling)
7959              ? cUNOPo : ((UNOP*)cUNOPo->op_first))->op_first;
7960     OP *o2 = prev->op_sibling;
7961     OP *cvop;
7962     const char *proto = NULL;
7963     const char *proto_end = NULL;
7964     CV *cv = NULL;
7965     GV *namegv = NULL;
7966     int optional = 0;
7967     I32 arg = 0;
7968     I32 contextclass = 0;
7969     const char *e = NULL;
7970     bool delete_op = 0;
7971
7972     PERL_ARGS_ASSERT_CK_SUBR;
7973
7974     o->op_private |= OPpENTERSUB_HASTARG;
7975     for (cvop = o2; cvop->op_sibling; cvop = cvop->op_sibling) ;
7976     if (cvop->op_type == OP_RV2CV) {
7977         SVOP* tmpop;
7978         o->op_private |= (cvop->op_private & OPpENTERSUB_AMPER);
7979         op_null(cvop);          /* disable rv2cv */
7980         tmpop = (SVOP*)((UNOP*)cvop)->op_first;
7981         if (tmpop->op_type == OP_GV && !(o->op_private & OPpENTERSUB_AMPER)) {
7982             GV *gv = cGVOPx_gv(tmpop);
7983             cv = GvCVu(gv);
7984             if (!cv)
7985                 tmpop->op_private |= OPpEARLY_CV;
7986             else {
7987                 if (SvPOK(cv)) {
7988                     STRLEN len;
7989                     namegv = CvANON(cv) ? gv : CvGV(cv);
7990                     proto = SvPV(MUTABLE_SV(cv), len);
7991                     proto_end = proto + len;
7992                 }
7993             }
7994         }
7995     }
7996     else if (cvop->op_type == OP_METHOD || cvop->op_type == OP_METHOD_NAMED) {
7997         if (o2->op_type == OP_CONST)
7998             o2->op_private &= ~OPpCONST_STRICT;
7999         else if (o2->op_type == OP_LIST) {
8000             OP * const sib = ((UNOP*)o2)->op_first->op_sibling;
8001             if (sib && sib->op_type == OP_CONST)
8002                 sib->op_private &= ~OPpCONST_STRICT;
8003         }
8004     }
8005     o->op_private |= (PL_hints & HINT_STRICT_REFS);
8006     if (PERLDB_SUB && PL_curstash != PL_debstash)
8007         o->op_private |= OPpENTERSUB_DB;
8008     while (o2 != cvop) {
8009         OP* o3;
8010         if (PL_madskills && o2->op_type == OP_STUB) {
8011             o2 = o2->op_sibling;
8012             continue;
8013         }
8014         if (PL_madskills && o2->op_type == OP_NULL)
8015             o3 = ((UNOP*)o2)->op_first;
8016         else
8017             o3 = o2;
8018         if (proto) {
8019             if (proto >= proto_end)
8020                 return too_many_arguments(o, gv_ename(namegv));
8021
8022             switch (*proto) {
8023             case ';':
8024                 optional = 1;
8025                 proto++;
8026                 continue;
8027             case '_':
8028                 /* _ must be at the end */
8029                 if (proto[1] && proto[1] != ';')
8030                     goto oops;
8031             case '$':
8032                 proto++;
8033                 arg++;
8034                 scalar(o2);
8035                 break;
8036             case '%':
8037             case '@':
8038                 list(o2);
8039                 arg++;
8040                 break;
8041             case '&':
8042                 proto++;
8043                 arg++;
8044                 if (o3->op_type != OP_REFGEN && o3->op_type != OP_UNDEF)
8045                     bad_type(arg,
8046                         arg == 1 ? "block or sub {}" : "sub {}",
8047                         gv_ename(namegv), o3);
8048                 break;
8049             case '*':
8050                 /* '*' allows any scalar type, including bareword */
8051                 proto++;
8052                 arg++;
8053                 if (o3->op_type == OP_RV2GV)
8054                     goto wrapref;       /* autoconvert GLOB -> GLOBref */
8055                 else if (o3->op_type == OP_CONST)
8056                     o3->op_private &= ~OPpCONST_STRICT;
8057                 else if (o3->op_type == OP_ENTERSUB) {
8058                     /* accidental subroutine, revert to bareword */
8059                     OP *gvop = ((UNOP*)o3)->op_first;
8060                     if (gvop && gvop->op_type == OP_NULL) {
8061                         gvop = ((UNOP*)gvop)->op_first;
8062                         if (gvop) {
8063                             for (; gvop->op_sibling; gvop = gvop->op_sibling)
8064                                 ;
8065                             if (gvop &&
8066                                 (gvop->op_private & OPpENTERSUB_NOPAREN) &&
8067                                 (gvop = ((UNOP*)gvop)->op_first) &&
8068                                 gvop->op_type == OP_GV)
8069                             {
8070                                 GV * const gv = cGVOPx_gv(gvop);
8071                                 OP * const sibling = o2->op_sibling;
8072                                 SV * const n = newSVpvs("");
8073 #ifdef PERL_MAD
8074                                 OP * const oldo2 = o2;
8075 #else
8076                                 op_free(o2);
8077 #endif
8078                                 gv_fullname4(n, gv, "", FALSE);
8079                                 o2 = newSVOP(OP_CONST, 0, n);
8080                                 op_getmad(oldo2,o2,'O');
8081                                 prev->op_sibling = o2;
8082                                 o2->op_sibling = sibling;
8083                             }
8084                         }
8085                     }
8086                 }
8087                 scalar(o2);
8088                 break;
8089             case '[': case ']':
8090                  goto oops;
8091                  break;
8092             case '\\':
8093                 proto++;
8094                 arg++;
8095             again:
8096                 switch (*proto++) {
8097                 case '[':
8098                      if (contextclass++ == 0) {
8099                           e = strchr(proto, ']');
8100                           if (!e || e == proto)
8101                                goto oops;
8102                      }
8103                      else
8104                           goto oops;
8105                      goto again;
8106                      break;
8107                 case ']':
8108                      if (contextclass) {
8109                          const char *p = proto;
8110                          const char *const end = proto;
8111                          contextclass = 0;
8112                          while (*--p != '[') {}
8113                          bad_type(arg, Perl_form(aTHX_ "one of %.*s",
8114                                                  (int)(end - p), p),
8115                                   gv_ename(namegv), o3);
8116                      } else
8117                           goto oops;
8118                      break;
8119                 case '*':
8120                      if (o3->op_type == OP_RV2GV)
8121                           goto wrapref;
8122                      if (!contextclass)
8123                           bad_type(arg, "symbol", gv_ename(namegv), o3);
8124                      break;
8125                 case '&':
8126                      if (o3->op_type == OP_ENTERSUB)
8127                           goto wrapref;
8128                      if (!contextclass)
8129                           bad_type(arg, "subroutine entry", gv_ename(namegv),
8130                                    o3);
8131                      break;
8132                 case '$':
8133                     if (o3->op_type == OP_RV2SV ||
8134                         o3->op_type == OP_PADSV ||
8135                         o3->op_type == OP_HELEM ||
8136                         o3->op_type == OP_AELEM)
8137                          goto wrapref;
8138                     if (!contextclass)
8139                         bad_type(arg, "scalar", gv_ename(namegv), o3);
8140                      break;
8141                 case '@':
8142                     if (o3->op_type == OP_RV2AV ||
8143                         o3->op_type == OP_PADAV)
8144                          goto wrapref;
8145                     if (!contextclass)
8146                         bad_type(arg, "array", gv_ename(namegv), o3);
8147                     break;
8148                 case '%':
8149                     if (o3->op_type == OP_RV2HV ||
8150                         o3->op_type == OP_PADHV)
8151                          goto wrapref;
8152                     if (!contextclass)
8153                          bad_type(arg, "hash", gv_ename(namegv), o3);
8154                     break;
8155                 wrapref:
8156                     {
8157                         OP* const kid = o2;
8158                         OP* const sib = kid->op_sibling;
8159                         kid->op_sibling = 0;
8160                         o2 = newUNOP(OP_REFGEN, 0, kid);
8161                         o2->op_sibling = sib;
8162                         prev->op_sibling = o2;
8163                     }
8164                     if (contextclass && e) {
8165                          proto = e + 1;
8166                          contextclass = 0;
8167                     }
8168                     break;
8169                 default: goto oops;
8170                 }
8171                 if (contextclass)
8172                      goto again;
8173                 break;
8174             case ' ':
8175                 proto++;
8176                 continue;
8177             default:
8178               oops:
8179                 Perl_croak(aTHX_ "Malformed prototype for %s: %"SVf,
8180                            gv_ename(namegv), SVfARG(cv));
8181             }
8182         }
8183         else
8184             list(o2);
8185         mod(o2, OP_ENTERSUB);
8186         prev = o2;
8187         o2 = o2->op_sibling;
8188     } /* while */
8189     if (o2 == cvop && proto && *proto == '_') {
8190         /* generate an access to $_ */
8191         o2 = newDEFSVOP();
8192         o2->op_sibling = prev->op_sibling;
8193         prev->op_sibling = o2; /* instead of cvop */
8194     }
8195     if (proto && !optional && proto_end > proto &&
8196         (*proto != '@' && *proto != '%' && *proto != ';' && *proto != '_'))
8197         return too_few_arguments(o, gv_ename(namegv));
8198     if(delete_op) {
8199 #ifdef PERL_MAD
8200         OP * const oldo = o;
8201 #else
8202         op_free(o);
8203 #endif
8204         o=newSVOP(OP_CONST, 0, newSViv(0));
8205         op_getmad(oldo,o,'O');
8206     }
8207     return o;
8208 }
8209
8210 OP *
8211 Perl_ck_svconst(pTHX_ OP *o)
8212 {
8213     PERL_ARGS_ASSERT_CK_SVCONST;
8214     PERL_UNUSED_CONTEXT;
8215     SvREADONLY_on(cSVOPo->op_sv);
8216     return o;
8217 }
8218
8219 OP *
8220 Perl_ck_chdir(pTHX_ OP *o)
8221 {
8222     if (o->op_flags & OPf_KIDS) {
8223         SVOP * const kid = (SVOP*)cUNOPo->op_first;
8224
8225         if (kid && kid->op_type == OP_CONST &&
8226             (kid->op_private & OPpCONST_BARE))
8227         {
8228             o->op_flags |= OPf_SPECIAL;
8229             kid->op_private &= ~OPpCONST_STRICT;
8230         }
8231     }
8232     return ck_fun(o);
8233 }
8234
8235 OP *
8236 Perl_ck_trunc(pTHX_ OP *o)
8237 {
8238     PERL_ARGS_ASSERT_CK_TRUNC;
8239
8240     if (o->op_flags & OPf_KIDS) {
8241         SVOP *kid = (SVOP*)cUNOPo->op_first;
8242
8243         if (kid->op_type == OP_NULL)
8244             kid = (SVOP*)kid->op_sibling;
8245         if (kid && kid->op_type == OP_CONST &&
8246             (kid->op_private & OPpCONST_BARE))
8247         {
8248             o->op_flags |= OPf_SPECIAL;
8249             kid->op_private &= ~OPpCONST_STRICT;
8250         }
8251     }
8252     return ck_fun(o);
8253 }
8254
8255 OP *
8256 Perl_ck_unpack(pTHX_ OP *o)
8257 {
8258     OP *kid = cLISTOPo->op_first;
8259
8260     PERL_ARGS_ASSERT_CK_UNPACK;
8261
8262     if (kid->op_sibling) {
8263         kid = kid->op_sibling;
8264         if (!kid->op_sibling)
8265             kid->op_sibling = newDEFSVOP();
8266     }
8267     return ck_fun(o);
8268 }
8269
8270 OP *
8271 Perl_ck_substr(pTHX_ OP *o)
8272 {
8273     PERL_ARGS_ASSERT_CK_SUBSTR;
8274
8275     o = ck_fun(o);
8276     if ((o->op_flags & OPf_KIDS) && (o->op_private == 4)) {
8277         OP *kid = cLISTOPo->op_first;
8278
8279         if (kid->op_type == OP_NULL)
8280             kid = kid->op_sibling;
8281         if (kid)
8282             kid->op_flags |= OPf_MOD;
8283
8284     }
8285     return o;
8286 }
8287
8288 OP *
8289 Perl_ck_each(pTHX_ OP *o)
8290 {
8291     dVAR;
8292     OP *kid = cLISTOPo->op_first;
8293
8294     PERL_ARGS_ASSERT_CK_EACH;
8295
8296     if (kid->op_type == OP_PADAV || kid->op_type == OP_RV2AV) {
8297         const unsigned new_type = o->op_type == OP_EACH ? OP_AEACH
8298             : o->op_type == OP_KEYS ? OP_AKEYS : OP_AVALUES;
8299         o->op_type = new_type;
8300         o->op_ppaddr = PL_ppaddr[new_type];
8301     }
8302     else if (!(kid->op_type == OP_PADHV || kid->op_type == OP_RV2HV
8303                || (kid->op_type == OP_CONST && kid->op_private & OPpCONST_BARE)
8304                )) {
8305         bad_type(1, "hash or array", PL_op_desc[o->op_type], kid);
8306         return o;
8307     }
8308     return ck_fun(o);
8309 }
8310
8311 /* A peephole optimizer.  We visit the ops in the order they're to execute.
8312  * See the comments at the top of this file for more details about when
8313  * peep() is called */
8314
8315 void
8316 Perl_peep(pTHX_ register OP *o)
8317 {
8318     dVAR;
8319     register OP* oldop = NULL;
8320
8321     if (!o || o->op_opt)
8322         return;
8323     ENTER;
8324     SAVEOP();
8325     SAVEVPTR(PL_curcop);
8326     for (; o; o = o->op_next) {
8327         if (o->op_opt)
8328             break;
8329         /* By default, this op has now been optimised. A couple of cases below
8330            clear this again.  */
8331         o->op_opt = 1;
8332         PL_op = o;
8333         switch (o->op_type) {
8334         case OP_NEXTSTATE:
8335         case OP_DBSTATE:
8336             PL_curcop = ((COP*)o);              /* for warnings */
8337             break;
8338
8339         case OP_CONST:
8340             if (cSVOPo->op_private & OPpCONST_STRICT)
8341                 no_bareword_allowed(o);
8342 #ifdef USE_ITHREADS
8343         case OP_HINTSEVAL:
8344         case OP_METHOD_NAMED:
8345             /* Relocate sv to the pad for thread safety.
8346              * Despite being a "constant", the SV is written to,
8347              * for reference counts, sv_upgrade() etc. */
8348             if (cSVOP->op_sv) {
8349                 const PADOFFSET ix = pad_alloc(OP_CONST, SVs_PADTMP);
8350                 if (o->op_type != OP_METHOD_NAMED && SvPADTMP(cSVOPo->op_sv)) {
8351                     /* If op_sv is already a PADTMP then it is being used by
8352                      * some pad, so make a copy. */
8353                     sv_setsv(PAD_SVl(ix),cSVOPo->op_sv);
8354                     SvREADONLY_on(PAD_SVl(ix));
8355                     SvREFCNT_dec(cSVOPo->op_sv);
8356                 }
8357                 else if (o->op_type != OP_METHOD_NAMED
8358                          && cSVOPo->op_sv == &PL_sv_undef) {
8359                     /* PL_sv_undef is hack - it's unsafe to store it in the
8360                        AV that is the pad, because av_fetch treats values of
8361                        PL_sv_undef as a "free" AV entry and will merrily
8362                        replace them with a new SV, causing pad_alloc to think
8363                        that this pad slot is free. (When, clearly, it is not)
8364                     */
8365                     SvOK_off(PAD_SVl(ix));
8366                     SvPADTMP_on(PAD_SVl(ix));
8367                     SvREADONLY_on(PAD_SVl(ix));
8368                 }
8369                 else {
8370                     SvREFCNT_dec(PAD_SVl(ix));
8371                     SvPADTMP_on(cSVOPo->op_sv);
8372                     PAD_SETSV(ix, cSVOPo->op_sv);
8373                     /* XXX I don't know how this isn't readonly already. */
8374                     SvREADONLY_on(PAD_SVl(ix));
8375                 }
8376                 cSVOPo->op_sv = NULL;
8377                 o->op_targ = ix;
8378             }
8379 #endif
8380             break;
8381
8382         case OP_CONCAT:
8383             if (o->op_next && o->op_next->op_type == OP_STRINGIFY) {
8384                 if (o->op_next->op_private & OPpTARGET_MY) {
8385                     if (o->op_flags & OPf_STACKED) /* chained concats */
8386                         break; /* ignore_optimization */
8387                     else {
8388                         /* assert(PL_opargs[o->op_type] & OA_TARGLEX); */
8389                         o->op_targ = o->op_next->op_targ;
8390                         o->op_next->op_targ = 0;
8391                         o->op_private |= OPpTARGET_MY;
8392                     }
8393                 }
8394                 op_null(o->op_next);
8395             }
8396             break;
8397         case OP_STUB:
8398             if ((o->op_flags & OPf_WANT) != OPf_WANT_LIST) {
8399                 break; /* Scalar stub must produce undef.  List stub is noop */
8400             }
8401             goto nothin;
8402         case OP_NULL:
8403             if (o->op_targ == OP_NEXTSTATE
8404                 || o->op_targ == OP_DBSTATE)
8405             {
8406                 PL_curcop = ((COP*)o);
8407             }
8408             /* XXX: We avoid setting op_seq here to prevent later calls
8409                to peep() from mistakenly concluding that optimisation
8410                has already occurred. This doesn't fix the real problem,
8411                though (See 20010220.007). AMS 20010719 */
8412             /* op_seq functionality is now replaced by op_opt */
8413             o->op_opt = 0;
8414             /* FALL THROUGH */
8415         case OP_SCALAR:
8416         case OP_LINESEQ:
8417         case OP_SCOPE:
8418         nothin:
8419             if (oldop && o->op_next) {
8420                 oldop->op_next = o->op_next;
8421                 o->op_opt = 0;
8422                 continue;
8423             }
8424             break;
8425
8426         case OP_PADAV:
8427         case OP_GV:
8428             if (o->op_type == OP_PADAV || o->op_next->op_type == OP_RV2AV) {
8429                 OP* const pop = (o->op_type == OP_PADAV) ?
8430                             o->op_next : o->op_next->op_next;
8431                 IV i;
8432                 if (pop && pop->op_type == OP_CONST &&
8433                     ((PL_op = pop->op_next)) &&
8434                     pop->op_next->op_type == OP_AELEM &&
8435                     !(pop->op_next->op_private &
8436                       (OPpLVAL_INTRO|OPpLVAL_DEFER|OPpDEREF|OPpMAYBE_LVSUB)) &&
8437                     (i = SvIV(((SVOP*)pop)->op_sv) - CopARYBASE_get(PL_curcop))
8438                                 <= 255 &&
8439                     i >= 0)
8440                 {
8441                     GV *gv;
8442                     if (cSVOPx(pop)->op_private & OPpCONST_STRICT)
8443                         no_bareword_allowed(pop);
8444                     if (o->op_type == OP_GV)
8445                         op_null(o->op_next);
8446                     op_null(pop->op_next);
8447                     op_null(pop);
8448                     o->op_flags |= pop->op_next->op_flags & OPf_MOD;
8449                     o->op_next = pop->op_next->op_next;
8450                     o->op_ppaddr = PL_ppaddr[OP_AELEMFAST];
8451                     o->op_private = (U8)i;
8452                     if (o->op_type == OP_GV) {
8453                         gv = cGVOPo_gv;
8454                         GvAVn(gv);
8455                     }
8456                     else
8457                         o->op_flags |= OPf_SPECIAL;
8458                     o->op_type = OP_AELEMFAST;
8459                 }
8460                 break;
8461             }
8462
8463             if (o->op_next->op_type == OP_RV2SV) {
8464                 if (!(o->op_next->op_private & OPpDEREF)) {
8465                     op_null(o->op_next);
8466                     o->op_private |= o->op_next->op_private & (OPpLVAL_INTRO
8467                                                                | OPpOUR_INTRO);
8468                     o->op_next = o->op_next->op_next;
8469                     o->op_type = OP_GVSV;
8470                     o->op_ppaddr = PL_ppaddr[OP_GVSV];
8471                 }
8472             }
8473             else if ((o->op_private & OPpEARLY_CV) && ckWARN(WARN_PROTOTYPE)) {
8474                 GV * const gv = cGVOPo_gv;
8475                 if (SvTYPE(gv) == SVt_PVGV && GvCV(gv) && SvPVX_const(GvCV(gv))) {
8476                     /* XXX could check prototype here instead of just carping */
8477                     SV * const sv = sv_newmortal();
8478                     gv_efullname3(sv, gv, NULL);
8479                     Perl_warner(aTHX_ packWARN(WARN_PROTOTYPE),
8480                                 "%"SVf"() called too early to check prototype",
8481                                 SVfARG(sv));
8482                 }
8483             }
8484             else if (o->op_next->op_type == OP_READLINE
8485                     && o->op_next->op_next->op_type == OP_CONCAT
8486                     && (o->op_next->op_next->op_flags & OPf_STACKED))
8487             {
8488                 /* Turn "$a .= <FH>" into an OP_RCATLINE. AMS 20010917 */
8489                 o->op_type   = OP_RCATLINE;
8490                 o->op_flags |= OPf_STACKED;
8491                 o->op_ppaddr = PL_ppaddr[OP_RCATLINE];
8492                 op_null(o->op_next->op_next);
8493                 op_null(o->op_next);
8494             }
8495
8496             break;
8497
8498         case OP_MAPWHILE:
8499         case OP_GREPWHILE:
8500         case OP_AND:
8501         case OP_OR:
8502         case OP_DOR:
8503         case OP_ANDASSIGN:
8504         case OP_ORASSIGN:
8505         case OP_DORASSIGN:
8506         case OP_COND_EXPR:
8507         case OP_RANGE:
8508         case OP_ONCE:
8509             while (cLOGOP->op_other->op_type == OP_NULL)
8510                 cLOGOP->op_other = cLOGOP->op_other->op_next;
8511             peep(cLOGOP->op_other); /* Recursive calls are not replaced by fptr calls */
8512             break;
8513
8514         case OP_ENTERLOOP:
8515         case OP_ENTERITER:
8516             while (cLOOP->op_redoop->op_type == OP_NULL)
8517                 cLOOP->op_redoop = cLOOP->op_redoop->op_next;
8518             peep(cLOOP->op_redoop);
8519             while (cLOOP->op_nextop->op_type == OP_NULL)
8520                 cLOOP->op_nextop = cLOOP->op_nextop->op_next;
8521             peep(cLOOP->op_nextop);
8522             while (cLOOP->op_lastop->op_type == OP_NULL)
8523                 cLOOP->op_lastop = cLOOP->op_lastop->op_next;
8524             peep(cLOOP->op_lastop);
8525             break;
8526
8527         case OP_SUBST:
8528             assert(!(cPMOP->op_pmflags & PMf_ONCE));
8529             while (cPMOP->op_pmstashstartu.op_pmreplstart &&
8530                    cPMOP->op_pmstashstartu.op_pmreplstart->op_type == OP_NULL)
8531                 cPMOP->op_pmstashstartu.op_pmreplstart
8532                     = cPMOP->op_pmstashstartu.op_pmreplstart->op_next;
8533             peep(cPMOP->op_pmstashstartu.op_pmreplstart);
8534             break;
8535
8536         case OP_EXEC:
8537             if (o->op_next && o->op_next->op_type == OP_NEXTSTATE
8538                 && ckWARN(WARN_SYNTAX))
8539             {
8540                 if (o->op_next->op_sibling) {
8541                     const OPCODE type = o->op_next->op_sibling->op_type;
8542                     if (type != OP_EXIT && type != OP_WARN && type != OP_DIE) {
8543                         const line_t oldline = CopLINE(PL_curcop);
8544                         CopLINE_set(PL_curcop, CopLINE((COP*)o->op_next));
8545                         Perl_warner(aTHX_ packWARN(WARN_EXEC),
8546                                     "Statement unlikely to be reached");
8547                         Perl_warner(aTHX_ packWARN(WARN_EXEC),
8548                                     "\t(Maybe you meant system() when you said exec()?)\n");
8549                         CopLINE_set(PL_curcop, oldline);
8550                     }
8551                 }
8552             }
8553             break;
8554
8555         case OP_HELEM: {
8556             UNOP *rop;
8557             SV *lexname;
8558             GV **fields;
8559             SV **svp, *sv;
8560             const char *key = NULL;
8561             STRLEN keylen;
8562
8563             if (((BINOP*)o)->op_last->op_type != OP_CONST)
8564                 break;
8565
8566             /* Make the CONST have a shared SV */
8567             svp = cSVOPx_svp(((BINOP*)o)->op_last);
8568             if (!SvFAKE(sv = *svp) || !SvREADONLY(sv)) {
8569                 key = SvPV_const(sv, keylen);
8570                 lexname = newSVpvn_share(key,
8571                                          SvUTF8(sv) ? -(I32)keylen : (I32)keylen,
8572                                          0);
8573                 SvREFCNT_dec(sv);
8574                 *svp = lexname;
8575             }
8576
8577             if ((o->op_private & (OPpLVAL_INTRO)))
8578                 break;
8579
8580             rop = (UNOP*)((BINOP*)o)->op_first;
8581             if (rop->op_type != OP_RV2HV || rop->op_first->op_type != OP_PADSV)
8582                 break;
8583             lexname = *av_fetch(PL_comppad_name, rop->op_first->op_targ, TRUE);
8584             if (!SvPAD_TYPED(lexname))
8585                 break;
8586             fields = (GV**)hv_fetchs(SvSTASH(lexname), "FIELDS", FALSE);
8587             if (!fields || !GvHV(*fields))
8588                 break;
8589             key = SvPV_const(*svp, keylen);
8590             if (!hv_fetch(GvHV(*fields), key,
8591                         SvUTF8(*svp) ? -(I32)keylen : (I32)keylen, FALSE))
8592             {
8593                 Perl_croak(aTHX_ "No such class field \"%s\" " 
8594                            "in variable %s of type %s", 
8595                       key, SvPV_nolen_const(lexname), HvNAME_get(SvSTASH(lexname)));
8596             }
8597
8598             break;
8599         }
8600
8601         case OP_HSLICE: {
8602             UNOP *rop;
8603             SV *lexname;
8604             GV **fields;
8605             SV **svp;
8606             const char *key;
8607             STRLEN keylen;
8608             SVOP *first_key_op, *key_op;
8609
8610             if ((o->op_private & (OPpLVAL_INTRO))
8611                 /* I bet there's always a pushmark... */
8612                 || ((LISTOP*)o)->op_first->op_sibling->op_type != OP_LIST)
8613                 /* hmmm, no optimization if list contains only one key. */
8614                 break;
8615             rop = (UNOP*)((LISTOP*)o)->op_last;
8616             if (rop->op_type != OP_RV2HV)
8617                 break;
8618             if (rop->op_first->op_type == OP_PADSV)
8619                 /* @$hash{qw(keys here)} */
8620                 rop = (UNOP*)rop->op_first;
8621             else {
8622                 /* @{$hash}{qw(keys here)} */
8623                 if (rop->op_first->op_type == OP_SCOPE 
8624                     && cLISTOPx(rop->op_first)->op_last->op_type == OP_PADSV)
8625                 {
8626                     rop = (UNOP*)cLISTOPx(rop->op_first)->op_last;
8627                 }
8628                 else
8629                     break;
8630             }
8631                     
8632             lexname = *av_fetch(PL_comppad_name, rop->op_targ, TRUE);
8633             if (!SvPAD_TYPED(lexname))
8634                 break;
8635             fields = (GV**)hv_fetchs(SvSTASH(lexname), "FIELDS", FALSE);
8636             if (!fields || !GvHV(*fields))
8637                 break;
8638             /* Again guessing that the pushmark can be jumped over.... */
8639             first_key_op = (SVOP*)((LISTOP*)((LISTOP*)o)->op_first->op_sibling)
8640                 ->op_first->op_sibling;
8641             for (key_op = first_key_op; key_op;
8642                  key_op = (SVOP*)key_op->op_sibling) {
8643                 if (key_op->op_type != OP_CONST)
8644                     continue;
8645                 svp = cSVOPx_svp(key_op);
8646                 key = SvPV_const(*svp, keylen);
8647                 if (!hv_fetch(GvHV(*fields), key, 
8648                             SvUTF8(*svp) ? -(I32)keylen : (I32)keylen, FALSE))
8649                 {
8650                     Perl_croak(aTHX_ "No such class field \"%s\" "
8651                                "in variable %s of type %s",
8652                           key, SvPV_nolen(lexname), HvNAME_get(SvSTASH(lexname)));
8653                 }
8654             }
8655             break;
8656         }
8657
8658         case OP_SORT: {
8659             /* will point to RV2AV or PADAV op on LHS/RHS of assign */
8660             OP *oleft;
8661             OP *o2;
8662
8663             /* check that RHS of sort is a single plain array */
8664             OP *oright = cUNOPo->op_first;
8665             if (!oright || oright->op_type != OP_PUSHMARK)
8666                 break;
8667
8668             /* reverse sort ... can be optimised.  */
8669             if (!cUNOPo->op_sibling) {
8670                 /* Nothing follows us on the list. */
8671                 OP * const reverse = o->op_next;
8672
8673                 if (reverse->op_type == OP_REVERSE &&
8674                     (reverse->op_flags & OPf_WANT) == OPf_WANT_LIST) {
8675                     OP * const pushmark = cUNOPx(reverse)->op_first;
8676                     if (pushmark && (pushmark->op_type == OP_PUSHMARK)
8677                         && (cUNOPx(pushmark)->op_sibling == o)) {
8678                         /* reverse -> pushmark -> sort */
8679                         o->op_private |= OPpSORT_REVERSE;
8680                         op_null(reverse);
8681                         pushmark->op_next = oright->op_next;
8682                         op_null(oright);
8683                     }
8684                 }
8685             }
8686
8687             /* make @a = sort @a act in-place */
8688
8689             oright = cUNOPx(oright)->op_sibling;
8690             if (!oright)
8691                 break;
8692             if (oright->op_type == OP_NULL) { /* skip sort block/sub */
8693                 oright = cUNOPx(oright)->op_sibling;
8694             }
8695
8696             if (!oright ||
8697                 (oright->op_type != OP_RV2AV && oright->op_type != OP_PADAV)
8698                 || oright->op_next != o
8699                 || (oright->op_private & OPpLVAL_INTRO)
8700             )
8701                 break;
8702
8703             /* o2 follows the chain of op_nexts through the LHS of the
8704              * assign (if any) to the aassign op itself */
8705             o2 = o->op_next;
8706             if (!o2 || o2->op_type != OP_NULL)
8707                 break;
8708             o2 = o2->op_next;
8709             if (!o2 || o2->op_type != OP_PUSHMARK)
8710                 break;
8711             o2 = o2->op_next;
8712             if (o2 && o2->op_type == OP_GV)
8713                 o2 = o2->op_next;
8714             if (!o2
8715                 || (o2->op_type != OP_PADAV && o2->op_type != OP_RV2AV)
8716                 || (o2->op_private & OPpLVAL_INTRO)
8717             )
8718                 break;
8719             oleft = o2;
8720             o2 = o2->op_next;
8721             if (!o2 || o2->op_type != OP_NULL)
8722                 break;
8723             o2 = o2->op_next;
8724             if (!o2 || o2->op_type != OP_AASSIGN
8725                     || (o2->op_flags & OPf_WANT) != OPf_WANT_VOID)
8726                 break;
8727
8728             /* check that the sort is the first arg on RHS of assign */
8729
8730             o2 = cUNOPx(o2)->op_first;
8731             if (!o2 || o2->op_type != OP_NULL)
8732                 break;
8733             o2 = cUNOPx(o2)->op_first;
8734             if (!o2 || o2->op_type != OP_PUSHMARK)
8735                 break;
8736             if (o2->op_sibling != o)
8737                 break;
8738
8739             /* check the array is the same on both sides */
8740             if (oleft->op_type == OP_RV2AV) {
8741                 if (oright->op_type != OP_RV2AV
8742                     || !cUNOPx(oright)->op_first
8743                     || cUNOPx(oright)->op_first->op_type != OP_GV
8744                     ||  cGVOPx_gv(cUNOPx(oleft)->op_first) !=
8745                         cGVOPx_gv(cUNOPx(oright)->op_first)
8746                 )
8747                     break;
8748             }
8749             else if (oright->op_type != OP_PADAV
8750                 || oright->op_targ != oleft->op_targ
8751             )
8752                 break;
8753
8754             /* transfer MODishness etc from LHS arg to RHS arg */
8755             oright->op_flags = oleft->op_flags;
8756             o->op_private |= OPpSORT_INPLACE;
8757
8758             /* excise push->gv->rv2av->null->aassign */
8759             o2 = o->op_next->op_next;
8760             op_null(o2); /* PUSHMARK */
8761             o2 = o2->op_next;
8762             if (o2->op_type == OP_GV) {
8763                 op_null(o2); /* GV */
8764                 o2 = o2->op_next;
8765             }
8766             op_null(o2); /* RV2AV or PADAV */
8767             o2 = o2->op_next->op_next;
8768             op_null(o2); /* AASSIGN */
8769
8770             o->op_next = o2->op_next;
8771
8772             break;
8773         }
8774
8775         case OP_REVERSE: {
8776             OP *ourmark, *theirmark, *ourlast, *iter, *expushmark, *rv2av;
8777             OP *gvop = NULL;
8778             LISTOP *enter, *exlist;
8779
8780             enter = (LISTOP *) o->op_next;
8781             if (!enter)
8782                 break;
8783             if (enter->op_type == OP_NULL) {
8784                 enter = (LISTOP *) enter->op_next;
8785                 if (!enter)
8786                     break;
8787             }
8788             /* for $a (...) will have OP_GV then OP_RV2GV here.
8789                for (...) just has an OP_GV.  */
8790             if (enter->op_type == OP_GV) {
8791                 gvop = (OP *) enter;
8792                 enter = (LISTOP *) enter->op_next;
8793                 if (!enter)
8794                     break;
8795                 if (enter->op_type == OP_RV2GV) {
8796                   enter = (LISTOP *) enter->op_next;
8797                   if (!enter)
8798                     break;
8799                 }
8800             }
8801
8802             if (enter->op_type != OP_ENTERITER)
8803                 break;
8804
8805             iter = enter->op_next;
8806             if (!iter || iter->op_type != OP_ITER)
8807                 break;
8808             
8809             expushmark = enter->op_first;
8810             if (!expushmark || expushmark->op_type != OP_NULL
8811                 || expushmark->op_targ != OP_PUSHMARK)
8812                 break;
8813
8814             exlist = (LISTOP *) expushmark->op_sibling;
8815             if (!exlist || exlist->op_type != OP_NULL
8816                 || exlist->op_targ != OP_LIST)
8817                 break;
8818
8819             if (exlist->op_last != o) {
8820                 /* Mmm. Was expecting to point back to this op.  */
8821                 break;
8822             }
8823             theirmark = exlist->op_first;
8824             if (!theirmark || theirmark->op_type != OP_PUSHMARK)
8825                 break;
8826
8827             if (theirmark->op_sibling != o) {
8828                 /* There's something between the mark and the reverse, eg
8829                    for (1, reverse (...))
8830                    so no go.  */
8831                 break;
8832             }
8833
8834             ourmark = ((LISTOP *)o)->op_first;
8835             if (!ourmark || ourmark->op_type != OP_PUSHMARK)
8836                 break;
8837
8838             ourlast = ((LISTOP *)o)->op_last;
8839             if (!ourlast || ourlast->op_next != o)
8840                 break;
8841
8842             rv2av = ourmark->op_sibling;
8843             if (rv2av && rv2av->op_type == OP_RV2AV && rv2av->op_sibling == 0
8844                 && rv2av->op_flags == (OPf_WANT_LIST | OPf_KIDS)
8845                 && enter->op_flags == (OPf_WANT_LIST | OPf_KIDS)) {
8846                 /* We're just reversing a single array.  */
8847                 rv2av->op_flags = OPf_WANT_SCALAR | OPf_KIDS | OPf_REF;
8848                 enter->op_flags |= OPf_STACKED;
8849             }
8850
8851             /* We don't have control over who points to theirmark, so sacrifice
8852                ours.  */
8853             theirmark->op_next = ourmark->op_next;
8854             theirmark->op_flags = ourmark->op_flags;
8855             ourlast->op_next = gvop ? gvop : (OP *) enter;
8856             op_null(ourmark);
8857             op_null(o);
8858             enter->op_private |= OPpITER_REVERSED;
8859             iter->op_private |= OPpITER_REVERSED;
8860             
8861             break;
8862         }
8863
8864         case OP_SASSIGN: {
8865             OP *rv2gv;
8866             UNOP *refgen, *rv2cv;
8867             LISTOP *exlist;
8868
8869             if ((o->op_flags & OPf_WANT) != OPf_WANT_VOID)
8870                 break;
8871
8872             if ((o->op_private & ~OPpASSIGN_BACKWARDS) != 2)
8873                 break;
8874
8875             rv2gv = ((BINOP *)o)->op_last;
8876             if (!rv2gv || rv2gv->op_type != OP_RV2GV)
8877                 break;
8878
8879             refgen = (UNOP *)((BINOP *)o)->op_first;
8880
8881             if (!refgen || refgen->op_type != OP_REFGEN)
8882                 break;
8883
8884             exlist = (LISTOP *)refgen->op_first;
8885             if (!exlist || exlist->op_type != OP_NULL
8886                 || exlist->op_targ != OP_LIST)
8887                 break;
8888
8889             if (exlist->op_first->op_type != OP_PUSHMARK)
8890                 break;
8891
8892             rv2cv = (UNOP*)exlist->op_last;
8893
8894             if (rv2cv->op_type != OP_RV2CV)
8895                 break;
8896
8897             assert ((rv2gv->op_private & OPpDONT_INIT_GV) == 0);
8898             assert ((o->op_private & OPpASSIGN_CV_TO_GV) == 0);
8899             assert ((rv2cv->op_private & OPpMAY_RETURN_CONSTANT) == 0);
8900
8901             o->op_private |= OPpASSIGN_CV_TO_GV;
8902             rv2gv->op_private |= OPpDONT_INIT_GV;
8903             rv2cv->op_private |= OPpMAY_RETURN_CONSTANT;
8904
8905             break;
8906         }
8907
8908         
8909         case OP_QR:
8910         case OP_MATCH:
8911             if (!(cPMOP->op_pmflags & PMf_ONCE)) {
8912                 assert (!cPMOP->op_pmstashstartu.op_pmreplstart);
8913             }
8914             break;
8915         }
8916         oldop = o;
8917     }
8918     LEAVE;
8919 }
8920
8921 const char*
8922 Perl_custom_op_name(pTHX_ const OP* o)
8923 {
8924     dVAR;
8925     const IV index = PTR2IV(o->op_ppaddr);
8926     SV* keysv;
8927     HE* he;
8928
8929     PERL_ARGS_ASSERT_CUSTOM_OP_NAME;
8930
8931     if (!PL_custom_op_names) /* This probably shouldn't happen */
8932         return (char *)PL_op_name[OP_CUSTOM];
8933
8934     keysv = sv_2mortal(newSViv(index));
8935
8936     he = hv_fetch_ent(PL_custom_op_names, keysv, 0, 0);
8937     if (!he)
8938         return (char *)PL_op_name[OP_CUSTOM]; /* Don't know who you are */
8939
8940     return SvPV_nolen(HeVAL(he));
8941 }
8942
8943 const char*
8944 Perl_custom_op_desc(pTHX_ const OP* o)
8945 {
8946     dVAR;
8947     const IV index = PTR2IV(o->op_ppaddr);
8948     SV* keysv;
8949     HE* he;
8950
8951     PERL_ARGS_ASSERT_CUSTOM_OP_DESC;
8952
8953     if (!PL_custom_op_descs)
8954         return (char *)PL_op_desc[OP_CUSTOM];
8955
8956     keysv = sv_2mortal(newSViv(index));
8957
8958     he = hv_fetch_ent(PL_custom_op_descs, keysv, 0, 0);
8959     if (!he)
8960         return (char *)PL_op_desc[OP_CUSTOM];
8961
8962     return SvPV_nolen(HeVAL(he));
8963 }
8964
8965 #include "XSUB.h"
8966
8967 /* Efficient sub that returns a constant scalar value. */
8968 static void
8969 const_sv_xsub(pTHX_ CV* cv)
8970 {
8971     dVAR;
8972     dXSARGS;
8973     SV *const sv = MUTABLE_SV(XSANY.any_ptr);
8974     if (items != 0) {
8975         NOOP;
8976 #if 0
8977         /* diag_listed_as: SKIPME */
8978         Perl_croak(aTHX_ "usage: %s::%s()",
8979                    HvNAME_get(GvSTASH(CvGV(cv))), GvNAME(CvGV(cv)));
8980 #endif
8981     }
8982     if (!sv) {
8983         XSRETURN(0);
8984     }
8985     EXTEND(sp, 1);
8986     ST(0) = sv;
8987     XSRETURN(1);
8988 }
8989
8990 /*
8991  * Local variables:
8992  * c-indentation-style: bsd
8993  * c-basic-offset: 4
8994  * indent-tabs-mode: t
8995  * End:
8996  *
8997  * ex: set ts=8 sts=4 sw=4 noet:
8998  */