home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / perl560.zip / op.c < prev    next >
C/C++ Source or Header  |  2000-03-20  |  163KB  |  6,724 lines

  1. /*    op.c
  2.  *
  3.  *    Copyright (c) 1991-2000, Larry Wall
  4.  *
  5.  *    You may distribute under the terms of either the GNU General Public
  6.  *    License or the Artistic License, as specified in the README file.
  7.  *
  8.  */
  9.  
  10. /*
  11.  * "You see: Mr. Drogo, he married poor Miss Primula Brandybuck.  She was
  12.  * our Mr. Bilbo's first cousin on the mother's side (her mother being the
  13.  * youngest of the Old Took's daughters); and Mr. Drogo was his second
  14.  * cousin.  So Mr. Frodo is his first *and* second cousin, once removed
  15.  * either way, as the saying is, if you follow me."  --the Gaffer
  16.  */
  17.  
  18. #include "EXTERN.h"
  19. #define PERL_IN_OP_C
  20. #include "perl.h"
  21. #include "keywords.h"
  22.  
  23. /* #define PL_OP_SLAB_ALLOC */
  24.  
  25. #ifdef PL_OP_SLAB_ALLOC 
  26. #define SLAB_SIZE 8192
  27. static char    *PL_OpPtr  = NULL;
  28. static int     PL_OpSpace = 0;
  29. #define NewOp(m,var,c,type) do { if ((PL_OpSpace -= c*sizeof(type)) >= 0)     \
  30.                               var =  (type *)(PL_OpPtr -= c*sizeof(type));    \
  31.                              else                                             \
  32.                               var = (type *) Slab_Alloc(m,c*sizeof(type));    \
  33.                            } while (0)
  34.  
  35. STATIC void *           
  36. S_Slab_Alloc(pTHX_ int m, size_t sz)
  37.  Newz(m,PL_OpPtr,SLAB_SIZE,char);
  38.  PL_OpSpace = SLAB_SIZE - sz;
  39.  return PL_OpPtr += PL_OpSpace;
  40. }
  41.  
  42. #else 
  43. #define NewOp(m, var, c, type) Newz(m, var, c, type)
  44. #endif
  45. /*
  46.  * In the following definition, the ", Nullop" is just to make the compiler
  47.  * think the expression is of the right type: croak actually does a Siglongjmp.
  48.  */
  49. #define CHECKOP(type,o) \
  50.     ((PL_op_mask && PL_op_mask[type])                    \
  51.      ? ( op_free((OP*)o),                    \
  52.      Perl_croak(aTHX_ "%s trapped by operation mask", PL_op_desc[type]),    \
  53.      Nullop )                        \
  54.      : CALL_FPTR(PL_check[type])(aTHX_ (OP*)o))
  55.  
  56. #define PAD_MAX 999999999
  57.  
  58. STATIC char*
  59. S_gv_ename(pTHX_ GV *gv)
  60. {
  61.     STRLEN n_a;
  62.     SV* tmpsv = sv_newmortal();
  63.     gv_efullname3(tmpsv, gv, Nullch);
  64.     return SvPV(tmpsv,n_a);
  65. }
  66.  
  67. STATIC OP *
  68. S_no_fh_allowed(pTHX_ OP *o)
  69. {
  70.     yyerror(Perl_form(aTHX_ "Missing comma after first argument to %s function",
  71.          PL_op_desc[o->op_type]));
  72.     return o;
  73. }
  74.  
  75. STATIC OP *
  76. S_too_few_arguments(pTHX_ OP *o, char *name)
  77. {
  78.     yyerror(Perl_form(aTHX_ "Not enough arguments for %s", name));
  79.     return o;
  80. }
  81.  
  82. STATIC OP *
  83. S_too_many_arguments(pTHX_ OP *o, char *name)
  84. {
  85.     yyerror(Perl_form(aTHX_ "Too many arguments for %s", name));
  86.     return o;
  87. }
  88.  
  89. STATIC void
  90. S_bad_type(pTHX_ I32 n, char *t, char *name, OP *kid)
  91. {
  92.     yyerror(Perl_form(aTHX_ "Type of arg %d to %s must be %s (not %s)",
  93.          (int)n, name, t, PL_op_desc[kid->op_type]));
  94. }
  95.  
  96. STATIC void
  97. S_no_bareword_allowed(pTHX_ OP *o)
  98. {
  99.     qerror(Perl_mess(aTHX_
  100.              "Bareword \"%s\" not allowed while \"strict subs\" in use",
  101.              SvPV_nolen(cSVOPo_sv)));
  102. }
  103.  
  104. /* "register" allocation */
  105.  
  106. PADOFFSET
  107. Perl_pad_allocmy(pTHX_ char *name)
  108. {
  109.     dTHR;
  110.     PADOFFSET off;
  111.     SV *sv;
  112.  
  113.     if (!(PL_in_my == KEY_our ||
  114.       isALPHA(name[1]) ||
  115.       (PL_hints & HINT_UTF8 && (name[1] & 0xc0) == 0xc0) ||
  116.       (name[1] == '_' && (int)strlen(name) > 2)))
  117.     {
  118.     if (!isPRINT(name[1]) || strchr("\t\n\r\f", name[1])) {
  119.         /* 1999-02-27 mjd@plover.com */
  120.         char *p;
  121.         p = strchr(name, '\0');
  122.         /* The next block assumes the buffer is at least 205 chars
  123.            long.  At present, it's always at least 256 chars. */
  124.         if (p-name > 200) {
  125.         strcpy(name+200, "...");
  126.         p = name+199;
  127.         }
  128.         else {
  129.         p[1] = '\0';
  130.         }
  131.         /* Move everything else down one character */
  132.         for (; p-name > 2; p--)
  133.         *p = *(p-1);
  134.         name[2] = toCTRL(name[1]);
  135.         name[1] = '^';
  136.     }
  137.     yyerror(Perl_form(aTHX_ "Can't use global %s in \"my\"",name));
  138.     }
  139.     if (ckWARN(WARN_MISC) && AvFILLp(PL_comppad_name) >= 0) {
  140.     SV **svp = AvARRAY(PL_comppad_name);
  141.     HV *ourstash = (PL_curstash ? PL_curstash : PL_defstash);
  142.     PADOFFSET top = AvFILLp(PL_comppad_name);
  143.     for (off = top; off > PL_comppad_name_floor; off--) {
  144.         if ((sv = svp[off])
  145.         && sv != &PL_sv_undef
  146.         && (SvIVX(sv) == PAD_MAX || SvIVX(sv) == 0)
  147.         && (PL_in_my != KEY_our
  148.             || ((SvFLAGS(sv) & SVpad_OUR) && GvSTASH(sv) == ourstash))
  149.         && strEQ(name, SvPVX(sv)))
  150.         {
  151.         Perl_warner(aTHX_ WARN_MISC,
  152.             "\"%s\" variable %s masks earlier declaration in same %s", 
  153.             (PL_in_my == KEY_our ? "our" : "my"),
  154.             name,
  155.             (SvIVX(sv) == PAD_MAX ? "scope" : "statement"));
  156.         --off;
  157.         break;
  158.         }
  159.     }
  160.     if (PL_in_my == KEY_our) {
  161.         do {
  162.         if ((sv = svp[off])
  163.             && sv != &PL_sv_undef
  164.             && ((SvFLAGS(sv) & SVpad_OUR) && GvSTASH(sv) == ourstash)
  165.             && strEQ(name, SvPVX(sv)))
  166.         {
  167.             Perl_warner(aTHX_ WARN_MISC,
  168.             "\"our\" variable %s redeclared", name);
  169.             Perl_warner(aTHX_ WARN_MISC,
  170.             "\t(Did you mean \"local\" instead of \"our\"?)\n");
  171.             break;
  172.         }
  173.         } while ( off-- > 0 );
  174.     }
  175.     }
  176.     off = pad_alloc(OP_PADSV, SVs_PADMY);
  177.     sv = NEWSV(1102,0);
  178.     sv_upgrade(sv, SVt_PVNV);
  179.     sv_setpv(sv, name);
  180.     if (PL_in_my_stash) {
  181.     if (*name != '$')
  182.         yyerror(Perl_form(aTHX_ "Can't declare class for non-scalar %s in \"%s\"",
  183.              name, PL_in_my == KEY_our ? "our" : "my"));
  184.     SvOBJECT_on(sv);
  185.     (void)SvUPGRADE(sv, SVt_PVMG);
  186.     SvSTASH(sv) = (HV*)SvREFCNT_inc(PL_in_my_stash);
  187.     PL_sv_objcount++;
  188.     }
  189.     if (PL_in_my == KEY_our) {
  190.     (void)SvUPGRADE(sv, SVt_PVGV);
  191.     GvSTASH(sv) = (HV*)SvREFCNT_inc(PL_curstash ? (SV*)PL_curstash : (SV*)PL_defstash);
  192.     SvFLAGS(sv) |= SVpad_OUR;
  193.     }
  194.     av_store(PL_comppad_name, off, sv);
  195.     SvNVX(sv) = (NV)PAD_MAX;
  196.     SvIVX(sv) = 0;            /* Not yet introduced--see newSTATEOP */
  197.     if (!PL_min_intro_pending)
  198.     PL_min_intro_pending = off;
  199.     PL_max_intro_pending = off;
  200.     if (*name == '@')
  201.     av_store(PL_comppad, off, (SV*)newAV());
  202.     else if (*name == '%')
  203.     av_store(PL_comppad, off, (SV*)newHV());
  204.     SvPADMY_on(PL_curpad[off]);
  205.     return off;
  206. }
  207.  
  208. STATIC PADOFFSET
  209. S_pad_addlex(pTHX_ SV *proto_namesv)
  210. {
  211.     SV *namesv = NEWSV(1103,0);
  212.     PADOFFSET newoff = pad_alloc(OP_PADSV, SVs_PADMY);
  213.     sv_upgrade(namesv, SVt_PVNV);
  214.     sv_setpv(namesv, SvPVX(proto_namesv));
  215.     av_store(PL_comppad_name, newoff, namesv);
  216.     SvNVX(namesv) = (NV)PL_curcop->cop_seq;
  217.     SvIVX(namesv) = PAD_MAX;            /* A ref, intro immediately */
  218.     SvFAKE_on(namesv);                /* A ref, not a real var */
  219.     if (SvFLAGS(proto_namesv) & SVpad_OUR) {    /* An "our" variable */
  220.     SvFLAGS(namesv) |= SVpad_OUR;
  221.     (void)SvUPGRADE(namesv, SVt_PVGV);
  222.     GvSTASH(namesv) = (HV*)SvREFCNT_inc((SV*)GvSTASH(proto_namesv));
  223.     }
  224.     if (SvOBJECT(proto_namesv)) {        /* A typed var */
  225.     SvOBJECT_on(namesv);
  226.     (void)SvUPGRADE(namesv, SVt_PVMG);
  227.     SvSTASH(namesv) = (HV*)SvREFCNT_inc((SV*)SvSTASH(proto_namesv));
  228.     PL_sv_objcount++;
  229.     }
  230.     return newoff;
  231. }
  232.  
  233. #define FINDLEX_NOSEARCH    1        /* don't search outer contexts */
  234.  
  235. STATIC PADOFFSET
  236. S_pad_findlex(pTHX_ char *name, PADOFFSET newoff, U32 seq, CV* startcv,
  237.         I32 cx_ix, I32 saweval, U32 flags)
  238. {
  239.     dTHR;
  240.     CV *cv;
  241.     I32 off;
  242.     SV *sv;
  243.     register I32 i;
  244.     register PERL_CONTEXT *cx;
  245.  
  246.     for (cv = startcv; cv; cv = CvOUTSIDE(cv)) {
  247.     AV *curlist = CvPADLIST(cv);
  248.     SV **svp = av_fetch(curlist, 0, FALSE);
  249.     AV *curname;
  250.  
  251.     if (!svp || *svp == &PL_sv_undef)
  252.         continue;
  253.     curname = (AV*)*svp;
  254.     svp = AvARRAY(curname);
  255.     for (off = AvFILLp(curname); off > 0; off--) {
  256.         if ((sv = svp[off]) &&
  257.         sv != &PL_sv_undef &&
  258.         seq <= SvIVX(sv) &&
  259.         seq > I_32(SvNVX(sv)) &&
  260.         strEQ(SvPVX(sv), name))
  261.         {
  262.         I32 depth;
  263.         AV *oldpad;
  264.         SV *oldsv;
  265.  
  266.         depth = CvDEPTH(cv);
  267.         if (!depth) {
  268.             if (newoff) {
  269.             if (SvFAKE(sv))
  270.                 continue;
  271.             return 0; /* don't clone from inactive stack frame */
  272.             }
  273.             depth = 1;
  274.         }
  275.         oldpad = (AV*)AvARRAY(curlist)[depth];
  276.         oldsv = *av_fetch(oldpad, off, TRUE);
  277.         if (!newoff) {        /* Not a mere clone operation. */
  278.             newoff = pad_addlex(sv);
  279.             if (CvANON(PL_compcv) || SvTYPE(PL_compcv) == SVt_PVFM) {
  280.             /* "It's closures all the way down." */
  281.             CvCLONE_on(PL_compcv);
  282.             if (cv == startcv) {
  283.                 if (CvANON(PL_compcv))
  284.                 oldsv = Nullsv; /* no need to keep ref */
  285.             }
  286.             else {
  287.                 CV *bcv;
  288.                 for (bcv = startcv;
  289.                  bcv && bcv != cv && !CvCLONE(bcv);
  290.                  bcv = CvOUTSIDE(bcv))
  291.                 {
  292.                 if (CvANON(bcv)) {
  293.                     /* install the missing pad entry in intervening
  294.                      * nested subs and mark them cloneable.
  295.                      * XXX fix pad_foo() to not use globals */
  296.                     AV *ocomppad_name = PL_comppad_name;
  297.                     AV *ocomppad = PL_comppad;
  298.                     SV **ocurpad = PL_curpad;
  299.                     AV *padlist = CvPADLIST(bcv);
  300.                     PL_comppad_name = (AV*)AvARRAY(padlist)[0];
  301.                     PL_comppad = (AV*)AvARRAY(padlist)[1];
  302.                     PL_curpad = AvARRAY(PL_comppad);
  303.                     pad_addlex(sv);
  304.                     PL_comppad_name = ocomppad_name;
  305.                     PL_comppad = ocomppad;
  306.                     PL_curpad = ocurpad;
  307.                     CvCLONE_on(bcv);
  308.                 }
  309.                 else {
  310.                     if (ckWARN(WARN_CLOSURE)
  311.                     && !CvUNIQUE(bcv) && !CvUNIQUE(cv))
  312.                     {
  313.                     Perl_warner(aTHX_ WARN_CLOSURE,
  314.                       "Variable \"%s\" may be unavailable",
  315.                          name);
  316.                     }
  317.                     break;
  318.                 }
  319.                 }
  320.             }
  321.             }
  322.             else if (!CvUNIQUE(PL_compcv)) {
  323.             if (ckWARN(WARN_CLOSURE) && !SvFAKE(sv) && !CvUNIQUE(cv))
  324.                 Perl_warner(aTHX_ WARN_CLOSURE,
  325.                 "Variable \"%s\" will not stay shared", name);
  326.             }
  327.         }
  328.         av_store(PL_comppad, newoff, SvREFCNT_inc(oldsv));
  329.         return newoff;
  330.         }
  331.     }
  332.     }
  333.  
  334.     if (flags & FINDLEX_NOSEARCH)
  335.     return 0;
  336.  
  337.     /* Nothing in current lexical context--try eval's context, if any.
  338.      * This is necessary to let the perldb get at lexically scoped variables.
  339.      * XXX This will also probably interact badly with eval tree caching.
  340.      */
  341.  
  342.     for (i = cx_ix; i >= 0; i--) {
  343.     cx = &cxstack[i];
  344.     switch (CxTYPE(cx)) {
  345.     default:
  346.         if (i == 0 && saweval) {
  347.         seq = cxstack[saweval].blk_oldcop->cop_seq;
  348.         return pad_findlex(name, newoff, seq, PL_main_cv, -1, saweval, 0);
  349.         }
  350.         break;
  351.     case CXt_EVAL:
  352.         switch (cx->blk_eval.old_op_type) {
  353.         case OP_ENTEREVAL:
  354.         if (CxREALEVAL(cx))
  355.             saweval = i;
  356.         break;
  357.         case OP_DOFILE:
  358.         case OP_REQUIRE:
  359.         /* require/do must have their own scope */
  360.         return 0;
  361.         }
  362.         break;
  363.     case CXt_FORMAT:
  364.     case CXt_SUB:
  365.         if (!saweval)
  366.         return 0;
  367.         cv = cx->blk_sub.cv;
  368.         if (PL_debstash && CvSTASH(cv) == PL_debstash) {    /* ignore DB'* scope */
  369.         saweval = i;    /* so we know where we were called from */
  370.         continue;
  371.         }
  372.         seq = cxstack[saweval].blk_oldcop->cop_seq;
  373.         return pad_findlex(name, newoff, seq, cv, i-1, saweval,FINDLEX_NOSEARCH);
  374.     }
  375.     }
  376.  
  377.     return 0;
  378. }
  379.  
  380. PADOFFSET
  381. Perl_pad_findmy(pTHX_ char *name)
  382. {
  383.     dTHR;
  384.     I32 off;
  385.     I32 pendoff = 0;
  386.     SV *sv;
  387.     SV **svp = AvARRAY(PL_comppad_name);
  388.     U32 seq = PL_cop_seqmax;
  389.     PERL_CONTEXT *cx;
  390.     CV *outside;
  391.  
  392. #ifdef USE_THREADS
  393.     /*
  394.      * Special case to get lexical (and hence per-thread) @_.
  395.      * XXX I need to find out how to tell at parse-time whether use
  396.      * of @_ should refer to a lexical (from a sub) or defgv (global
  397.      * scope and maybe weird sub-ish things like formats). See
  398.      * startsub in perly.y.  It's possible that @_ could be lexical
  399.      * (at least from subs) even in non-threaded perl.
  400.      */
  401.     if (strEQ(name, "@_"))
  402.     return 0;        /* success. (NOT_IN_PAD indicates failure) */
  403. #endif /* USE_THREADS */
  404.  
  405.     /* The one we're looking for is probably just before comppad_name_fill. */
  406.     for (off = AvFILLp(PL_comppad_name); off > 0; off--) {
  407.     if ((sv = svp[off]) &&
  408.         sv != &PL_sv_undef &&
  409.         (!SvIVX(sv) ||
  410.          (seq <= SvIVX(sv) &&
  411.           seq > I_32(SvNVX(sv)))) &&
  412.         strEQ(SvPVX(sv), name))
  413.     {
  414.         if (SvIVX(sv) || SvFLAGS(sv) & SVpad_OUR)
  415.         return (PADOFFSET)off;
  416.         pendoff = off;    /* this pending def. will override import */
  417.     }
  418.     }
  419.  
  420.     outside = CvOUTSIDE(PL_compcv);
  421.  
  422.     /* Check if if we're compiling an eval'', and adjust seq to be the
  423.      * eval's seq number.  This depends on eval'' having a non-null
  424.      * CvOUTSIDE() while it is being compiled.  The eval'' itself is
  425.      * identified by CvEVAL being true and CvGV being null. */
  426.     if (outside && CvEVAL(PL_compcv) && !CvGV(PL_compcv) && cxstack_ix >= 0) {
  427.     cx = &cxstack[cxstack_ix];
  428.     if (CxREALEVAL(cx))
  429.         seq = cx->blk_oldcop->cop_seq;
  430.     }
  431.  
  432.     /* See if it's in a nested scope */
  433.     off = pad_findlex(name, 0, seq, outside, cxstack_ix, 0, 0);
  434.     if (off) {
  435.     /* If there is a pending local definition, this new alias must die */
  436.     if (pendoff)
  437.         SvIVX(AvARRAY(PL_comppad_name)[off]) = seq;
  438.     return off;        /* pad_findlex returns 0 for failure...*/
  439.     }
  440.     return NOT_IN_PAD;        /* ...but we return NOT_IN_PAD for failure */
  441. }
  442.  
  443. void
  444. Perl_pad_leavemy(pTHX_ I32 fill)
  445. {
  446.     dTHR;
  447.     I32 off;
  448.     SV **svp = AvARRAY(PL_comppad_name);
  449.     SV *sv;
  450.     if (PL_min_intro_pending && fill < PL_min_intro_pending) {
  451.     for (off = PL_max_intro_pending; off >= PL_min_intro_pending; off--) {
  452.         if ((sv = svp[off]) && sv != &PL_sv_undef && ckWARN_d(WARN_INTERNAL))
  453.         Perl_warner(aTHX_ WARN_INTERNAL, "%s never introduced", SvPVX(sv));
  454.     }
  455.     }
  456.     /* "Deintroduce" my variables that are leaving with this scope. */
  457.     for (off = AvFILLp(PL_comppad_name); off > fill; off--) {
  458.     if ((sv = svp[off]) && sv != &PL_sv_undef && SvIVX(sv) == PAD_MAX)
  459.         SvIVX(sv) = PL_cop_seqmax;
  460.     }
  461. }
  462.  
  463. PADOFFSET
  464. Perl_pad_alloc(pTHX_ I32 optype, U32 tmptype)
  465. {
  466.     dTHR;
  467.     SV *sv;
  468.     I32 retval;
  469.  
  470.     if (AvARRAY(PL_comppad) != PL_curpad)
  471.     Perl_croak(aTHX_ "panic: pad_alloc");
  472.     if (PL_pad_reset_pending)
  473.     pad_reset();
  474.     if (tmptype & SVs_PADMY) {
  475.     do {
  476.         sv = *av_fetch(PL_comppad, AvFILLp(PL_comppad) + 1, TRUE);
  477.     } while (SvPADBUSY(sv));        /* need a fresh one */
  478.     retval = AvFILLp(PL_comppad);
  479.     }
  480.     else {
  481.     SV **names = AvARRAY(PL_comppad_name);
  482.     SSize_t names_fill = AvFILLp(PL_comppad_name);
  483.     for (;;) {
  484.         /*
  485.          * "foreach" index vars temporarily become aliases to non-"my"
  486.          * values.  Thus we must skip, not just pad values that are
  487.          * marked as current pad values, but also those with names.
  488.          */
  489.         if (++PL_padix <= names_fill &&
  490.            (sv = names[PL_padix]) && sv != &PL_sv_undef)
  491.         continue;
  492.         sv = *av_fetch(PL_comppad, PL_padix, TRUE);
  493.         if (!(SvFLAGS(sv) & (SVs_PADTMP|SVs_PADMY)) && !IS_PADGV(sv))
  494.         break;
  495.     }
  496.     retval = PL_padix;
  497.     }
  498.     SvFLAGS(sv) |= tmptype;
  499.     PL_curpad = AvARRAY(PL_comppad);
  500. #ifdef USE_THREADS
  501.     DEBUG_X(PerlIO_printf(Perl_debug_log,
  502.               "0x%"UVxf" Pad 0x%"UVxf" alloc %ld for %s\n",
  503.               PTR2UV(thr), PTR2UV(PL_curpad),
  504.               (long) retval, PL_op_name[optype]));
  505. #else
  506.     DEBUG_X(PerlIO_printf(Perl_debug_log,
  507.               "Pad 0x%"UVxf" alloc %ld for %s\n",
  508.               PTR2UV(PL_curpad),
  509.               (long) retval, PL_op_name[optype]));
  510. #endif /* USE_THREADS */
  511.     return (PADOFFSET)retval;
  512. }
  513.  
  514. SV *
  515. Perl_pad_sv(pTHX_ PADOFFSET po)
  516. {
  517.     dTHR;
  518. #ifdef USE_THREADS
  519.     DEBUG_X(PerlIO_printf(Perl_debug_log,
  520.               "0x%"UVxf" Pad 0x%"UVxf" sv %"IVdf"\n",
  521.               PTR2UV(thr), PTR2UV(PL_curpad), (IV)po));
  522. #else
  523.     if (!po)
  524.     Perl_croak(aTHX_ "panic: pad_sv po");
  525.     DEBUG_X(PerlIO_printf(Perl_debug_log, "Pad 0x%"UVxf" sv %"IVdf"\n",
  526.               PTR2UV(PL_curpad), (IV)po));
  527. #endif /* USE_THREADS */
  528.     return PL_curpad[po];        /* eventually we'll turn this into a macro */
  529. }
  530.  
  531. void
  532. Perl_pad_free(pTHX_ PADOFFSET po)
  533. {
  534.     dTHR;
  535.     if (!PL_curpad)
  536.     return;
  537.     if (AvARRAY(PL_comppad) != PL_curpad)
  538.     Perl_croak(aTHX_ "panic: pad_free curpad");
  539.     if (!po)
  540.     Perl_croak(aTHX_ "panic: pad_free po");
  541. #ifdef USE_THREADS
  542.     DEBUG_X(PerlIO_printf(Perl_debug_log,
  543.               "0x%"UVxf" Pad 0x%"UVxf" free %"IVdf"\n",
  544.               PTR2UV(thr), PTR2UV(PL_curpad), (IV)po));
  545. #else
  546.     DEBUG_X(PerlIO_printf(Perl_debug_log, "Pad 0x%"UVxf" free %"IVdf"\n",
  547.               PTR2UV(PL_curpad), (IV)po));
  548. #endif /* USE_THREADS */
  549.     if (PL_curpad[po] && PL_curpad[po] != &PL_sv_undef) {
  550.     SvPADTMP_off(PL_curpad[po]);
  551. #ifdef USE_ITHREADS
  552.     SvREADONLY_off(PL_curpad[po]);    /* could be a freed constant */
  553. #endif
  554.     }
  555.     if ((I32)po < PL_padix)
  556.     PL_padix = po - 1;
  557. }
  558.  
  559. void
  560. Perl_pad_swipe(pTHX_ PADOFFSET po)
  561. {
  562.     dTHR;
  563.     if (AvARRAY(PL_comppad) != PL_curpad)
  564.     Perl_croak(aTHX_ "panic: pad_swipe curpad");
  565.     if (!po)
  566.     Perl_croak(aTHX_ "panic: pad_swipe po");
  567. #ifdef USE_THREADS
  568.     DEBUG_X(PerlIO_printf(Perl_debug_log,
  569.               "0x%"UVxf" Pad 0x%"UVxf" swipe %"IVdf"\n",
  570.               PTR2UV(thr), PTR2UV(PL_curpad), (IV)po));
  571. #else
  572.     DEBUG_X(PerlIO_printf(Perl_debug_log, "Pad 0x%"UVxf" swipe %"IVdf"\n",
  573.               PTR2UV(PL_curpad), (IV)po));
  574. #endif /* USE_THREADS */
  575.     SvPADTMP_off(PL_curpad[po]);
  576.     PL_curpad[po] = NEWSV(1107,0);
  577.     SvPADTMP_on(PL_curpad[po]);
  578.     if ((I32)po < PL_padix)
  579.     PL_padix = po - 1;
  580. }
  581.  
  582. /* XXX pad_reset() is currently disabled because it results in serious bugs.
  583.  * It causes pad temp TARGs to be shared between OPs. Since TARGs are pushed
  584.  * on the stack by OPs that use them, there are several ways to get an alias
  585.  * to  a shared TARG.  Such an alias will change randomly and unpredictably.
  586.  * We avoid doing this until we can think of a Better Way.
  587.  * GSAR 97-10-29 */
  588. void
  589. Perl_pad_reset(pTHX)
  590. {
  591. #ifdef USE_BROKEN_PAD_RESET
  592.     dTHR;
  593.     register I32 po;
  594.  
  595.     if (AvARRAY(PL_comppad) != PL_curpad)
  596.     Perl_croak(aTHX_ "panic: pad_reset curpad");
  597. #ifdef USE_THREADS
  598.     DEBUG_X(PerlIO_printf(Perl_debug_log,
  599.               "0x%"UVxf" Pad 0x%"UVxf" reset\n",
  600.               PTR2UV(thr), PTR2UV(PL_curpad)));
  601. #else
  602.     DEBUG_X(PerlIO_printf(Perl_debug_log, "Pad 0x%"UVxf" reset\n",
  603.               PTR2UV(PL_curpad)));
  604. #endif /* USE_THREADS */
  605.     if (!PL_tainting) {    /* Can't mix tainted and non-tainted temporaries. */
  606.     for (po = AvMAX(PL_comppad); po > PL_padix_floor; po--) {
  607.         if (PL_curpad[po] && !SvIMMORTAL(PL_curpad[po]))
  608.         SvPADTMP_off(PL_curpad[po]);
  609.     }
  610.     PL_padix = PL_padix_floor;
  611.     }
  612. #endif
  613.     PL_pad_reset_pending = FALSE;
  614. }
  615.  
  616. #ifdef USE_THREADS
  617. /* find_threadsv is not reentrant */
  618. PADOFFSET
  619. Perl_find_threadsv(pTHX_ const char *name)
  620. {
  621.     dTHR;
  622.     char *p;
  623.     PADOFFSET key;
  624.     SV **svp;
  625.     /* We currently only handle names of a single character */
  626.     p = strchr(PL_threadsv_names, *name);
  627.     if (!p)
  628.     return NOT_IN_PAD;
  629.     key = p - PL_threadsv_names;
  630.     MUTEX_LOCK(&thr->mutex);
  631.     svp = av_fetch(thr->threadsv, key, FALSE);
  632.     if (svp)
  633.     MUTEX_UNLOCK(&thr->mutex);
  634.     else {
  635.     SV *sv = NEWSV(0, 0);
  636.     av_store(thr->threadsv, key, sv);
  637.     thr->threadsvp = AvARRAY(thr->threadsv);
  638.     MUTEX_UNLOCK(&thr->mutex);
  639.     /*
  640.      * Some magic variables used to be automagically initialised
  641.      * in gv_fetchpv. Those which are now per-thread magicals get
  642.      * initialised here instead.
  643.      */
  644.     switch (*name) {
  645.     case '_':
  646.         break;
  647.     case ';':
  648.         sv_setpv(sv, "\034");
  649.         sv_magic(sv, 0, 0, name, 1); 
  650.         break;
  651.     case '&':
  652.     case '`':
  653.     case '\'':
  654.         PL_sawampersand = TRUE;
  655.         /* FALL THROUGH */
  656.     case '1':
  657.     case '2':
  658.     case '3':
  659.     case '4':
  660.     case '5':
  661.     case '6':
  662.     case '7':
  663.     case '8':
  664.     case '9':
  665.         SvREADONLY_on(sv);
  666.         /* FALL THROUGH */
  667.  
  668.     /* XXX %! tied to Errno.pm needs to be added here.
  669.      * See gv_fetchpv(). */
  670.     /* case '!': */
  671.  
  672.     default:
  673.         sv_magic(sv, 0, 0, name, 1); 
  674.     }
  675.     DEBUG_S(PerlIO_printf(Perl_error_log,
  676.                   "find_threadsv: new SV %p for $%s%c\n",
  677.                   sv, (*name < 32) ? "^" : "",
  678.                   (*name < 32) ? toCTRL(*name) : *name));
  679.     }
  680.     return key;
  681. }
  682. #endif /* USE_THREADS */
  683.  
  684. /* Destructor */
  685.  
  686. void
  687. Perl_op_free(pTHX_ OP *o)
  688. {
  689.     register OP *kid, *nextkid;
  690.     OPCODE type;
  691.  
  692.     if (!o || o->op_seq == (U16)-1)
  693.     return;
  694.  
  695.     if (o->op_private & OPpREFCOUNTED) {
  696.     switch (o->op_type) {
  697.     case OP_LEAVESUB:
  698.     case OP_LEAVESUBLV:
  699.     case OP_LEAVEEVAL:
  700.     case OP_LEAVE:
  701.     case OP_SCOPE:
  702.     case OP_LEAVEWRITE:
  703.         OP_REFCNT_LOCK;
  704.         if (OpREFCNT_dec(o)) {
  705.         OP_REFCNT_UNLOCK;
  706.         return;
  707.         }
  708.         OP_REFCNT_UNLOCK;
  709.         break;
  710.     default:
  711.         break;
  712.     }
  713.     }
  714.  
  715.     if (o->op_flags & OPf_KIDS) {
  716.     for (kid = cUNOPo->op_first; kid; kid = nextkid) {
  717.         nextkid = kid->op_sibling; /* Get before next freeing kid */
  718.         op_free(kid);
  719.     }
  720.     }
  721.     type = o->op_type;
  722.     if (type == OP_NULL)
  723.     type = o->op_targ;
  724.  
  725.     /* COP* is not cleared by op_clear() so that we may track line
  726.      * numbers etc even after null() */
  727.     if (type == OP_NEXTSTATE || type == OP_SETSTATE || type == OP_DBSTATE)
  728.     cop_free((COP*)o);
  729.  
  730.     op_clear(o);
  731.  
  732. #ifdef PL_OP_SLAB_ALLOC
  733.     if ((char *) o == PL_OpPtr)
  734.      {
  735.      }
  736. #else
  737.     Safefree(o);
  738. #endif
  739. }
  740.  
  741. STATIC void
  742. S_op_clear(pTHX_ OP *o)
  743. {
  744.     switch (o->op_type) {
  745.     case OP_NULL:    /* Was holding old type, if any. */
  746.     case OP_ENTEREVAL:    /* Was holding hints. */
  747. #ifdef USE_THREADS
  748.     case OP_THREADSV:    /* Was holding index into thr->threadsv AV. */
  749. #endif
  750.     o->op_targ = 0;
  751.     break;
  752. #ifdef USE_THREADS
  753.     case OP_ENTERITER:
  754.     if (!(o->op_flags & OPf_SPECIAL))
  755.         break;
  756.     /* FALL THROUGH */
  757. #endif /* USE_THREADS */
  758.     default:
  759.     if (!(o->op_flags & OPf_REF)
  760.         || (PL_check[o->op_type] != MEMBER_TO_FPTR(Perl_ck_ftst)))
  761.         break;
  762.     /* FALL THROUGH */
  763.     case OP_GVSV:
  764.     case OP_GV:
  765.     case OP_AELEMFAST:
  766. #ifdef USE_ITHREADS
  767.     if (cPADOPo->op_padix > 0) {
  768.         if (PL_curpad) {
  769.         GV *gv = cGVOPo_gv;
  770.         pad_swipe(cPADOPo->op_padix);
  771.         /* No GvIN_PAD_off(gv) here, because other references may still
  772.          * exist on the pad */
  773.         SvREFCNT_dec(gv);
  774.         }
  775.         cPADOPo->op_padix = 0;
  776.     }
  777. #else
  778.     SvREFCNT_dec(cSVOPo->op_sv);
  779.     cSVOPo->op_sv = Nullsv;
  780. #endif
  781.     break;
  782.     case OP_CONST:
  783.     SvREFCNT_dec(cSVOPo->op_sv);
  784.     cSVOPo->op_sv = Nullsv;
  785.     break;
  786.     case OP_GOTO:
  787.     case OP_NEXT:
  788.     case OP_LAST:
  789.     case OP_REDO:
  790.     if (o->op_flags & (OPf_SPECIAL|OPf_STACKED|OPf_KIDS))
  791.         break;
  792.     /* FALL THROUGH */
  793.     case OP_TRANS:
  794.     if (o->op_private & (OPpTRANS_FROM_UTF|OPpTRANS_TO_UTF)) {
  795.         SvREFCNT_dec(cSVOPo->op_sv);
  796.         cSVOPo->op_sv = Nullsv;
  797.     }
  798.     else {
  799.         Safefree(cPVOPo->op_pv);
  800.         cPVOPo->op_pv = Nullch;
  801.     }
  802.     break;
  803.     case OP_SUBST:
  804.     op_free(cPMOPo->op_pmreplroot);
  805.     goto clear_pmop;
  806.     case OP_PUSHRE:
  807. #ifdef USE_ITHREADS
  808.     if ((PADOFFSET)cPMOPo->op_pmreplroot) {
  809.         if (PL_curpad) {
  810.         GV *gv = (GV*)PL_curpad[(PADOFFSET)cPMOPo->op_pmreplroot];
  811.         pad_swipe((PADOFFSET)cPMOPo->op_pmreplroot);
  812.         /* No GvIN_PAD_off(gv) here, because other references may still
  813.          * exist on the pad */
  814.         SvREFCNT_dec(gv);
  815.         }
  816.     }
  817. #else
  818.     SvREFCNT_dec((SV*)cPMOPo->op_pmreplroot);
  819. #endif
  820.     /* FALL THROUGH */
  821.     case OP_MATCH:
  822.     case OP_QR:
  823. clear_pmop:
  824.     cPMOPo->op_pmreplroot = Nullop;
  825.     ReREFCNT_dec(cPMOPo->op_pmregexp);
  826.     cPMOPo->op_pmregexp = (REGEXP*)NULL;
  827.     break;
  828.     }
  829.  
  830.     if (o->op_targ > 0) {
  831.     pad_free(o->op_targ);
  832.     o->op_targ = 0;
  833.     }
  834. }
  835.  
  836. STATIC void
  837. S_cop_free(pTHX_ COP* cop)
  838. {
  839.     Safefree(cop->cop_label);
  840. #ifdef USE_ITHREADS
  841.     Safefree(CopFILE(cop));        /* XXXXX share in a pvtable? */
  842.     Safefree(CopSTASHPV(cop));        /* XXXXX share in a pvtable? */
  843. #else
  844.     /* NOTE: COP.cop_stash is not refcounted */
  845.     SvREFCNT_dec(CopFILEGV(cop));
  846. #endif
  847.     if (! specialWARN(cop->cop_warnings))
  848.     SvREFCNT_dec(cop->cop_warnings);
  849. }
  850.  
  851. STATIC void
  852. S_null(pTHX_ OP *o)
  853. {
  854.     if (o->op_type == OP_NULL)
  855.     return;
  856.     op_clear(o);
  857.     o->op_targ = o->op_type;
  858.     o->op_type = OP_NULL;
  859.     o->op_ppaddr = PL_ppaddr[OP_NULL];
  860. }
  861.  
  862. /* Contextualizers */
  863.  
  864. #define LINKLIST(o) ((o)->op_next ? (o)->op_next : linklist((OP*)o))
  865.  
  866. OP *
  867. Perl_linklist(pTHX_ OP *o)
  868. {
  869.     register OP *kid;
  870.  
  871.     if (o->op_next)
  872.     return o->op_next;
  873.  
  874.     /* establish postfix order */
  875.     if (cUNOPo->op_first) {
  876.     o->op_next = LINKLIST(cUNOPo->op_first);
  877.     for (kid = cUNOPo->op_first; kid; kid = kid->op_sibling) {
  878.         if (kid->op_sibling)
  879.         kid->op_next = LINKLIST(kid->op_sibling);
  880.         else
  881.         kid->op_next = o;
  882.     }
  883.     }
  884.     else
  885.     o->op_next = o;
  886.  
  887.     return o->op_next;
  888. }
  889.  
  890. OP *
  891. Perl_scalarkids(pTHX_ OP *o)
  892. {
  893.     OP *kid;
  894.     if (o && o->op_flags & OPf_KIDS) {
  895.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  896.         scalar(kid);
  897.     }
  898.     return o;
  899. }
  900.  
  901. STATIC OP *
  902. S_scalarboolean(pTHX_ OP *o)
  903. {
  904.     if (o->op_type == OP_SASSIGN && cBINOPo->op_first->op_type == OP_CONST) {
  905.     dTHR;
  906.     if (ckWARN(WARN_SYNTAX)) {
  907.         line_t oldline = CopLINE(PL_curcop);
  908.  
  909.         if (PL_copline != NOLINE)
  910.         CopLINE_set(PL_curcop, PL_copline);
  911.         Perl_warner(aTHX_ WARN_SYNTAX, "Found = in conditional, should be ==");
  912.         CopLINE_set(PL_curcop, oldline);
  913.     }
  914.     }
  915.     return scalar(o);
  916. }
  917.  
  918. OP *
  919. Perl_scalar(pTHX_ OP *o)
  920. {
  921.     OP *kid;
  922.  
  923.     /* assumes no premature commitment */
  924.     if (!o || (o->op_flags & OPf_WANT) || PL_error_count
  925.      || o->op_type == OP_RETURN)
  926.     {
  927.     return o;
  928.     }
  929.  
  930.     o->op_flags = (o->op_flags & ~OPf_WANT) | OPf_WANT_SCALAR;
  931.  
  932.     switch (o->op_type) {
  933.     case OP_REPEAT:
  934.     if (o->op_private & OPpREPEAT_DOLIST)
  935.         null(((LISTOP*)cBINOPo->op_first)->op_first);
  936.     scalar(cBINOPo->op_first);
  937.     break;
  938.     case OP_OR:
  939.     case OP_AND:
  940.     case OP_COND_EXPR:
  941.     for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
  942.         scalar(kid);
  943.     break;
  944.     case OP_SPLIT:
  945.     if ((kid = cLISTOPo->op_first) && kid->op_type == OP_PUSHRE) {
  946.         if (!kPMOP->op_pmreplroot)
  947.         deprecate("implicit split to @_");
  948.     }
  949.     /* FALL THROUGH */
  950.     case OP_MATCH:
  951.     case OP_QR:
  952.     case OP_SUBST:
  953.     case OP_NULL:
  954.     default:
  955.     if (o->op_flags & OPf_KIDS) {
  956.         for (kid = cUNOPo->op_first; kid; kid = kid->op_sibling)
  957.         scalar(kid);
  958.     }
  959.     break;
  960.     case OP_LEAVE:
  961.     case OP_LEAVETRY:
  962.     kid = cLISTOPo->op_first;
  963.     scalar(kid);
  964.     while ((kid = kid->op_sibling)) {
  965.         if (kid->op_sibling)
  966.         scalarvoid(kid);
  967.         else
  968.         scalar(kid);
  969.     }
  970.     WITH_THR(PL_curcop = &PL_compiling);
  971.     break;
  972.     case OP_SCOPE:
  973.     case OP_LINESEQ:
  974.     case OP_LIST:
  975.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling) {
  976.         if (kid->op_sibling)
  977.         scalarvoid(kid);
  978.         else
  979.         scalar(kid);
  980.     }
  981.     WITH_THR(PL_curcop = &PL_compiling);
  982.     break;
  983.     }
  984.     return o;
  985. }
  986.  
  987. OP *
  988. Perl_scalarvoid(pTHX_ OP *o)
  989. {
  990.     OP *kid;
  991.     char* useless = 0;
  992.     SV* sv;
  993.     U8 want;
  994.  
  995.     if (o->op_type == OP_NEXTSTATE
  996.     || o->op_type == OP_SETSTATE
  997.     || o->op_type == OP_DBSTATE
  998.     || (o->op_type == OP_NULL && (o->op_targ == OP_NEXTSTATE
  999.                       || o->op_targ == OP_SETSTATE
  1000.                       || o->op_targ == OP_DBSTATE)))
  1001.     {
  1002.     dTHR;
  1003.     PL_curcop = (COP*)o;        /* for warning below */
  1004.     }
  1005.  
  1006.     /* assumes no premature commitment */
  1007.     want = o->op_flags & OPf_WANT;
  1008.     if ((want && want != OPf_WANT_SCALAR) || PL_error_count
  1009.      || o->op_type == OP_RETURN)
  1010.     {
  1011.     return o;
  1012.     }
  1013.  
  1014.     if ((o->op_private & OPpTARGET_MY)
  1015.     && (PL_opargs[o->op_type] & OA_TARGLEX))/* OPp share the meaning */
  1016.     {
  1017.     return scalar(o);            /* As if inside SASSIGN */
  1018.     }
  1019.     
  1020.     o->op_flags = (o->op_flags & ~OPf_WANT) | OPf_WANT_VOID;
  1021.  
  1022.     switch (o->op_type) {
  1023.     default:
  1024.     if (!(PL_opargs[o->op_type] & OA_FOLDCONST))
  1025.         break;
  1026.     /* FALL THROUGH */
  1027.     case OP_REPEAT:
  1028.     if (o->op_flags & OPf_STACKED)
  1029.         break;
  1030.     goto func_ops;
  1031.     case OP_SUBSTR:
  1032.     if (o->op_private == 4)
  1033.         break;
  1034.     /* FALL THROUGH */
  1035.     case OP_GVSV:
  1036.     case OP_WANTARRAY:
  1037.     case OP_GV:
  1038.     case OP_PADSV:
  1039.     case OP_PADAV:
  1040.     case OP_PADHV:
  1041.     case OP_PADANY:
  1042.     case OP_AV2ARYLEN:
  1043.     case OP_REF:
  1044.     case OP_REFGEN:
  1045.     case OP_SREFGEN:
  1046.     case OP_DEFINED:
  1047.     case OP_HEX:
  1048.     case OP_OCT:
  1049.     case OP_LENGTH:
  1050.     case OP_VEC:
  1051.     case OP_INDEX:
  1052.     case OP_RINDEX:
  1053.     case OP_SPRINTF:
  1054.     case OP_AELEM:
  1055.     case OP_AELEMFAST:
  1056.     case OP_ASLICE:
  1057.     case OP_HELEM:
  1058.     case OP_HSLICE:
  1059.     case OP_UNPACK:
  1060.     case OP_PACK:
  1061.     case OP_JOIN:
  1062.     case OP_LSLICE:
  1063.     case OP_ANONLIST:
  1064.     case OP_ANONHASH:
  1065.     case OP_SORT:
  1066.     case OP_REVERSE:
  1067.     case OP_RANGE:
  1068.     case OP_FLIP:
  1069.     case OP_FLOP:
  1070.     case OP_CALLER:
  1071.     case OP_FILENO:
  1072.     case OP_EOF:
  1073.     case OP_TELL:
  1074.     case OP_GETSOCKNAME:
  1075.     case OP_GETPEERNAME:
  1076.     case OP_READLINK:
  1077.     case OP_TELLDIR:
  1078.     case OP_GETPPID:
  1079.     case OP_GETPGRP:
  1080.     case OP_GETPRIORITY:
  1081.     case OP_TIME:
  1082.     case OP_TMS:
  1083.     case OP_LOCALTIME:
  1084.     case OP_GMTIME:
  1085.     case OP_GHBYNAME:
  1086.     case OP_GHBYADDR:
  1087.     case OP_GHOSTENT:
  1088.     case OP_GNBYNAME:
  1089.     case OP_GNBYADDR:
  1090.     case OP_GNETENT:
  1091.     case OP_GPBYNAME:
  1092.     case OP_GPBYNUMBER:
  1093.     case OP_GPROTOENT:
  1094.     case OP_GSBYNAME:
  1095.     case OP_GSBYPORT:
  1096.     case OP_GSERVENT:
  1097.     case OP_GPWNAM:
  1098.     case OP_GPWUID:
  1099.     case OP_GGRNAM:
  1100.     case OP_GGRGID:
  1101.     case OP_GETLOGIN:
  1102.       func_ops:
  1103.     if (!(o->op_private & (OPpLVAL_INTRO|OPpOUR_INTRO)))
  1104.         useless = PL_op_desc[o->op_type];
  1105.     break;
  1106.  
  1107.     case OP_RV2GV:
  1108.     case OP_RV2SV:
  1109.     case OP_RV2AV:
  1110.     case OP_RV2HV:
  1111.     if (!(o->op_private & (OPpLVAL_INTRO|OPpOUR_INTRO)) &&
  1112.         (!o->op_sibling || o->op_sibling->op_type != OP_READLINE))
  1113.         useless = "a variable";
  1114.     break;
  1115.  
  1116.     case OP_CONST:
  1117.     sv = cSVOPo_sv;
  1118.     if (cSVOPo->op_private & OPpCONST_STRICT)
  1119.         no_bareword_allowed(o);
  1120.     else {
  1121.         dTHR;
  1122.         if (ckWARN(WARN_VOID)) {
  1123.         useless = "a constant";
  1124.         if (SvNIOK(sv) && (SvNV(sv) == 0.0 || SvNV(sv) == 1.0))
  1125.             useless = 0;
  1126.         else if (SvPOK(sv)) {
  1127.             if (strnEQ(SvPVX(sv), "di", 2) ||
  1128.             strnEQ(SvPVX(sv), "ds", 2) ||
  1129.             strnEQ(SvPVX(sv), "ig", 2))
  1130.                 useless = 0;
  1131.         }
  1132.         }
  1133.     }
  1134.     null(o);        /* don't execute or even remember it */
  1135.     break;
  1136.  
  1137.     case OP_POSTINC:
  1138.     o->op_type = OP_PREINC;        /* pre-increment is faster */
  1139.     o->op_ppaddr = PL_ppaddr[OP_PREINC];
  1140.     break;
  1141.  
  1142.     case OP_POSTDEC:
  1143.     o->op_type = OP_PREDEC;        /* pre-decrement is faster */
  1144.     o->op_ppaddr = PL_ppaddr[OP_PREDEC];
  1145.     break;
  1146.  
  1147.     case OP_OR:
  1148.     case OP_AND:
  1149.     case OP_COND_EXPR:
  1150.     for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
  1151.         scalarvoid(kid);
  1152.     break;
  1153.  
  1154.     case OP_NULL:
  1155.     if (o->op_flags & OPf_STACKED)
  1156.         break;
  1157.     /* FALL THROUGH */
  1158.     case OP_NEXTSTATE:
  1159.     case OP_DBSTATE:
  1160.     case OP_ENTERTRY:
  1161.     case OP_ENTER:
  1162.     case OP_SCALAR:
  1163.     if (!(o->op_flags & OPf_KIDS))
  1164.         break;
  1165.     /* FALL THROUGH */
  1166.     case OP_SCOPE:
  1167.     case OP_LEAVE:
  1168.     case OP_LEAVETRY:
  1169.     case OP_LEAVELOOP:
  1170.     case OP_LINESEQ:
  1171.     case OP_LIST:
  1172.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  1173.         scalarvoid(kid);
  1174.     break;
  1175.     case OP_ENTEREVAL:
  1176.     scalarkids(o);
  1177.     break;
  1178.     case OP_REQUIRE:
  1179.     /* all requires must return a boolean value */
  1180.     o->op_flags &= ~OPf_WANT;
  1181.     return scalar(o);
  1182.     case OP_SPLIT:
  1183.     if ((kid = cLISTOPo->op_first) && kid->op_type == OP_PUSHRE) {
  1184.         if (!kPMOP->op_pmreplroot)
  1185.         deprecate("implicit split to @_");
  1186.     }
  1187.     break;
  1188.     }
  1189.     if (useless) {
  1190.     dTHR;
  1191.     if (ckWARN(WARN_VOID))
  1192.         Perl_warner(aTHX_ WARN_VOID, "Useless use of %s in void context", useless);
  1193.     }
  1194.     return o;
  1195. }
  1196.  
  1197. OP *
  1198. Perl_listkids(pTHX_ OP *o)
  1199. {
  1200.     OP *kid;
  1201.     if (o && o->op_flags & OPf_KIDS) {
  1202.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  1203.         list(kid);
  1204.     }
  1205.     return o;
  1206. }
  1207.  
  1208. OP *
  1209. Perl_list(pTHX_ OP *o)
  1210. {
  1211.     OP *kid;
  1212.  
  1213.     /* assumes no premature commitment */
  1214.     if (!o || (o->op_flags & OPf_WANT) || PL_error_count
  1215.      || o->op_type == OP_RETURN)
  1216.     {
  1217.     return o;
  1218.     }
  1219.  
  1220.     if ((o->op_private & OPpTARGET_MY)
  1221.     && (PL_opargs[o->op_type] & OA_TARGLEX))/* OPp share the meaning */
  1222.     {
  1223.     return o;                /* As if inside SASSIGN */
  1224.     }
  1225.     
  1226.     o->op_flags = (o->op_flags & ~OPf_WANT) | OPf_WANT_LIST;
  1227.  
  1228.     switch (o->op_type) {
  1229.     case OP_FLOP:
  1230.     case OP_REPEAT:
  1231.     list(cBINOPo->op_first);
  1232.     break;
  1233.     case OP_OR:
  1234.     case OP_AND:
  1235.     case OP_COND_EXPR:
  1236.     for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
  1237.         list(kid);
  1238.     break;
  1239.     default:
  1240.     case OP_MATCH:
  1241.     case OP_QR:
  1242.     case OP_SUBST:
  1243.     case OP_NULL:
  1244.     if (!(o->op_flags & OPf_KIDS))
  1245.         break;
  1246.     if (!o->op_next && cUNOPo->op_first->op_type == OP_FLOP) {
  1247.         list(cBINOPo->op_first);
  1248.         return gen_constant_list(o);
  1249.     }
  1250.     case OP_LIST:
  1251.     listkids(o);
  1252.     break;
  1253.     case OP_LEAVE:
  1254.     case OP_LEAVETRY:
  1255.     kid = cLISTOPo->op_first;
  1256.     list(kid);
  1257.     while ((kid = kid->op_sibling)) {
  1258.         if (kid->op_sibling)
  1259.         scalarvoid(kid);
  1260.         else
  1261.         list(kid);
  1262.     }
  1263.     WITH_THR(PL_curcop = &PL_compiling);
  1264.     break;
  1265.     case OP_SCOPE:
  1266.     case OP_LINESEQ:
  1267.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling) {
  1268.         if (kid->op_sibling)
  1269.         scalarvoid(kid);
  1270.         else
  1271.         list(kid);
  1272.     }
  1273.     WITH_THR(PL_curcop = &PL_compiling);
  1274.     break;
  1275.     case OP_REQUIRE:
  1276.     /* all requires must return a boolean value */
  1277.     o->op_flags &= ~OPf_WANT;
  1278.     return scalar(o);
  1279.     }
  1280.     return o;
  1281. }
  1282.  
  1283. OP *
  1284. Perl_scalarseq(pTHX_ OP *o)
  1285. {
  1286.     OP *kid;
  1287.  
  1288.     if (o) {
  1289.     if (o->op_type == OP_LINESEQ ||
  1290.          o->op_type == OP_SCOPE ||
  1291.          o->op_type == OP_LEAVE ||
  1292.          o->op_type == OP_LEAVETRY)
  1293.     {
  1294.         dTHR;
  1295.         for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling) {
  1296.         if (kid->op_sibling) {
  1297.             scalarvoid(kid);
  1298.         }
  1299.         }
  1300.         PL_curcop = &PL_compiling;
  1301.     }
  1302.     o->op_flags &= ~OPf_PARENS;
  1303.     if (PL_hints & HINT_BLOCK_SCOPE)
  1304.         o->op_flags |= OPf_PARENS;
  1305.     }
  1306.     else
  1307.     o = newOP(OP_STUB, 0);
  1308.     return o;
  1309. }
  1310.  
  1311. STATIC OP *
  1312. S_modkids(pTHX_ OP *o, I32 type)
  1313. {
  1314.     OP *kid;
  1315.     if (o && o->op_flags & OPf_KIDS) {
  1316.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  1317.         mod(kid, type);
  1318.     }
  1319.     return o;
  1320. }
  1321.  
  1322. OP *
  1323. Perl_mod(pTHX_ OP *o, I32 type)
  1324. {
  1325.     dTHR;
  1326.     OP *kid;
  1327.     STRLEN n_a;
  1328.  
  1329.     if (!o || PL_error_count)
  1330.     return o;
  1331.  
  1332.     if ((o->op_private & OPpTARGET_MY)
  1333.     && (PL_opargs[o->op_type] & OA_TARGLEX))/* OPp share the meaning */
  1334.     {
  1335.     return o;
  1336.     }
  1337.     
  1338.     switch (o->op_type) {
  1339.     case OP_UNDEF:
  1340.     PL_modcount++;
  1341.     return o;
  1342.     case OP_CONST:
  1343.     if (!(o->op_private & (OPpCONST_ARYBASE)))
  1344.         goto nomod;
  1345.     if (PL_eval_start && PL_eval_start->op_type == OP_CONST) {
  1346.         PL_compiling.cop_arybase = (I32)SvIV(cSVOPx(PL_eval_start)->op_sv);
  1347.         PL_eval_start = 0;
  1348.     }
  1349.     else if (!type) {
  1350.         SAVEI32(PL_compiling.cop_arybase);
  1351.         PL_compiling.cop_arybase = 0;
  1352.     }
  1353.     else if (type == OP_REFGEN)
  1354.         goto nomod;
  1355.     else
  1356.         Perl_croak(aTHX_ "That use of $[ is unsupported");
  1357.     break;
  1358.     case OP_STUB:
  1359.     if (o->op_flags & OPf_PARENS)
  1360.         break;
  1361.     goto nomod;
  1362.     case OP_ENTERSUB:
  1363.     if ((type == OP_UNDEF || type == OP_REFGEN) &&
  1364.         !(o->op_flags & OPf_STACKED)) {
  1365.         o->op_type = OP_RV2CV;        /* entersub => rv2cv */
  1366.         o->op_ppaddr = PL_ppaddr[OP_RV2CV];
  1367.         assert(cUNOPo->op_first->op_type == OP_NULL);
  1368.         null(((LISTOP*)cUNOPo->op_first)->op_first);/* disable pushmark */
  1369.         break;
  1370.     }
  1371.     else {                /* lvalue subroutine call */
  1372.         o->op_private |= OPpLVAL_INTRO;
  1373.         if (type == OP_GREPSTART || type == OP_ENTERSUB || type == OP_REFGEN) {
  1374.         /* Backward compatibility mode: */
  1375.         o->op_private |= OPpENTERSUB_INARGS;
  1376.         break;
  1377.         }
  1378.         else {                      /* Compile-time error message: */
  1379.         OP *kid = cUNOPo->op_first;
  1380.         CV *cv;
  1381.         OP *okid;
  1382.  
  1383.         if (kid->op_type == OP_PUSHMARK)
  1384.             goto skip_kids;
  1385.         if (kid->op_type != OP_NULL || kid->op_targ != OP_LIST)
  1386.             Perl_croak(aTHX_
  1387.                    "panic: unexpected lvalue entersub "
  1388.                    "args: type/targ %ld:%ld",
  1389.                    (long)kid->op_type,kid->op_targ);
  1390.         kid = kLISTOP->op_first;
  1391.           skip_kids:
  1392.         while (kid->op_sibling)
  1393.             kid = kid->op_sibling;
  1394.         if (!(kid->op_type == OP_NULL && kid->op_targ == OP_RV2CV)) {
  1395.             /* Indirect call */
  1396.             if (kid->op_type == OP_METHOD_NAMED
  1397.             || kid->op_type == OP_METHOD)
  1398.             {
  1399.             UNOP *newop;
  1400.  
  1401.             if (kid->op_sibling || kid->op_next != kid) {
  1402.                 yyerror("panic: unexpected optree near method call");
  1403.                 break;
  1404.             }
  1405.             
  1406.             NewOp(1101, newop, 1, UNOP);
  1407.             newop->op_type = OP_RV2CV;
  1408.             newop->op_ppaddr = PL_ppaddr[OP_RV2CV];
  1409.             newop->op_first = Nullop;
  1410.                         newop->op_next = (OP*)newop;
  1411.             kid->op_sibling = (OP*)newop;
  1412.             newop->op_private |= OPpLVAL_INTRO;
  1413.             break;
  1414.             }
  1415.             
  1416.             if (kid->op_type != OP_RV2CV)
  1417.             Perl_croak(aTHX_
  1418.                    "panic: unexpected lvalue entersub "
  1419.                    "entry via type/targ %ld:%ld",
  1420.                    (long)kid->op_type,kid->op_targ);
  1421.             kid->op_private |= OPpLVAL_INTRO;
  1422.             break;    /* Postpone until runtime */
  1423.         }
  1424.         
  1425.         okid = kid;        
  1426.         kid = kUNOP->op_first;
  1427.         if (kid->op_type == OP_NULL && kid->op_targ == OP_RV2SV)
  1428.             kid = kUNOP->op_first;
  1429.         if (kid->op_type == OP_NULL)        
  1430.             Perl_croak(aTHX_
  1431.                    "Unexpected constant lvalue entersub "
  1432.                    "entry via type/targ %ld:%ld",
  1433.                    (long)kid->op_type,kid->op_targ);
  1434.         if (kid->op_type != OP_GV) {
  1435.             /* Restore RV2CV to check lvalueness */
  1436.           restore_2cv:
  1437.             if (kid->op_next && kid->op_next != kid) { /* Happens? */
  1438.             okid->op_next = kid->op_next;
  1439.             kid->op_next = okid;
  1440.             }
  1441.             else
  1442.             okid->op_next = Nullop;
  1443.             okid->op_type = OP_RV2CV;
  1444.             okid->op_targ = 0;
  1445.             okid->op_ppaddr = PL_ppaddr[OP_RV2CV];
  1446.             okid->op_private |= OPpLVAL_INTRO;
  1447.             break;
  1448.         }
  1449.         
  1450.         cv = GvCV(kGVOP_gv);
  1451.         if (!cv) 
  1452.             goto restore_2cv;
  1453.         if (CvLVALUE(cv))
  1454.             break;
  1455.         }
  1456.     }
  1457.     /* FALL THROUGH */
  1458.     default:
  1459.       nomod:
  1460.     /* grep, foreach, subcalls, refgen */
  1461.     if (type == OP_GREPSTART || type == OP_ENTERSUB || type == OP_REFGEN)
  1462.         break;
  1463.     yyerror(Perl_form(aTHX_ "Can't modify %s in %s",
  1464.              (o->op_type == OP_NULL && (o->op_flags & OPf_SPECIAL)
  1465.               ? "do block"
  1466.               : (o->op_type == OP_ENTERSUB
  1467.             ? "non-lvalue subroutine call"
  1468.             : PL_op_desc[o->op_type])),
  1469.              type ? PL_op_desc[type] : "local"));
  1470.     return o;
  1471.  
  1472.     case OP_PREINC:
  1473.     case OP_PREDEC:
  1474.     case OP_POW:
  1475.     case OP_MULTIPLY:
  1476.     case OP_DIVIDE:
  1477.     case OP_MODULO:
  1478.     case OP_REPEAT:
  1479.     case OP_ADD:
  1480.     case OP_SUBTRACT:
  1481.     case OP_CONCAT:
  1482.     case OP_LEFT_SHIFT:
  1483.     case OP_RIGHT_SHIFT:
  1484.     case OP_BIT_AND:
  1485.     case OP_BIT_XOR:
  1486.     case OP_BIT_OR:
  1487.     case OP_I_MULTIPLY:
  1488.     case OP_I_DIVIDE:
  1489.     case OP_I_MODULO:
  1490.     case OP_I_ADD:
  1491.     case OP_I_SUBTRACT:
  1492.     if (!(o->op_flags & OPf_STACKED))
  1493.         goto nomod;
  1494.     PL_modcount++;
  1495.     break;
  1496.     
  1497.     case OP_COND_EXPR:
  1498.     for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
  1499.         mod(kid, type);
  1500.     break;
  1501.  
  1502.     case OP_RV2AV:
  1503.     case OP_RV2HV:
  1504.     if (!type && cUNOPo->op_first->op_type != OP_GV)
  1505.         Perl_croak(aTHX_ "Can't localize through a reference");
  1506.     if (type == OP_REFGEN && o->op_flags & OPf_PARENS) {
  1507.         PL_modcount = 10000;
  1508.         return o;        /* Treat \(@foo) like ordinary list. */
  1509.     }
  1510.     /* FALL THROUGH */
  1511.     case OP_RV2GV:
  1512.     if (scalar_mod_type(o, type))
  1513.         goto nomod;
  1514.     ref(cUNOPo->op_first, o->op_type);
  1515.     /* FALL THROUGH */
  1516.     case OP_AASSIGN:
  1517.     case OP_ASLICE:
  1518.     case OP_HSLICE:
  1519.     case OP_NEXTSTATE:
  1520.     case OP_DBSTATE:
  1521.     case OP_REFGEN:
  1522.     case OP_CHOMP:
  1523.     PL_modcount = 10000;
  1524.     break;
  1525.     case OP_RV2SV:
  1526.     if (!type && cUNOPo->op_first->op_type != OP_GV)
  1527.         Perl_croak(aTHX_ "Can't localize through a reference");
  1528.     ref(cUNOPo->op_first, o->op_type);
  1529.     /* FALL THROUGH */
  1530.     case OP_GV:
  1531.     case OP_AV2ARYLEN:
  1532.     PL_hints |= HINT_BLOCK_SCOPE;
  1533.     case OP_SASSIGN:
  1534.     case OP_ANDASSIGN:
  1535.     case OP_ORASSIGN:
  1536.     case OP_AELEMFAST:
  1537.     PL_modcount++;
  1538.     break;
  1539.  
  1540.     case OP_PADAV:
  1541.     case OP_PADHV:
  1542.     PL_modcount = 10000;
  1543.     if (type == OP_REFGEN && o->op_flags & OPf_PARENS)
  1544.         return o;        /* Treat \(@foo) like ordinary list. */
  1545.     if (scalar_mod_type(o, type))
  1546.         goto nomod;
  1547.     /* FALL THROUGH */
  1548.     case OP_PADSV:
  1549.     PL_modcount++;
  1550.     if (!type)
  1551.         Perl_croak(aTHX_ "Can't localize lexical variable %s",
  1552.         SvPV(*av_fetch(PL_comppad_name, o->op_targ, 4), n_a));
  1553.     break;
  1554.  
  1555. #ifdef USE_THREADS
  1556.     case OP_THREADSV:
  1557.     PL_modcount++;    /* XXX ??? */
  1558.     break;
  1559. #endif /* USE_THREADS */
  1560.  
  1561.     case OP_PUSHMARK:
  1562.     break;
  1563.     
  1564.     case OP_KEYS:
  1565.     if (type != OP_SASSIGN)
  1566.         goto nomod;
  1567.     goto lvalue_func;
  1568.     case OP_SUBSTR:
  1569.     if (o->op_private == 4) /* don't allow 4 arg substr as lvalue */
  1570.         goto nomod;
  1571.     /* FALL THROUGH */
  1572.     case OP_POS:
  1573.     case OP_VEC:
  1574.       lvalue_func:
  1575.     pad_free(o->op_targ);
  1576.     o->op_targ = pad_alloc(o->op_type, SVs_PADMY);
  1577.     assert(SvTYPE(PAD_SV(o->op_targ)) == SVt_NULL);
  1578.     if (o->op_flags & OPf_KIDS)
  1579.         mod(cBINOPo->op_first->op_sibling, type);
  1580.     break;
  1581.  
  1582.     case OP_AELEM:
  1583.     case OP_HELEM:
  1584.     ref(cBINOPo->op_first, o->op_type);
  1585.     if (type == OP_ENTERSUB &&
  1586.          !(o->op_private & (OPpLVAL_INTRO | OPpDEREF)))
  1587.         o->op_private |= OPpLVAL_DEFER;
  1588.     PL_modcount++;
  1589.     break;
  1590.  
  1591.     case OP_SCOPE:
  1592.     case OP_LEAVE:
  1593.     case OP_ENTER:
  1594.     if (o->op_flags & OPf_KIDS)
  1595.         mod(cLISTOPo->op_last, type);
  1596.     break;
  1597.  
  1598.     case OP_NULL:
  1599.     if (o->op_flags & OPf_SPECIAL)        /* do BLOCK */
  1600.         goto nomod;
  1601.     else if (!(o->op_flags & OPf_KIDS))
  1602.         break;
  1603.     if (o->op_targ != OP_LIST) {
  1604.         mod(cBINOPo->op_first, type);
  1605.         break;
  1606.     }
  1607.     /* FALL THROUGH */
  1608.     case OP_LIST:
  1609.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  1610.         mod(kid, type);
  1611.     break;
  1612.     }
  1613.     o->op_flags |= OPf_MOD;
  1614.  
  1615.     if (type == OP_AASSIGN || type == OP_SASSIGN)
  1616.     o->op_flags |= OPf_SPECIAL|OPf_REF;
  1617.     else if (!type) {
  1618.     o->op_private |= OPpLVAL_INTRO;
  1619.     o->op_flags &= ~OPf_SPECIAL;
  1620.     PL_hints |= HINT_BLOCK_SCOPE;
  1621.     }
  1622.     else if (type != OP_GREPSTART && type != OP_ENTERSUB)
  1623.     o->op_flags |= OPf_REF;
  1624.     return o;
  1625. }
  1626.  
  1627. STATIC bool
  1628. S_scalar_mod_type(pTHX_ OP *o, I32 type)
  1629. {
  1630.     switch (type) {
  1631.     case OP_SASSIGN:
  1632.     if (o->op_type == OP_RV2GV)
  1633.         return FALSE;
  1634.     /* FALL THROUGH */
  1635.     case OP_PREINC:
  1636.     case OP_PREDEC:
  1637.     case OP_POSTINC:
  1638.     case OP_POSTDEC:
  1639.     case OP_I_PREINC:
  1640.     case OP_I_PREDEC:
  1641.     case OP_I_POSTINC:
  1642.     case OP_I_POSTDEC:
  1643.     case OP_POW:
  1644.     case OP_MULTIPLY:
  1645.     case OP_DIVIDE:
  1646.     case OP_MODULO:
  1647.     case OP_REPEAT:
  1648.     case OP_ADD:
  1649.     case OP_SUBTRACT:
  1650.     case OP_I_MULTIPLY:
  1651.     case OP_I_DIVIDE:
  1652.     case OP_I_MODULO:
  1653.     case OP_I_ADD:
  1654.     case OP_I_SUBTRACT:
  1655.     case OP_LEFT_SHIFT:
  1656.     case OP_RIGHT_SHIFT:
  1657.     case OP_BIT_AND:
  1658.     case OP_BIT_XOR:
  1659.     case OP_BIT_OR:
  1660.     case OP_CONCAT:
  1661.     case OP_SUBST:
  1662.     case OP_TRANS:
  1663.     case OP_READ:
  1664.     case OP_SYSREAD:
  1665.     case OP_RECV:
  1666.     case OP_ANDASSIGN:
  1667.     case OP_ORASSIGN:
  1668.     return TRUE;
  1669.     default:
  1670.     return FALSE;
  1671.     }
  1672. }
  1673.  
  1674. STATIC bool
  1675. S_is_handle_constructor(pTHX_ OP *o, I32 argnum)
  1676. {
  1677.     switch (o->op_type) {
  1678.     case OP_PIPE_OP:
  1679.     case OP_SOCKPAIR:
  1680.     if (argnum == 2)
  1681.         return TRUE;
  1682.     /* FALL THROUGH */
  1683.     case OP_SYSOPEN:
  1684.     case OP_OPEN:
  1685.     case OP_SELECT:        /* XXX c.f. SelectSaver.pm */
  1686.     case OP_SOCKET:
  1687.     case OP_OPEN_DIR:
  1688.     case OP_ACCEPT:
  1689.     if (argnum == 1)
  1690.         return TRUE;
  1691.     /* FALL THROUGH */
  1692.     default:
  1693.     return FALSE;
  1694.     }
  1695. }
  1696.  
  1697. OP *
  1698. Perl_refkids(pTHX_ OP *o, I32 type)
  1699. {
  1700.     OP *kid;
  1701.     if (o && o->op_flags & OPf_KIDS) {
  1702.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  1703.         ref(kid, type);
  1704.     }
  1705.     return o;
  1706. }
  1707.  
  1708. OP *
  1709. Perl_ref(pTHX_ OP *o, I32 type)
  1710. {
  1711.     OP *kid;
  1712.  
  1713.     if (!o || PL_error_count)
  1714.     return o;
  1715.  
  1716.     switch (o->op_type) {
  1717.     case OP_ENTERSUB:
  1718.     if ((type == OP_EXISTS || type == OP_DEFINED || type == OP_LOCK) &&
  1719.         !(o->op_flags & OPf_STACKED)) {
  1720.         o->op_type = OP_RV2CV;             /* entersub => rv2cv */
  1721.         o->op_ppaddr = PL_ppaddr[OP_RV2CV];
  1722.         assert(cUNOPo->op_first->op_type == OP_NULL);
  1723.         null(((LISTOP*)cUNOPo->op_first)->op_first);    /* disable pushmark */
  1724.         o->op_flags |= OPf_SPECIAL;
  1725.     }
  1726.     break;
  1727.  
  1728.     case OP_COND_EXPR:
  1729.     for (kid = cUNOPo->op_first->op_sibling; kid; kid = kid->op_sibling)
  1730.         ref(kid, type);
  1731.     break;
  1732.     case OP_RV2SV:
  1733.     if (type == OP_DEFINED)
  1734.         o->op_flags |= OPf_SPECIAL;        /* don't create GV */
  1735.     ref(cUNOPo->op_first, o->op_type);
  1736.     /* FALL THROUGH */
  1737.     case OP_PADSV:
  1738.     if (type == OP_RV2SV || type == OP_RV2AV || type == OP_RV2HV) {
  1739.         o->op_private |= (type == OP_RV2AV ? OPpDEREF_AV
  1740.                   : type == OP_RV2HV ? OPpDEREF_HV
  1741.                   : OPpDEREF_SV);
  1742.         o->op_flags |= OPf_MOD;
  1743.     }
  1744.     break;
  1745.       
  1746.     case OP_THREADSV:
  1747.     o->op_flags |= OPf_MOD;        /* XXX ??? */
  1748.     break;
  1749.  
  1750.     case OP_RV2AV:
  1751.     case OP_RV2HV:
  1752.     o->op_flags |= OPf_REF;
  1753.     /* FALL THROUGH */
  1754.     case OP_RV2GV:
  1755.     if (type == OP_DEFINED)
  1756.         o->op_flags |= OPf_SPECIAL;        /* don't create GV */
  1757.     ref(cUNOPo->op_first, o->op_type);
  1758.     break;
  1759.  
  1760.     case OP_PADAV:
  1761.     case OP_PADHV:
  1762.     o->op_flags |= OPf_REF;
  1763.     break;
  1764.  
  1765.     case OP_SCALAR:
  1766.     case OP_NULL:
  1767.     if (!(o->op_flags & OPf_KIDS))
  1768.         break;
  1769.     ref(cBINOPo->op_first, type);
  1770.     break;
  1771.     case OP_AELEM:
  1772.     case OP_HELEM:
  1773.     ref(cBINOPo->op_first, o->op_type);
  1774.     if (type == OP_RV2SV || type == OP_RV2AV || type == OP_RV2HV) {
  1775.         o->op_private |= (type == OP_RV2AV ? OPpDEREF_AV
  1776.                   : type == OP_RV2HV ? OPpDEREF_HV
  1777.                   : OPpDEREF_SV);
  1778.         o->op_flags |= OPf_MOD;
  1779.     }
  1780.     break;
  1781.  
  1782.     case OP_SCOPE:
  1783.     case OP_LEAVE:
  1784.     case OP_ENTER:
  1785.     case OP_LIST:
  1786.     if (!(o->op_flags & OPf_KIDS))
  1787.         break;
  1788.     ref(cLISTOPo->op_last, type);
  1789.     break;
  1790.     default:
  1791.     break;
  1792.     }
  1793.     return scalar(o);
  1794.  
  1795. }
  1796.  
  1797. STATIC OP *
  1798. S_dup_attrlist(pTHX_ OP *o)
  1799. {
  1800.     OP *rop = Nullop;
  1801.  
  1802.     /* An attrlist is either a simple OP_CONST or an OP_LIST with kids,
  1803.      * where the first kid is OP_PUSHMARK and the remaining ones
  1804.      * are OP_CONST.  We need to push the OP_CONST values.
  1805.      */
  1806.     if (o->op_type == OP_CONST)
  1807.     rop = newSVOP(OP_CONST, o->op_flags, SvREFCNT_inc(cSVOPo->op_sv));
  1808.     else {
  1809.     assert((o->op_type == OP_LIST) && (o->op_flags & OPf_KIDS));
  1810.     for (o = cLISTOPo->op_first; o; o=o->op_sibling) {
  1811.         if (o->op_type == OP_CONST)
  1812.         rop = append_elem(OP_LIST, rop,
  1813.                   newSVOP(OP_CONST, o->op_flags,
  1814.                       SvREFCNT_inc(cSVOPo->op_sv)));
  1815.     }
  1816.     }
  1817.     return rop;
  1818. }
  1819.  
  1820. STATIC void
  1821. S_apply_attrs(pTHX_ HV *stash, SV *target, OP *attrs)
  1822. {
  1823.     SV *stashsv;
  1824.  
  1825.     /* fake up C<use attributes $pkg,$rv,@attrs> */
  1826.     ENTER;        /* need to protect against side-effects of 'use' */
  1827.     SAVEINT(PL_expect);
  1828.     if (stash && HvNAME(stash))
  1829.     stashsv = newSVpv(HvNAME(stash), 0);
  1830.     else
  1831.     stashsv = &PL_sv_no;
  1832.  
  1833. #define ATTRSMODULE "attributes"
  1834.  
  1835.     Perl_load_module(aTHX_ PERL_LOADMOD_IMPORT_OPS,
  1836.              newSVpvn(ATTRSMODULE, sizeof(ATTRSMODULE)-1),
  1837.              Nullsv,
  1838.              prepend_elem(OP_LIST,
  1839.                   newSVOP(OP_CONST, 0, stashsv),
  1840.                   prepend_elem(OP_LIST,
  1841.                            newSVOP(OP_CONST, 0,
  1842.                                newRV(target)),
  1843.                            dup_attrlist(attrs))));
  1844.     LEAVE;
  1845. }
  1846.  
  1847. STATIC OP *
  1848. S_my_kid(pTHX_ OP *o, OP *attrs)
  1849. {
  1850.     OP *kid;
  1851.     I32 type;
  1852.  
  1853.     if (!o || PL_error_count)
  1854.     return o;
  1855.  
  1856.     type = o->op_type;
  1857.     if (type == OP_LIST) {
  1858.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  1859.         my_kid(kid, attrs);
  1860.     } else if (type == OP_UNDEF) {
  1861.     return o;
  1862.     } else if (type == OP_RV2SV ||    /* "our" declaration */
  1863.            type == OP_RV2AV ||
  1864.            type == OP_RV2HV) { /* XXX does this let anything illegal in? */
  1865.     o->op_private |= OPpOUR_INTRO;
  1866.     return o;
  1867.     } else if (type != OP_PADSV &&
  1868.          type != OP_PADAV &&
  1869.          type != OP_PADHV &&
  1870.          type != OP_PUSHMARK)
  1871.     {
  1872.     yyerror(Perl_form(aTHX_ "Can't declare %s in \"%s\"",
  1873.               PL_op_desc[o->op_type],
  1874.               PL_in_my == KEY_our ? "our" : "my"));
  1875.     return o;
  1876.     }
  1877.     else if (attrs && type != OP_PUSHMARK) {
  1878.     HV *stash;
  1879.     SV *padsv;
  1880.     SV **namesvp;
  1881.  
  1882.     PL_in_my = FALSE;
  1883.     PL_in_my_stash = Nullhv;
  1884.  
  1885.     /* check for C<my Dog $spot> when deciding package */
  1886.     namesvp = av_fetch(PL_comppad_name, o->op_targ, FALSE);
  1887.     if (namesvp && *namesvp && SvOBJECT(*namesvp) && HvNAME(SvSTASH(*namesvp)))
  1888.         stash = SvSTASH(*namesvp);
  1889.     else
  1890.         stash = PL_curstash;
  1891.     padsv = PAD_SV(o->op_targ);
  1892.     apply_attrs(stash, padsv, attrs);
  1893.     }
  1894.     o->op_flags |= OPf_MOD;
  1895.     o->op_private |= OPpLVAL_INTRO;
  1896.     return o;
  1897. }
  1898.  
  1899. OP *
  1900. Perl_my_attrs(pTHX_ OP *o, OP *attrs)
  1901. {
  1902.     if (o->op_flags & OPf_PARENS)
  1903.     list(o);
  1904.     if (attrs)
  1905.     SAVEFREEOP(attrs);
  1906.     o = my_kid(o, attrs);
  1907.     PL_in_my = FALSE;
  1908.     PL_in_my_stash = Nullhv;
  1909.     return o;
  1910. }
  1911.  
  1912. OP *
  1913. Perl_my(pTHX_ OP *o)
  1914. {
  1915.     return my_kid(o, Nullop);
  1916. }
  1917.  
  1918. OP *
  1919. Perl_sawparens(pTHX_ OP *o)
  1920. {
  1921.     if (o)
  1922.     o->op_flags |= OPf_PARENS;
  1923.     return o;
  1924. }
  1925.  
  1926. OP *
  1927. Perl_bind_match(pTHX_ I32 type, OP *left, OP *right)
  1928. {
  1929.     dTHR;
  1930.     OP *o;
  1931.  
  1932.     if (ckWARN(WARN_MISC) &&
  1933.       (left->op_type == OP_RV2AV ||
  1934.        left->op_type == OP_RV2HV ||
  1935.        left->op_type == OP_PADAV ||
  1936.        left->op_type == OP_PADHV)) {
  1937.       char *desc = PL_op_desc[(right->op_type == OP_SUBST ||
  1938.                             right->op_type == OP_TRANS)
  1939.                            ? right->op_type : OP_MATCH];
  1940.       const char *sample = ((left->op_type == OP_RV2AV ||
  1941.                  left->op_type == OP_PADAV)
  1942.                 ? "@array" : "%hash");
  1943.       Perl_warner(aTHX_ WARN_MISC,
  1944.              "Applying %s to %s will act on scalar(%s)", 
  1945.              desc, sample, sample);
  1946.     }
  1947.  
  1948.     if (right->op_type == OP_MATCH ||
  1949.     right->op_type == OP_SUBST ||
  1950.     right->op_type == OP_TRANS) {
  1951.     right->op_flags |= OPf_STACKED;
  1952.     if (right->op_type != OP_MATCH)
  1953.         left = mod(left, right->op_type);
  1954.     if (right->op_type == OP_TRANS)
  1955.         o = newBINOP(OP_NULL, OPf_STACKED, scalar(left), right);
  1956.     else
  1957.         o = prepend_elem(right->op_type, scalar(left), right);
  1958.     if (type == OP_NOT)
  1959.         return newUNOP(OP_NOT, 0, scalar(o));
  1960.     return o;
  1961.     }
  1962.     else
  1963.     return bind_match(type, left,
  1964.         pmruntime(newPMOP(OP_MATCH, 0), right, Nullop));
  1965. }
  1966.  
  1967. OP *
  1968. Perl_invert(pTHX_ OP *o)
  1969. {
  1970.     if (!o)
  1971.     return o;
  1972.     /* XXX need to optimize away NOT NOT here?  Or do we let optimizer do it? */
  1973.     return newUNOP(OP_NOT, OPf_SPECIAL, scalar(o));
  1974. }
  1975.  
  1976. OP *
  1977. Perl_scope(pTHX_ OP *o)
  1978. {
  1979.     if (o) {
  1980.     if (o->op_flags & OPf_PARENS || PERLDB_NOOPT || PL_tainting) {
  1981.         o = prepend_elem(OP_LINESEQ, newOP(OP_ENTER, 0), o);
  1982.         o->op_type = OP_LEAVE;
  1983.         o->op_ppaddr = PL_ppaddr[OP_LEAVE];
  1984.     }
  1985.     else {
  1986.         if (o->op_type == OP_LINESEQ) {
  1987.         OP *kid;
  1988.         o->op_type = OP_SCOPE;
  1989.         o->op_ppaddr = PL_ppaddr[OP_SCOPE];
  1990.         kid = ((LISTOP*)o)->op_first;
  1991.         if (kid->op_type == OP_NEXTSTATE || kid->op_type == OP_DBSTATE)
  1992.             null(kid);
  1993.         }
  1994.         else
  1995.         o = newLISTOP(OP_SCOPE, 0, o, Nullop);
  1996.     }
  1997.     }
  1998.     return o;
  1999. }
  2000.  
  2001. void
  2002. Perl_save_hints(pTHX)
  2003. {
  2004.     SAVEI32(PL_hints);
  2005.     SAVESPTR(GvHV(PL_hintgv));
  2006.     GvHV(PL_hintgv) = newHVhv(GvHV(PL_hintgv));
  2007.     SAVEFREESV(GvHV(PL_hintgv));
  2008. }
  2009.  
  2010. int
  2011. Perl_block_start(pTHX_ int full)
  2012. {
  2013.     dTHR;
  2014.     int retval = PL_savestack_ix;
  2015.  
  2016.     SAVEI32(PL_comppad_name_floor);
  2017.     PL_comppad_name_floor = AvFILLp(PL_comppad_name);
  2018.     if (full)
  2019.     PL_comppad_name_fill = PL_comppad_name_floor;
  2020.     if (PL_comppad_name_floor < 0)
  2021.     PL_comppad_name_floor = 0;
  2022.     SAVEI32(PL_min_intro_pending);
  2023.     SAVEI32(PL_max_intro_pending);
  2024.     PL_min_intro_pending = 0;
  2025.     SAVEI32(PL_comppad_name_fill);
  2026.     SAVEI32(PL_padix_floor);
  2027.     PL_padix_floor = PL_padix;
  2028.     PL_pad_reset_pending = FALSE;
  2029.     SAVEHINTS();
  2030.     PL_hints &= ~HINT_BLOCK_SCOPE;
  2031.     SAVESPTR(PL_compiling.cop_warnings); 
  2032.     if (! specialWARN(PL_compiling.cop_warnings)) {
  2033.         PL_compiling.cop_warnings = newSVsv(PL_compiling.cop_warnings) ;
  2034.         SAVEFREESV(PL_compiling.cop_warnings) ;
  2035.     }
  2036.     return retval;
  2037. }
  2038.  
  2039. OP*
  2040. Perl_block_end(pTHX_ I32 floor, OP *seq)
  2041. {
  2042.     dTHR;
  2043.     int needblockscope = PL_hints & HINT_BLOCK_SCOPE;
  2044.     OP* retval = scalarseq(seq);
  2045.     LEAVE_SCOPE(floor);
  2046.     PL_pad_reset_pending = FALSE;
  2047.     PL_compiling.op_private = PL_hints;
  2048.     if (needblockscope)
  2049.     PL_hints |= HINT_BLOCK_SCOPE; /* propagate out */
  2050.     pad_leavemy(PL_comppad_name_fill);
  2051.     PL_cop_seqmax++;
  2052.     return retval;
  2053. }
  2054.  
  2055. STATIC OP *
  2056. S_newDEFSVOP(pTHX)
  2057. {
  2058. #ifdef USE_THREADS
  2059.     OP *o = newOP(OP_THREADSV, 0);
  2060.     o->op_targ = find_threadsv("_");
  2061.     return o;
  2062. #else
  2063.     return newSVREF(newGVOP(OP_GV, 0, PL_defgv));
  2064. #endif /* USE_THREADS */
  2065. }
  2066.  
  2067. void
  2068. Perl_newPROG(pTHX_ OP *o)
  2069. {
  2070.     dTHR;
  2071.     if (PL_in_eval) {
  2072.     if (PL_eval_root)
  2073.         return;
  2074.     PL_eval_root = newUNOP(OP_LEAVEEVAL,
  2075.                    ((PL_in_eval & EVAL_KEEPERR)
  2076.                 ? OPf_SPECIAL : 0), o);
  2077.     PL_eval_start = linklist(PL_eval_root);
  2078.     PL_eval_root->op_private |= OPpREFCOUNTED;
  2079.     OpREFCNT_set(PL_eval_root, 1);
  2080.     PL_eval_root->op_next = 0;
  2081.     peep(PL_eval_start);
  2082.     }
  2083.     else {
  2084.     if (!o)
  2085.         return;
  2086.     PL_main_root = scope(sawparens(scalarvoid(o)));
  2087.     PL_curcop = &PL_compiling;
  2088.     PL_main_start = LINKLIST(PL_main_root);
  2089.     PL_main_root->op_private |= OPpREFCOUNTED;
  2090.     OpREFCNT_set(PL_main_root, 1);
  2091.     PL_main_root->op_next = 0;
  2092.     peep(PL_main_start);
  2093.     PL_compcv = 0;
  2094.  
  2095.     /* Register with debugger */
  2096.     if (PERLDB_INTER) {
  2097.         CV *cv = get_cv("DB::postponed", FALSE);
  2098.         if (cv) {
  2099.         dSP;
  2100.         PUSHMARK(SP);
  2101.         XPUSHs((SV*)CopFILEGV(&PL_compiling));
  2102.         PUTBACK;
  2103.         call_sv((SV*)cv, G_DISCARD);
  2104.         }
  2105.     }
  2106.     }
  2107. }
  2108.  
  2109. OP *
  2110. Perl_localize(pTHX_ OP *o, I32 lex)
  2111. {
  2112.     if (o->op_flags & OPf_PARENS)
  2113.     list(o);
  2114.     else {
  2115.     dTHR;
  2116.     if (ckWARN(WARN_PARENTHESIS) && PL_bufptr > PL_oldbufptr && PL_bufptr[-1] == ',') {
  2117.         char *s;
  2118.         for (s = PL_bufptr; *s && (isALNUM(*s) || (*s & 0x80) || strchr("@$%, ",*s)); s++) ;
  2119.         if (*s == ';' || *s == '=')
  2120.         Perl_warner(aTHX_ WARN_PARENTHESIS,
  2121.                 "Parentheses missing around \"%s\" list",
  2122.                 lex ? (PL_in_my == KEY_our ? "our" : "my") : "local");
  2123.     }
  2124.     }
  2125.     if (lex)
  2126.     o = my(o);
  2127.     else
  2128.     o = mod(o, OP_NULL);        /* a bit kludgey */
  2129.     PL_in_my = FALSE;
  2130.     PL_in_my_stash = Nullhv;
  2131.     return o;
  2132. }
  2133.  
  2134. OP *
  2135. Perl_jmaybe(pTHX_ OP *o)
  2136. {
  2137.     if (o->op_type == OP_LIST) {
  2138.     OP *o2;
  2139. #ifdef USE_THREADS
  2140.     o2 = newOP(OP_THREADSV, 0);
  2141.     o2->op_targ = find_threadsv(";");
  2142. #else
  2143.     o2 = newSVREF(newGVOP(OP_GV, 0, gv_fetchpv(";", TRUE, SVt_PV))),
  2144. #endif /* USE_THREADS */
  2145.     o = convert(OP_JOIN, 0, prepend_elem(OP_LIST, o2, o));
  2146.     }
  2147.     return o;
  2148. }
  2149.  
  2150. OP *
  2151. Perl_fold_constants(pTHX_ register OP *o)
  2152. {
  2153.     dTHR;
  2154.     register OP *curop;
  2155.     I32 type = o->op_type;
  2156.     SV *sv;
  2157.  
  2158.     if (PL_opargs[type] & OA_RETSCALAR)
  2159.     scalar(o);
  2160.     if (PL_opargs[type] & OA_TARGET && !o->op_targ)
  2161.     o->op_targ = pad_alloc(type, SVs_PADTMP);
  2162.  
  2163.     /* integerize op, unless it happens to be C<-foo>.
  2164.      * XXX should pp_i_negate() do magic string negation instead? */
  2165.     if ((PL_opargs[type] & OA_OTHERINT) && (PL_hints & HINT_INTEGER)
  2166.     && !(type == OP_NEGATE && cUNOPo->op_first->op_type == OP_CONST
  2167.          && (cUNOPo->op_first->op_private & OPpCONST_BARE)))
  2168.     {
  2169.     o->op_ppaddr = PL_ppaddr[type = ++(o->op_type)];
  2170.     }
  2171.  
  2172.     if (!(PL_opargs[type] & OA_FOLDCONST))
  2173.     goto nope;
  2174.  
  2175.     switch (type) {
  2176.     case OP_NEGATE:
  2177.     /* XXX might want a ck_negate() for this */
  2178.     cUNOPo->op_first->op_private &= ~OPpCONST_STRICT;
  2179.     break;
  2180.     case OP_SPRINTF:
  2181.     case OP_UCFIRST:
  2182.     case OP_LCFIRST:
  2183.     case OP_UC:
  2184.     case OP_LC:
  2185.     case OP_SLT:
  2186.     case OP_SGT:
  2187.     case OP_SLE:
  2188.     case OP_SGE:
  2189.     case OP_SCMP:
  2190.  
  2191.     if (o->op_private & OPpLOCALE)
  2192.         goto nope;
  2193.     }
  2194.  
  2195.     if (PL_error_count)
  2196.     goto nope;        /* Don't try to run w/ errors */
  2197.  
  2198.     for (curop = LINKLIST(o); curop != o; curop = LINKLIST(curop)) {
  2199.     if ((curop->op_type != OP_CONST ||
  2200.          (curop->op_private & OPpCONST_BARE)) &&
  2201.         curop->op_type != OP_LIST &&
  2202.         curop->op_type != OP_SCALAR &&
  2203.         curop->op_type != OP_NULL &&
  2204.         curop->op_type != OP_PUSHMARK)
  2205.     {
  2206.         goto nope;
  2207.     }
  2208.     }
  2209.  
  2210.     curop = LINKLIST(o);
  2211.     o->op_next = 0;
  2212.     PL_op = curop;
  2213.     CALLRUNOPS(aTHX);
  2214.     sv = *(PL_stack_sp--);
  2215.     if (o->op_targ && sv == PAD_SV(o->op_targ))    /* grab pad temp? */
  2216.     pad_swipe(o->op_targ);
  2217.     else if (SvTEMP(sv)) {            /* grab mortal temp? */
  2218.     (void)SvREFCNT_inc(sv);
  2219.     SvTEMP_off(sv);
  2220.     }
  2221.     op_free(o);
  2222.     if (type == OP_RV2GV)
  2223.     return newGVOP(OP_GV, 0, (GV*)sv);
  2224.     else {
  2225.     /* try to smush double to int, but don't smush -2.0 to -2 */
  2226.     if ((SvFLAGS(sv) & (SVf_IOK|SVf_NOK|SVf_POK)) == SVf_NOK &&
  2227.         type != OP_NEGATE)
  2228.     {
  2229.         IV iv = SvIV(sv);
  2230.         if ((NV)iv == SvNV(sv)) {
  2231.         SvREFCNT_dec(sv);
  2232.         sv = newSViv(iv);
  2233.         }
  2234.         else
  2235.         SvIOK_off(sv);            /* undo SvIV() damage */
  2236.     }
  2237.     return newSVOP(OP_CONST, 0, sv);
  2238.     }
  2239.  
  2240.   nope:
  2241.     if (!(PL_opargs[type] & OA_OTHERINT))
  2242.     return o;
  2243.  
  2244.     if (!(PL_hints & HINT_INTEGER)) {
  2245.     if (type == OP_MODULO
  2246.         || type == OP_DIVIDE
  2247.         || !(o->op_flags & OPf_KIDS))
  2248.     {
  2249.         return o;
  2250.     }
  2251.  
  2252.     for (curop = ((UNOP*)o)->op_first; curop; curop = curop->op_sibling) {
  2253.         if (curop->op_type == OP_CONST) {
  2254.         if (SvIOK(((SVOP*)curop)->op_sv))
  2255.             continue;
  2256.         return o;
  2257.         }
  2258.         if (PL_opargs[curop->op_type] & OA_RETINTEGER)
  2259.         continue;
  2260.         return o;
  2261.     }
  2262.     o->op_ppaddr = PL_ppaddr[++(o->op_type)];
  2263.     }
  2264.  
  2265.     return o;
  2266. }
  2267.  
  2268. OP *
  2269. Perl_gen_constant_list(pTHX_ register OP *o)
  2270. {
  2271.     dTHR;
  2272.     register OP *curop;
  2273.     I32 oldtmps_floor = PL_tmps_floor;
  2274.  
  2275.     list(o);
  2276.     if (PL_error_count)
  2277.     return o;        /* Don't attempt to run with errors */
  2278.  
  2279.     PL_op = curop = LINKLIST(o);
  2280.     o->op_next = 0;
  2281.     peep(curop);
  2282.     pp_pushmark();
  2283.     CALLRUNOPS(aTHX);
  2284.     PL_op = curop;
  2285.     pp_anonlist();
  2286.     PL_tmps_floor = oldtmps_floor;
  2287.  
  2288.     o->op_type = OP_RV2AV;
  2289.     o->op_ppaddr = PL_ppaddr[OP_RV2AV];
  2290.     curop = ((UNOP*)o)->op_first;
  2291.     ((UNOP*)o)->op_first = newSVOP(OP_CONST, 0, SvREFCNT_inc(*PL_stack_sp--));
  2292.     op_free(curop);
  2293.     linklist(o);
  2294.     return list(o);
  2295. }
  2296.  
  2297. OP *
  2298. Perl_convert(pTHX_ I32 type, I32 flags, OP *o)
  2299. {
  2300.     OP *kid;
  2301.     OP *last = 0;
  2302.  
  2303.     if (!o || o->op_type != OP_LIST)
  2304.     o = newLISTOP(OP_LIST, 0, o, Nullop);
  2305.     else
  2306.     o->op_flags &= ~OPf_WANT;
  2307.  
  2308.     if (!(PL_opargs[type] & OA_MARK))
  2309.     null(cLISTOPo->op_first);
  2310.  
  2311.     o->op_type = type;
  2312.     o->op_ppaddr = PL_ppaddr[type];
  2313.     o->op_flags |= flags;
  2314.  
  2315.     o = CHECKOP(type, o);
  2316.     if (o->op_type != type)
  2317.     return o;
  2318.  
  2319.     if (cLISTOPo->op_children < 7) {
  2320.     /* XXX do we really need to do this if we're done appending?? */
  2321.     for (kid = cLISTOPo->op_first; kid; kid = kid->op_sibling)
  2322.         last = kid;
  2323.     cLISTOPo->op_last = last;    /* in case check substituted last arg */
  2324.     }
  2325.  
  2326.     return fold_constants(o);
  2327. }
  2328.  
  2329. /* List constructors */
  2330.  
  2331. OP *
  2332. Perl_append_elem(pTHX_ I32 type, OP *first, OP *last)
  2333. {
  2334.     if (!first)
  2335.     return last;
  2336.  
  2337.     if (!last)
  2338.     return first;
  2339.  
  2340.     if (first->op_type != type
  2341.     || (type == OP_LIST && (first->op_flags & OPf_PARENS)))
  2342.     {
  2343.     return newLISTOP(type, 0, first, last);
  2344.     }
  2345.  
  2346.     if (first->op_flags & OPf_KIDS)
  2347.     ((LISTOP*)first)->op_last->op_sibling = last;
  2348.     else {
  2349.     first->op_flags |= OPf_KIDS;
  2350.     ((LISTOP*)first)->op_first = last;
  2351.     }
  2352.     ((LISTOP*)first)->op_last = last;
  2353.     ((LISTOP*)first)->op_children++;
  2354.     return first;
  2355. }
  2356.  
  2357. OP *
  2358. Perl_append_list(pTHX_ I32 type, LISTOP *first, LISTOP *last)
  2359. {
  2360.     if (!first)
  2361.     return (OP*)last;
  2362.  
  2363.     if (!last)
  2364.     return (OP*)first;
  2365.  
  2366.     if (first->op_type != type)
  2367.     return prepend_elem(type, (OP*)first, (OP*)last);
  2368.  
  2369.     if (last->op_type != type)
  2370.     return append_elem(type, (OP*)first, (OP*)last);
  2371.  
  2372.     first->op_last->op_sibling = last->op_first;
  2373.     first->op_last = last->op_last;
  2374.     first->op_children += last->op_children;
  2375.     if (first->op_children)
  2376.     first->op_flags |= OPf_KIDS;
  2377.     
  2378. #ifdef PL_OP_SLAB_ALLOC
  2379. #else
  2380.     Safefree(last);     
  2381. #endif
  2382.     return (OP*)first;
  2383. }
  2384.  
  2385. OP *
  2386. Perl_prepend_elem(pTHX_ I32 type, OP *first, OP *last)
  2387. {
  2388.     if (!first)
  2389.     return last;
  2390.  
  2391.     if (!last)
  2392.     return first;
  2393.  
  2394.     if (last->op_type == type) {
  2395.     if (type == OP_LIST) {    /* already a PUSHMARK there */
  2396.         first->op_sibling = ((LISTOP*)last)->op_first->op_sibling;
  2397.         ((LISTOP*)last)->op_first->op_sibling = first;
  2398.     }
  2399.     else {
  2400.         if (!(last->op_flags & OPf_KIDS)) {
  2401.         ((LISTOP*)last)->op_last = first;
  2402.         last->op_flags |= OPf_KIDS;
  2403.         }
  2404.         first->op_sibling = ((LISTOP*)last)->op_first;
  2405.         ((LISTOP*)last)->op_first = first;
  2406.     }
  2407.     ((LISTOP*)last)->op_children++;
  2408.     return last;
  2409.     }
  2410.  
  2411.     return newLISTOP(type, 0, first, last);
  2412. }
  2413.  
  2414. /* Constructors */
  2415.  
  2416. OP *
  2417. Perl_newNULLLIST(pTHX)
  2418. {
  2419.     return newOP(OP_STUB, 0);
  2420. }
  2421.  
  2422. OP *
  2423. Perl_force_list(pTHX_ OP *o)
  2424. {
  2425.     if (!o || o->op_type != OP_LIST)
  2426.     o = newLISTOP(OP_LIST, 0, o, Nullop);
  2427.     null(o);
  2428.     return o;
  2429. }
  2430.  
  2431. OP *
  2432. Perl_newLISTOP(pTHX_ I32 type, I32 flags, OP *first, OP *last)
  2433. {
  2434.     LISTOP *listop;
  2435.  
  2436.     NewOp(1101, listop, 1, LISTOP);
  2437.  
  2438.     listop->op_type = type;
  2439.     listop->op_ppaddr = PL_ppaddr[type];
  2440.     listop->op_children = (first != 0) + (last != 0);
  2441.     listop->op_flags = flags;
  2442.  
  2443.     if (!last && first)
  2444.     last = first;
  2445.     else if (!first && last)
  2446.     first = last;
  2447.     else if (first)
  2448.     first->op_sibling = last;
  2449.     listop->op_first = first;
  2450.     listop->op_last = last;
  2451.     if (type == OP_LIST) {
  2452.     OP* pushop;
  2453.     pushop = newOP(OP_PUSHMARK, 0);
  2454.     pushop->op_sibling = first;
  2455.     listop->op_first = pushop;
  2456.     listop->op_flags |= OPf_KIDS;
  2457.     if (!last)
  2458.         listop->op_last = pushop;
  2459.     }
  2460.     else if (listop->op_children)
  2461.     listop->op_flags |= OPf_KIDS;
  2462.  
  2463.     return (OP*)listop;
  2464. }
  2465.  
  2466. OP *
  2467. Perl_newOP(pTHX_ I32 type, I32 flags)
  2468. {
  2469.     OP *o;
  2470.     NewOp(1101, o, 1, OP);
  2471.     o->op_type = type;
  2472.     o->op_ppaddr = PL_ppaddr[type];
  2473.     o->op_flags = flags;
  2474.  
  2475.     o->op_next = o;
  2476.     o->op_private = 0 + (flags >> 8);
  2477.     if (PL_opargs[type] & OA_RETSCALAR)
  2478.     scalar(o);
  2479.     if (PL_opargs[type] & OA_TARGET)
  2480.     o->op_targ = pad_alloc(type, SVs_PADTMP);
  2481.     return CHECKOP(type, o);
  2482. }
  2483.  
  2484. OP *
  2485. Perl_newUNOP(pTHX_ I32 type, I32 flags, OP *first)
  2486. {
  2487.     UNOP *unop;
  2488.  
  2489.     if (!first)
  2490.     first = newOP(OP_STUB, 0);
  2491.     if (PL_opargs[type] & OA_MARK)
  2492.     first = force_list(first);
  2493.  
  2494.     NewOp(1101, unop, 1, UNOP);
  2495.     unop->op_type = type;
  2496.     unop->op_ppaddr = PL_ppaddr[type];
  2497.     unop->op_first = first;
  2498.     unop->op_flags = flags | OPf_KIDS;
  2499.     unop->op_private = 1 | (flags >> 8);
  2500.     unop = (UNOP*) CHECKOP(type, unop);
  2501.     if (unop->op_next)
  2502.     return (OP*)unop;
  2503.  
  2504.     return fold_constants((OP *) unop);
  2505. }
  2506.  
  2507. OP *
  2508. Perl_newBINOP(pTHX_ I32 type, I32 flags, OP *first, OP *last)
  2509. {
  2510.     BINOP *binop;
  2511.     NewOp(1101, binop, 1, BINOP);
  2512.  
  2513.     if (!first)
  2514.     first = newOP(OP_NULL, 0);
  2515.  
  2516.     binop->op_type = type;
  2517.     binop->op_ppaddr = PL_ppaddr[type];
  2518.     binop->op_first = first;
  2519.     binop->op_flags = flags | OPf_KIDS;
  2520.     if (!last) {
  2521.     last = first;
  2522.     binop->op_private = 1 | (flags >> 8);
  2523.     }
  2524.     else {
  2525.     binop->op_private = 2 | (flags >> 8);
  2526.     first->op_sibling = last;
  2527.     }
  2528.  
  2529.     binop = (BINOP*)CHECKOP(type, binop);
  2530.     if (binop->op_next || binop->op_type != type)
  2531.     return (OP*)binop;
  2532.  
  2533.     binop->op_last = binop->op_first->op_sibling;
  2534.  
  2535.     return fold_constants((OP *)binop);
  2536. }
  2537.  
  2538. static int
  2539. utf8compare(const void *a, const void *b)
  2540. {
  2541.     int i;
  2542.     for (i = 0; i < 10; i++) {
  2543.     if ((*(U8**)a)[i] < (*(U8**)b)[i])
  2544.         return -1;
  2545.     if ((*(U8**)a)[i] > (*(U8**)b)[i])
  2546.         return 1;
  2547.     }
  2548.     return 0;
  2549. }
  2550.  
  2551. OP *
  2552. Perl_pmtrans(pTHX_ OP *o, OP *expr, OP *repl)
  2553. {
  2554.     SV *tstr = ((SVOP*)expr)->op_sv;
  2555.     SV *rstr = ((SVOP*)repl)->op_sv;
  2556.     STRLEN tlen;
  2557.     STRLEN rlen;
  2558.     register U8 *t = (U8*)SvPV(tstr, tlen);
  2559.     register U8 *r = (U8*)SvPV(rstr, rlen);
  2560.     register I32 i;
  2561.     register I32 j;
  2562.     I32 del;
  2563.     I32 complement;
  2564.     I32 squash;
  2565.     register short *tbl;
  2566.  
  2567.     complement    = o->op_private & OPpTRANS_COMPLEMENT;
  2568.     del        = o->op_private & OPpTRANS_DELETE;
  2569.     squash    = o->op_private & OPpTRANS_SQUASH;
  2570.  
  2571.     if (o->op_private & (OPpTRANS_FROM_UTF|OPpTRANS_TO_UTF)) {
  2572.     SV* listsv = newSVpvn("# comment\n",10);
  2573.     SV* transv = 0;
  2574.     U8* tend = t + tlen;
  2575.     U8* rend = r + rlen;
  2576.     I32 ulen;
  2577.     U32 tfirst = 1;
  2578.     U32 tlast = 0;
  2579.     I32 tdiff;
  2580.     U32 rfirst = 1;
  2581.     U32 rlast = 0;
  2582.     I32 rdiff;
  2583.     I32 diff;
  2584.     I32 none = 0;
  2585.     U32 max = 0;
  2586.     I32 bits;
  2587.     I32 grows = 0;
  2588.     I32 havefinal = 0;
  2589.     U32 final;
  2590.     I32 from_utf    = o->op_private & OPpTRANS_FROM_UTF;
  2591.     I32 to_utf    = o->op_private & OPpTRANS_TO_UTF;
  2592.  
  2593.     if (complement) {
  2594.         U8 tmpbuf[UTF8_MAXLEN];
  2595.         U8** cp;
  2596.         UV nextmin = 0;
  2597.         New(1109, cp, tlen, U8*);
  2598.         i = 0;
  2599.         transv = newSVpvn("",0);
  2600.         while (t < tend) {
  2601.         cp[i++] = t;
  2602.         t += UTF8SKIP(t);
  2603.         if (*t == 0xff) {
  2604.             t++;
  2605.             t += UTF8SKIP(t);
  2606.         }
  2607.         }
  2608.         qsort(cp, i, sizeof(U8*), utf8compare);
  2609.         for (j = 0; j < i; j++) {
  2610.         U8 *s = cp[j];
  2611.         UV val = utf8_to_uv(s, &ulen);
  2612.         s += ulen;
  2613.         diff = val - nextmin;
  2614.         if (diff > 0) {
  2615.             t = uv_to_utf8(tmpbuf,nextmin);
  2616.             sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
  2617.             if (diff > 1) {
  2618.             t = uv_to_utf8(tmpbuf, val - 1);
  2619.             sv_catpvn(transv, "\377", 1);
  2620.             sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
  2621.             }
  2622.             }
  2623.         if (*s == 0xff)
  2624.             val = utf8_to_uv(s+1, &ulen);
  2625.         if (val >= nextmin)
  2626.             nextmin = val + 1;
  2627.         }
  2628.         t = uv_to_utf8(tmpbuf,nextmin);
  2629.         sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
  2630.         t = uv_to_utf8(tmpbuf, 0x7fffffff);
  2631.         sv_catpvn(transv, "\377", 1);
  2632.         sv_catpvn(transv, (char*)tmpbuf, t - tmpbuf);
  2633.         t = (U8*)SvPVX(transv);
  2634.         tlen = SvCUR(transv);
  2635.         tend = t + tlen;
  2636.     }
  2637.     else if (!rlen && !del) {
  2638.         r = t; rlen = tlen; rend = tend;
  2639.     }
  2640.     if (!squash) {
  2641.         if (to_utf && from_utf) {    /* only counting characters */
  2642.         if (t == r || (tlen == rlen && memEQ(t, r, tlen)))
  2643.             o->op_private |= OPpTRANS_IDENTICAL;
  2644.         }
  2645.         else {    /* straight latin-1 translation */
  2646.         if (tlen == 4 && memEQ(t, "\0\377\303\277", 4) &&
  2647.             rlen == 4 && memEQ(r, "\0\377\303\277", 4))
  2648.             o->op_private |= OPpTRANS_IDENTICAL;
  2649.         }
  2650.     }
  2651.  
  2652.     while (t < tend || tfirst <= tlast) {
  2653.         /* see if we need more "t" chars */
  2654.         if (tfirst > tlast) {
  2655.         tfirst = (I32)utf8_to_uv(t, &ulen);
  2656.         t += ulen;
  2657.         if (t < tend && *t == 0xff) {    /* illegal utf8 val indicates range */
  2658.             tlast = (I32)utf8_to_uv(++t, &ulen);
  2659.             t += ulen;
  2660.         }
  2661.         else
  2662.             tlast = tfirst;
  2663.         }
  2664.  
  2665.         /* now see if we need more "r" chars */
  2666.         if (rfirst > rlast) {
  2667.         if (r < rend) {
  2668.             rfirst = (I32)utf8_to_uv(r, &ulen);
  2669.             r += ulen;
  2670.             if (r < rend && *r == 0xff) {    /* illegal utf8 val indicates range */
  2671.             rlast = (I32)utf8_to_uv(++r, &ulen);
  2672.             r += ulen;
  2673.             }
  2674.             else
  2675.             rlast = rfirst;
  2676.         }
  2677.         else {
  2678.             if (!havefinal++)
  2679.             final = rlast;
  2680.             rfirst = rlast = 0xffffffff;
  2681.         }
  2682.         }
  2683.  
  2684.         /* now see which range will peter our first, if either. */
  2685.         tdiff = tlast - tfirst;
  2686.         rdiff = rlast - rfirst;
  2687.  
  2688.         if (tdiff <= rdiff)
  2689.         diff = tdiff;
  2690.         else
  2691.         diff = rdiff;
  2692.  
  2693.         if (rfirst == 0xffffffff) {
  2694.         diff = tdiff;    /* oops, pretend rdiff is infinite */
  2695.         if (diff > 0)
  2696.             Perl_sv_catpvf(aTHX_ listsv, "%04lx\t%04lx\tXXXX\n",
  2697.                    (long)tfirst, (long)tlast);
  2698.         else
  2699.             Perl_sv_catpvf(aTHX_ listsv, "%04lx\t\tXXXX\n", (long)tfirst);
  2700.         }
  2701.         else {
  2702.         if (diff > 0)
  2703.             Perl_sv_catpvf(aTHX_ listsv, "%04lx\t%04lx\t%04lx\n",
  2704.                    (long)tfirst, (long)(tfirst + diff),
  2705.                    (long)rfirst);
  2706.         else
  2707.             Perl_sv_catpvf(aTHX_ listsv, "%04lx\t\t%04lx\n",
  2708.                    (long)tfirst, (long)rfirst);
  2709.  
  2710.         if (rfirst + diff > max)
  2711.             max = rfirst + diff;
  2712.         rfirst += diff + 1;
  2713.         if (!grows) {
  2714.             if (rfirst <= 0x80)
  2715.             ;
  2716.             else if (rfirst <= 0x800)
  2717.             grows |= (tfirst < 0x80);
  2718.             else if (rfirst <= 0x10000)
  2719.             grows |= (tfirst < 0x800);
  2720.             else if (rfirst <= 0x200000)
  2721.             grows |= (tfirst < 0x10000);
  2722.             else if (rfirst <= 0x4000000)
  2723.             grows |= (tfirst < 0x200000);
  2724.             else if (rfirst <= 0x80000000)
  2725.             grows |= (tfirst < 0x4000000);
  2726.         }
  2727.         }
  2728.         tfirst += diff + 1;
  2729.     }
  2730.  
  2731.     none = ++max;
  2732.     if (del)
  2733.         del = ++max;
  2734.  
  2735.     if (max > 0xffff)
  2736.         bits = 32;
  2737.     else if (max > 0xff)
  2738.         bits = 16;
  2739.     else
  2740.         bits = 8;
  2741.  
  2742.     cSVOPo->op_sv = (SV*)swash_init("utf8", "", listsv, bits, none);
  2743.     SvREFCNT_dec(listsv);
  2744.     if (transv)
  2745.         SvREFCNT_dec(transv);
  2746.  
  2747.     if (!del && havefinal)
  2748.         (void)hv_store((HV*)SvRV((cSVOPo->op_sv)), "FINAL", 5,
  2749.                newSVuv((UV)final), 0);
  2750.  
  2751.     if (grows && to_utf)
  2752.         o->op_private |= OPpTRANS_GROWS;
  2753.  
  2754.     op_free(expr);
  2755.     op_free(repl);
  2756.     return o;
  2757.     }
  2758.  
  2759.     tbl = (short*)cPVOPo->op_pv;
  2760.     if (complement) {
  2761.     Zero(tbl, 256, short);
  2762.     for (i = 0; i < tlen; i++)
  2763.         tbl[t[i]] = -1;
  2764.     for (i = 0, j = 0; i < 256; i++) {
  2765.         if (!tbl[i]) {
  2766.         if (j >= rlen) {
  2767.             if (del)
  2768.             tbl[i] = -2;
  2769.             else if (rlen)
  2770.             tbl[i] = r[j-1];
  2771.             else
  2772.             tbl[i] = i;
  2773.         }
  2774.         else
  2775.             tbl[i] = r[j++];
  2776.         }
  2777.     }
  2778.     }
  2779.     else {
  2780.     if (!rlen && !del) {
  2781.         r = t; rlen = tlen;
  2782.         if (!squash)
  2783.         o->op_private |= OPpTRANS_IDENTICAL;
  2784.     }
  2785.     for (i = 0; i < 256; i++)
  2786.         tbl[i] = -1;
  2787.     for (i = 0, j = 0; i < tlen; i++,j++) {
  2788.         if (j >= rlen) {
  2789.         if (del) {
  2790.             if (tbl[t[i]] == -1)
  2791.             tbl[t[i]] = -2;
  2792.             continue;
  2793.         }
  2794.         --j;
  2795.         }
  2796.         if (tbl[t[i]] == -1)
  2797.         tbl[t[i]] = r[j];
  2798.     }
  2799.     }
  2800.     op_free(expr);
  2801.     op_free(repl);
  2802.  
  2803.     return o;
  2804. }
  2805.  
  2806. OP *
  2807. Perl_newPMOP(pTHX_ I32 type, I32 flags)
  2808. {
  2809.     dTHR;
  2810.     PMOP *pmop;
  2811.  
  2812.     NewOp(1101, pmop, 1, PMOP);
  2813.     pmop->op_type = type;
  2814.     pmop->op_ppaddr = PL_ppaddr[type];
  2815.     pmop->op_flags = flags;
  2816.     pmop->op_private = 0 | (flags >> 8);
  2817.  
  2818.     if (PL_hints & HINT_RE_TAINT)
  2819.     pmop->op_pmpermflags |= PMf_RETAINT;
  2820.     if (PL_hints & HINT_LOCALE)
  2821.     pmop->op_pmpermflags |= PMf_LOCALE;
  2822.     pmop->op_pmflags = pmop->op_pmpermflags;
  2823.  
  2824.     /* link into pm list */
  2825.     if (type != OP_TRANS && PL_curstash) {
  2826.     pmop->op_pmnext = HvPMROOT(PL_curstash);
  2827.     HvPMROOT(PL_curstash) = pmop;
  2828.     }
  2829.  
  2830.     return (OP*)pmop;
  2831. }
  2832.  
  2833. OP *
  2834. Perl_pmruntime(pTHX_ OP *o, OP *expr, OP *repl)
  2835. {
  2836.     dTHR;
  2837.     PMOP *pm;
  2838.     LOGOP *rcop;
  2839.     I32 repl_has_vars = 0;
  2840.  
  2841.     if (o->op_type == OP_TRANS)
  2842.     return pmtrans(o, expr, repl);
  2843.  
  2844.     PL_hints |= HINT_BLOCK_SCOPE;
  2845.     pm = (PMOP*)o;
  2846.  
  2847.     if (expr->op_type == OP_CONST) {
  2848.     STRLEN plen;
  2849.     SV *pat = ((SVOP*)expr)->op_sv;
  2850.     char *p = SvPV(pat, plen);
  2851.     if ((o->op_flags & OPf_SPECIAL) && strEQ(p, " ")) {
  2852.         sv_setpvn(pat, "\\s+", 3);
  2853.         p = SvPV(pat, plen);
  2854.         pm->op_pmflags |= PMf_SKIPWHITE;
  2855.     }
  2856.     if ((PL_hints & HINT_UTF8) || (SvUTF8(pat) && !(PL_hints & HINT_BYTE)))
  2857.         pm->op_pmdynflags |= PMdf_UTF8;
  2858.     pm->op_pmregexp = CALLREGCOMP(aTHX_ p, p + plen, pm);
  2859.     if (strEQ("\\s+", pm->op_pmregexp->precomp))
  2860.         pm->op_pmflags |= PMf_WHITE;
  2861.     op_free(expr);
  2862.     }
  2863.     else {
  2864.     if (PL_hints & HINT_UTF8)
  2865.         pm->op_pmdynflags |= PMdf_UTF8;
  2866.     if (pm->op_pmflags & PMf_KEEP || !(PL_hints & HINT_RE_EVAL))
  2867.         expr = newUNOP((!(PL_hints & HINT_RE_EVAL) 
  2868.                 ? OP_REGCRESET
  2869.                 : OP_REGCMAYBE),0,expr);
  2870.  
  2871.     NewOp(1101, rcop, 1, LOGOP);
  2872.     rcop->op_type = OP_REGCOMP;
  2873.     rcop->op_ppaddr = PL_ppaddr[OP_REGCOMP];
  2874.     rcop->op_first = scalar(expr);
  2875.     rcop->op_flags |= ((PL_hints & HINT_RE_EVAL) 
  2876.                ? (OPf_SPECIAL | OPf_KIDS)
  2877.                : OPf_KIDS);
  2878.     rcop->op_private = 1;
  2879.     rcop->op_other = o;
  2880.  
  2881.     /* establish postfix order */
  2882.     if (pm->op_pmflags & PMf_KEEP || !(PL_hints & HINT_RE_EVAL)) {
  2883.         LINKLIST(expr);
  2884.         rcop->op_next = expr;
  2885.         ((UNOP*)expr)->op_first->op_next = (OP*)rcop;
  2886.     }
  2887.     else {
  2888.         rcop->op_next = LINKLIST(expr);
  2889.         expr->op_next = (OP*)rcop;
  2890.     }
  2891.  
  2892.     prepend_elem(o->op_type, scalar((OP*)rcop), o);
  2893.     }
  2894.  
  2895.     if (repl) {
  2896.     OP *curop;
  2897.     if (pm->op_pmflags & PMf_EVAL) {
  2898.         curop = 0;
  2899.         if (CopLINE(PL_curcop) < PL_multi_end)
  2900.         CopLINE_set(PL_curcop, PL_multi_end);
  2901.     }
  2902. #ifdef USE_THREADS
  2903.     else if (repl->op_type == OP_THREADSV
  2904.          && strchr("&`'123456789+",
  2905.                PL_threadsv_names[repl->op_targ]))
  2906.     {
  2907.         curop = 0;
  2908.     }
  2909. #endif /* USE_THREADS */
  2910.     else if (repl->op_type == OP_CONST)
  2911.         curop = repl;
  2912.     else {
  2913.         OP *lastop = 0;
  2914.         for (curop = LINKLIST(repl); curop!=repl; curop = LINKLIST(curop)) {
  2915.         if (PL_opargs[curop->op_type] & OA_DANGEROUS) {
  2916. #ifdef USE_THREADS
  2917.             if (curop->op_type == OP_THREADSV) {
  2918.             repl_has_vars = 1;
  2919.             if (strchr("&`'123456789+", curop->op_private))
  2920.                 break;
  2921.             }
  2922. #else
  2923.             if (curop->op_type == OP_GV) {
  2924.             GV *gv = cGVOPx_gv(curop);
  2925.             repl_has_vars = 1;
  2926.             if (strchr("&`'123456789+", *GvENAME(gv)))
  2927.                 break;
  2928.             }
  2929. #endif /* USE_THREADS */
  2930.             else if (curop->op_type == OP_RV2CV)
  2931.             break;
  2932.             else if (curop->op_type == OP_RV2SV ||
  2933.                  curop->op_type == OP_RV2AV ||
  2934.                  curop->op_type == OP_RV2HV ||
  2935.                  curop->op_type == OP_RV2GV) {
  2936.             if (lastop && lastop->op_type != OP_GV)    /*funny deref?*/
  2937.                 break;
  2938.             }
  2939.             else if (curop->op_type == OP_PADSV ||
  2940.                  curop->op_type == OP_PADAV ||
  2941.                  curop->op_type == OP_PADHV ||
  2942.                  curop->op_type == OP_PADANY) {
  2943.             repl_has_vars = 1;
  2944.             }
  2945.             else if (curop->op_type == OP_PUSHRE)
  2946.             ; /* Okay here, dangerous in newASSIGNOP */
  2947.             else
  2948.             break;
  2949.         }
  2950.         lastop = curop;
  2951.         }
  2952.     }
  2953.     if (curop == repl
  2954.         && !(repl_has_vars 
  2955.          && (!pm->op_pmregexp 
  2956.              || pm->op_pmregexp->reganch & ROPT_EVAL_SEEN))) {
  2957.         pm->op_pmflags |= PMf_CONST;    /* const for long enough */
  2958.         pm->op_pmpermflags |= PMf_CONST;    /* const for long enough */
  2959.         prepend_elem(o->op_type, scalar(repl), o);
  2960.     }
  2961.     else {
  2962.         if (curop == repl && !pm->op_pmregexp) { /* Has variables. */
  2963.         pm->op_pmflags |= PMf_MAYBE_CONST;
  2964.         pm->op_pmpermflags |= PMf_MAYBE_CONST;
  2965.         }
  2966.         NewOp(1101, rcop, 1, LOGOP);
  2967.         rcop->op_type = OP_SUBSTCONT;
  2968.         rcop->op_ppaddr = PL_ppaddr[OP_SUBSTCONT];
  2969.         rcop->op_first = scalar(repl);
  2970.         rcop->op_flags |= OPf_KIDS;
  2971.         rcop->op_private = 1;
  2972.         rcop->op_other = o;
  2973.  
  2974.         /* establish postfix order */
  2975.         rcop->op_next = LINKLIST(repl);
  2976.         repl->op_next = (OP*)rcop;
  2977.  
  2978.         pm->op_pmreplroot = scalar((OP*)rcop);
  2979.         pm->op_pmreplstart = LINKLIST(rcop);
  2980.         rcop->op_next = 0;
  2981.     }
  2982.     }
  2983.  
  2984.     return (OP*)pm;
  2985. }
  2986.  
  2987. OP *
  2988. Perl_newSVOP(pTHX_ I32 type, I32 flags, SV *sv)
  2989. {
  2990.     SVOP *svop;
  2991.     NewOp(1101, svop, 1, SVOP);
  2992.     svop->op_type = type;
  2993.     svop->op_ppaddr = PL_ppaddr[type];
  2994.     svop->op_sv = sv;
  2995.     svop->op_next = (OP*)svop;
  2996.     svop->op_flags = flags;
  2997.     if (PL_opargs[type] & OA_RETSCALAR)
  2998.     scalar((OP*)svop);
  2999.     if (PL_opargs[type] & OA_TARGET)
  3000.     svop->op_targ = pad_alloc(type, SVs_PADTMP);
  3001.     return CHECKOP(type, svop);
  3002. }
  3003.  
  3004. OP *
  3005. Perl_newPADOP(pTHX_ I32 type, I32 flags, SV *sv)
  3006. {
  3007.     PADOP *padop;
  3008.     NewOp(1101, padop, 1, PADOP);
  3009.     padop->op_type = type;
  3010.     padop->op_ppaddr = PL_ppaddr[type];
  3011.     padop->op_padix = pad_alloc(type, SVs_PADTMP);
  3012.     SvREFCNT_dec(PL_curpad[padop->op_padix]);
  3013.     PL_curpad[padop->op_padix] = sv;
  3014.     SvPADTMP_on(sv);
  3015.     padop->op_next = (OP*)padop;
  3016.     padop->op_flags = flags;
  3017.     if (PL_opargs[type] & OA_RETSCALAR)
  3018.     scalar((OP*)padop);
  3019.     if (PL_opargs[type] & OA_TARGET)
  3020.     padop->op_targ = pad_alloc(type, SVs_PADTMP);
  3021.     return CHECKOP(type, padop);
  3022. }
  3023.  
  3024. OP *
  3025. Perl_newGVOP(pTHX_ I32 type, I32 flags, GV *gv)
  3026. {
  3027.     dTHR;
  3028. #ifdef USE_ITHREADS
  3029.     GvIN_PAD_on(gv);
  3030.     return newPADOP(type, flags, SvREFCNT_inc(gv));
  3031. #else
  3032.     return newSVOP(type, flags, SvREFCNT_inc(gv));
  3033. #endif
  3034. }
  3035.  
  3036. OP *
  3037. Perl_newPVOP(pTHX_ I32 type, I32 flags, char *pv)
  3038. {
  3039.     PVOP *pvop;
  3040.     NewOp(1101, pvop, 1, PVOP);
  3041.     pvop->op_type = type;
  3042.     pvop->op_ppaddr = PL_ppaddr[type];
  3043.     pvop->op_pv = pv;
  3044.     pvop->op_next = (OP*)pvop;
  3045.     pvop->op_flags = flags;
  3046.     if (PL_opargs[type] & OA_RETSCALAR)
  3047.     scalar((OP*)pvop);
  3048.     if (PL_opargs[type] & OA_TARGET)
  3049.     pvop->op_targ = pad_alloc(type, SVs_PADTMP);
  3050.     return CHECKOP(type, pvop);
  3051. }
  3052.  
  3053. void
  3054. Perl_package(pTHX_ OP *o)
  3055. {
  3056.     dTHR;
  3057.     SV *sv;
  3058.  
  3059.     save_hptr(&PL_curstash);
  3060.     save_item(PL_curstname);
  3061.     if (o) {
  3062.     STRLEN len;
  3063.     char *name;
  3064.     sv = cSVOPo->op_sv;
  3065.     name = SvPV(sv, len);
  3066.     PL_curstash = gv_stashpvn(name,len,TRUE);
  3067.     sv_setpvn(PL_curstname, name, len);
  3068.     op_free(o);
  3069.     }
  3070.     else {
  3071.     sv_setpv(PL_curstname,"<none>");
  3072.     PL_curstash = Nullhv;
  3073.     }
  3074.     PL_hints |= HINT_BLOCK_SCOPE;
  3075.     PL_copline = NOLINE;
  3076.     PL_expect = XSTATE;
  3077. }
  3078.  
  3079. void
  3080. Perl_utilize(pTHX_ int aver, I32 floor, OP *version, OP *id, OP *arg)
  3081. {
  3082.     OP *pack;
  3083.     OP *rqop;
  3084.     OP *imop;
  3085.     OP *veop;
  3086.     GV *gv;
  3087.  
  3088.     if (id->op_type != OP_CONST)
  3089.     Perl_croak(aTHX_ "Module name must be constant");
  3090.  
  3091.     veop = Nullop;
  3092.  
  3093.     if (version != Nullop) {
  3094.     SV *vesv = ((SVOP*)version)->op_sv;
  3095.  
  3096.     if (arg == Nullop && !SvNIOKp(vesv)) {
  3097.         arg = version;
  3098.     }
  3099.     else {
  3100.         OP *pack;
  3101.         SV *meth;
  3102.  
  3103.         if (version->op_type != OP_CONST || !SvNIOKp(vesv))
  3104.         Perl_croak(aTHX_ "Version number must be constant number");
  3105.  
  3106.         /* Make copy of id so we don't free it twice */
  3107.         pack = newSVOP(OP_CONST, 0, newSVsv(((SVOP*)id)->op_sv));
  3108.  
  3109.         /* Fake up a method call to VERSION */
  3110.         meth = newSVpvn("VERSION",7);
  3111.         sv_upgrade(meth, SVt_PVIV);
  3112.         (void)SvIOK_on(meth);
  3113.         PERL_HASH(SvUVX(meth), SvPVX(meth), SvCUR(meth));
  3114.         veop = convert(OP_ENTERSUB, OPf_STACKED|OPf_SPECIAL,
  3115.                 append_elem(OP_LIST,
  3116.                     prepend_elem(OP_LIST, pack, list(version)),
  3117.                     newSVOP(OP_METHOD_NAMED, 0, meth)));
  3118.     }
  3119.     }
  3120.  
  3121.     /* Fake up an import/unimport */
  3122.     if (arg && arg->op_type == OP_STUB)
  3123.     imop = arg;        /* no import on explicit () */
  3124.     else if (SvNIOKp(((SVOP*)id)->op_sv)) {
  3125.     imop = Nullop;        /* use 5.0; */
  3126.     }
  3127.     else {
  3128.     SV *meth;
  3129.  
  3130.     /* Make copy of id so we don't free it twice */
  3131.     pack = newSVOP(OP_CONST, 0, newSVsv(((SVOP*)id)->op_sv));
  3132.  
  3133.     /* Fake up a method call to import/unimport */
  3134.     meth = aver ? newSVpvn("import",6) : newSVpvn("unimport", 8);;
  3135.     sv_upgrade(meth, SVt_PVIV);
  3136.     (void)SvIOK_on(meth);
  3137.     PERL_HASH(SvUVX(meth), SvPVX(meth), SvCUR(meth));
  3138.     imop = convert(OP_ENTERSUB, OPf_STACKED|OPf_SPECIAL,
  3139.                append_elem(OP_LIST,
  3140.                    prepend_elem(OP_LIST, pack, list(arg)),
  3141.                    newSVOP(OP_METHOD_NAMED, 0, meth)));
  3142.     }
  3143.  
  3144.     /* Fake up a require, handle override, if any */
  3145.     gv = gv_fetchpv("require", FALSE, SVt_PVCV);
  3146.     if (!(gv && GvIMPORTED_CV(gv)))
  3147.     gv = gv_fetchpv("CORE::GLOBAL::require", FALSE, SVt_PVCV);
  3148.  
  3149.     if (gv && GvIMPORTED_CV(gv)) {
  3150.     rqop = ck_subr(newUNOP(OP_ENTERSUB, OPf_STACKED,
  3151.                    append_elem(OP_LIST, id,
  3152.                        scalar(newUNOP(OP_RV2CV, 0,
  3153.                               newGVOP(OP_GV, 0,
  3154.                                   gv))))));
  3155.     }
  3156.     else {
  3157.     rqop = newUNOP(OP_REQUIRE, 0, id);
  3158.     }
  3159.  
  3160.     /* Fake up the BEGIN {}, which does its thing immediately. */
  3161.     newATTRSUB(floor,
  3162.     newSVOP(OP_CONST, 0, newSVpvn("BEGIN", 5)),
  3163.     Nullop,
  3164.     Nullop,
  3165.     append_elem(OP_LINESEQ,
  3166.         append_elem(OP_LINESEQ,
  3167.             newSTATEOP(0, Nullch, rqop),
  3168.             newSTATEOP(0, Nullch, veop)),
  3169.         newSTATEOP(0, Nullch, imop) ));
  3170.  
  3171.     PL_hints |= HINT_BLOCK_SCOPE;
  3172.     PL_copline = NOLINE;
  3173.     PL_expect = XSTATE;
  3174. }
  3175.  
  3176. void
  3177. Perl_load_module(pTHX_ U32 flags, SV *name, SV *ver, ...)
  3178. {
  3179.     va_list args;
  3180.     va_start(args, ver);
  3181.     vload_module(flags, name, ver, &args);
  3182.     va_end(args);
  3183. }
  3184.  
  3185. #ifdef PERL_IMPLICIT_CONTEXT
  3186. void
  3187. Perl_load_module_nocontext(U32 flags, SV *name, SV *ver, ...)
  3188. {
  3189.     dTHX;
  3190.     va_list args;
  3191.     va_start(args, ver);
  3192.     vload_module(flags, name, ver, &args);
  3193.     va_end(args);
  3194. }
  3195. #endif
  3196.  
  3197. void
  3198. Perl_vload_module(pTHX_ U32 flags, SV *name, SV *ver, va_list *args)
  3199. {
  3200.     OP *modname, *veop, *imop;
  3201.  
  3202.     modname = newSVOP(OP_CONST, 0, name);
  3203.     modname->op_private |= OPpCONST_BARE;
  3204.     if (ver) {
  3205.     veop = newSVOP(OP_CONST, 0, ver);
  3206.     }
  3207.     else
  3208.     veop = Nullop;
  3209.     if (flags & PERL_LOADMOD_NOIMPORT) {
  3210.     imop = sawparens(newNULLLIST());
  3211.     }
  3212.     else if (flags & PERL_LOADMOD_IMPORT_OPS) {
  3213.     imop = va_arg(*args, OP*);
  3214.     }
  3215.     else {
  3216.     SV *sv;
  3217.     imop = Nullop;
  3218.     sv = va_arg(*args, SV*);
  3219.     while (sv) {
  3220.         imop = append_elem(OP_LIST, imop, newSVOP(OP_CONST, 0, sv));
  3221.         sv = va_arg(*args, SV*);
  3222.     }
  3223.     }
  3224.     utilize(!(flags & PERL_LOADMOD_DENY), start_subparse(FALSE, 0),
  3225.         veop, modname, imop);
  3226. }
  3227.  
  3228. OP *
  3229. Perl_dofile(pTHX_ OP *term)
  3230. {
  3231.     OP *doop;
  3232.     GV *gv;
  3233.  
  3234.     gv = gv_fetchpv("do", FALSE, SVt_PVCV);
  3235.     if (!(gv && GvIMPORTED_CV(gv)))
  3236.     gv = gv_fetchpv("CORE::GLOBAL::do", FALSE, SVt_PVCV);
  3237.  
  3238.     if (gv && GvIMPORTED_CV(gv)) {
  3239.     doop = ck_subr(newUNOP(OP_ENTERSUB, OPf_STACKED,
  3240.                    append_elem(OP_LIST, term,
  3241.                        scalar(newUNOP(OP_RV2CV, 0,
  3242.                               newGVOP(OP_GV, 0,
  3243.                                   gv))))));
  3244.     }
  3245.     else {
  3246.     doop = newUNOP(OP_DOFILE, 0, scalar(term));
  3247.     }
  3248.     return doop;
  3249. }
  3250.  
  3251. OP *
  3252. Perl_newSLICEOP(pTHX_ I32 flags, OP *subscript, OP *listval)
  3253. {
  3254.     return newBINOP(OP_LSLICE, flags,
  3255.         list(force_list(subscript)),
  3256.         list(force_list(listval)) );
  3257. }
  3258.  
  3259. STATIC I32
  3260. S_list_assignment(pTHX_ register OP *o)
  3261. {
  3262.     if (!o)
  3263.     return TRUE;
  3264.  
  3265.     if (o->op_type == OP_NULL && o->op_flags & OPf_KIDS)
  3266.     o = cUNOPo->op_first;
  3267.  
  3268.     if (o->op_type == OP_COND_EXPR) {
  3269.     I32 t = list_assignment(cLOGOPo->op_first->op_sibling);
  3270.     I32 f = list_assignment(cLOGOPo->op_first->op_sibling->op_sibling);
  3271.  
  3272.     if (t && f)
  3273.         return TRUE;
  3274.     if (t || f)
  3275.         yyerror("Assignment to both a list and a scalar");
  3276.     return FALSE;
  3277.     }
  3278.  
  3279.     if (o->op_type == OP_LIST || o->op_flags & OPf_PARENS ||
  3280.     o->op_type == OP_RV2AV || o->op_type == OP_RV2HV ||
  3281.     o->op_type == OP_ASLICE || o->op_type == OP_HSLICE)
  3282.     return TRUE;
  3283.  
  3284.     if (o->op_type == OP_PADAV || o->op_type == OP_PADHV)
  3285.     return TRUE;
  3286.  
  3287.     if (o->op_type == OP_RV2SV)
  3288.     return FALSE;
  3289.  
  3290.     return FALSE;
  3291. }
  3292.  
  3293. OP *
  3294. Perl_newASSIGNOP(pTHX_ I32 flags, OP *left, I32 optype, OP *right)
  3295. {
  3296.     OP *o;
  3297.  
  3298.     if (optype) {
  3299.     if (optype == OP_ANDASSIGN || optype == OP_ORASSIGN) {
  3300.         return newLOGOP(optype, 0,
  3301.         mod(scalar(left), optype),
  3302.         newUNOP(OP_SASSIGN, 0, scalar(right)));
  3303.     }
  3304.     else {
  3305.         return newBINOP(optype, OPf_STACKED,
  3306.         mod(scalar(left), optype), scalar(right));
  3307.     }
  3308.     }
  3309.  
  3310.     if (list_assignment(left)) {
  3311.     dTHR;
  3312.     OP *curop;
  3313.  
  3314.     PL_modcount = 0;
  3315.     PL_eval_start = right;    /* Grandfathering $[ assignment here.  Bletch.*/
  3316.     left = mod(left, OP_AASSIGN);
  3317.     if (PL_eval_start)
  3318.         PL_eval_start = 0;
  3319.     else {
  3320.         op_free(left);
  3321.         op_free(right);
  3322.         return Nullop;
  3323.     }
  3324.     curop = list(force_list(left));
  3325.     o = newBINOP(OP_AASSIGN, flags, list(force_list(right)), curop);
  3326.     o->op_private = 0 | (flags >> 8);
  3327.     for (curop = ((LISTOP*)curop)->op_first;
  3328.          curop; curop = curop->op_sibling)
  3329.     {
  3330.         if (curop->op_type == OP_RV2HV &&
  3331.         ((UNOP*)curop)->op_first->op_type != OP_GV) {
  3332.         o->op_private |= OPpASSIGN_HASH;
  3333.         break;
  3334.         }
  3335.     }
  3336.     if (!(left->op_private & OPpLVAL_INTRO)) {
  3337.         OP *lastop = o;
  3338.         PL_generation++;
  3339.         for (curop = LINKLIST(o); curop != o; curop = LINKLIST(curop)) {
  3340.         if (PL_opargs[curop->op_type] & OA_DANGEROUS) {
  3341.             if (curop->op_type == OP_GV) {
  3342.             GV *gv = cGVOPx_gv(curop);
  3343.             if (gv == PL_defgv || SvCUR(gv) == PL_generation)
  3344.                 break;
  3345.             SvCUR(gv) = PL_generation;
  3346.             }
  3347.             else if (curop->op_type == OP_PADSV ||
  3348.                  curop->op_type == OP_PADAV ||
  3349.                  curop->op_type == OP_PADHV ||
  3350.                  curop->op_type == OP_PADANY) {
  3351.             SV **svp = AvARRAY(PL_comppad_name);
  3352.             SV *sv = svp[curop->op_targ];
  3353.             if (SvCUR(sv) == PL_generation)
  3354.                 break;
  3355.             SvCUR(sv) = PL_generation;    /* (SvCUR not used any more) */
  3356.             }
  3357.             else if (curop->op_type == OP_RV2CV)
  3358.             break;
  3359.             else if (curop->op_type == OP_RV2SV ||
  3360.                  curop->op_type == OP_RV2AV ||
  3361.                  curop->op_type == OP_RV2HV ||
  3362.                  curop->op_type == OP_RV2GV) {
  3363.             if (lastop->op_type != OP_GV)    /* funny deref? */
  3364.                 break;
  3365.             }
  3366.             else if (curop->op_type == OP_PUSHRE) {
  3367.             if (((PMOP*)curop)->op_pmreplroot) {
  3368.                 GV *gv = (GV*)((PMOP*)curop)->op_pmreplroot;
  3369.                 if (gv == PL_defgv || SvCUR(gv) == PL_generation)
  3370.                 break;
  3371.                 SvCUR(gv) = PL_generation;
  3372.             }    
  3373.             }
  3374.             else
  3375.             break;
  3376.         }
  3377.         lastop = curop;
  3378.         }
  3379.         if (curop != o)
  3380.         o->op_private |= OPpASSIGN_COMMON;
  3381.     }
  3382.     if (right && right->op_type == OP_SPLIT) {
  3383.         OP* tmpop;
  3384.         if ((tmpop = ((LISTOP*)right)->op_first) &&
  3385.         tmpop->op_type == OP_PUSHRE)
  3386.         {
  3387.         PMOP *pm = (PMOP*)tmpop;
  3388.         if (left->op_type == OP_RV2AV &&
  3389.             !(left->op_private & OPpLVAL_INTRO) &&
  3390.             !(o->op_private & OPpASSIGN_COMMON) )
  3391.         {
  3392.             tmpop = ((UNOP*)left)->op_first;
  3393.             if (tmpop->op_type == OP_GV && !pm->op_pmreplroot) {
  3394. #ifdef USE_ITHREADS
  3395.             pm->op_pmreplroot = (OP*)cPADOPx(tmpop)->op_padix;
  3396.             cPADOPx(tmpop)->op_padix = 0;    /* steal it */
  3397. #else
  3398.             pm->op_pmreplroot = (OP*)cSVOPx(tmpop)->op_sv;
  3399.             cSVOPx(tmpop)->op_sv = Nullsv;    /* steal it */
  3400. #endif
  3401.             pm->op_pmflags |= PMf_ONCE;
  3402.             tmpop = cUNOPo->op_first;    /* to list (nulled) */
  3403.             tmpop = ((UNOP*)tmpop)->op_first; /* to pushmark */
  3404.             tmpop->op_sibling = Nullop;    /* don't free split */
  3405.             right->op_next = tmpop->op_next;  /* fix starting loc */
  3406.             op_free(o);            /* blow off assign */
  3407.             right->op_flags &= ~OPf_WANT;
  3408.                 /* "I don't know and I don't care." */
  3409.             return right;
  3410.             }
  3411.         }
  3412.         else {
  3413.             if (PL_modcount < 10000 &&
  3414.               ((LISTOP*)right)->op_last->op_type == OP_CONST)
  3415.             {
  3416.             SV *sv = ((SVOP*)((LISTOP*)right)->op_last)->op_sv;
  3417.             if (SvIVX(sv) == 0)
  3418.                 sv_setiv(sv, PL_modcount+1);
  3419.             }
  3420.         }
  3421.         }
  3422.     }
  3423.     return o;
  3424.     }
  3425.     if (!right)
  3426.     right = newOP(OP_UNDEF, 0);
  3427.     if (right->op_type == OP_READLINE) {
  3428.     right->op_flags |= OPf_STACKED;
  3429.     return newBINOP(OP_NULL, flags, mod(scalar(left), OP_SASSIGN), scalar(right));
  3430.     }
  3431.     else {
  3432.     PL_eval_start = right;    /* Grandfathering $[ assignment here.  Bletch.*/
  3433.     o = newBINOP(OP_SASSIGN, flags,
  3434.         scalar(right), mod(scalar(left), OP_SASSIGN) );
  3435.     if (PL_eval_start)
  3436.         PL_eval_start = 0;
  3437.     else {
  3438.         op_free(o);
  3439.         return Nullop;
  3440.     }
  3441.     }
  3442.     return o;
  3443. }
  3444.  
  3445. OP *
  3446. Perl_newSTATEOP(pTHX_ I32 flags, char *label, OP *o)
  3447. {
  3448.     dTHR;
  3449.     U32 seq = intro_my();
  3450.     register COP *cop;
  3451.  
  3452.     NewOp(1101, cop, 1, COP);
  3453.     if (PERLDB_LINE && CopLINE(PL_curcop) && PL_curstash != PL_debstash) {
  3454.     cop->op_type = OP_DBSTATE;
  3455.     cop->op_ppaddr = PL_ppaddr[ OP_DBSTATE ];
  3456.     }
  3457.     else {
  3458.     cop->op_type = OP_NEXTSTATE;
  3459.     cop->op_ppaddr = PL_ppaddr[ OP_NEXTSTATE ];
  3460.     }
  3461.     cop->op_flags = flags;
  3462.     cop->op_private = (PL_hints & HINT_BYTE);
  3463. #ifdef NATIVE_HINTS
  3464.     cop->op_private |= NATIVE_HINTS;
  3465. #endif
  3466.     PL_compiling.op_private = cop->op_private;
  3467.     cop->op_next = (OP*)cop;
  3468.  
  3469.     if (label) {
  3470.     cop->cop_label = label;
  3471.     PL_hints |= HINT_BLOCK_SCOPE;
  3472.     }
  3473.     cop->cop_seq = seq;
  3474.     cop->cop_arybase = PL_curcop->cop_arybase;
  3475.     if (specialWARN(PL_curcop->cop_warnings))
  3476.         cop->cop_warnings = PL_curcop->cop_warnings ;
  3477.     else 
  3478.         cop->cop_warnings = newSVsv(PL_curcop->cop_warnings) ;
  3479.  
  3480.  
  3481.     if (PL_copline == NOLINE)
  3482.         CopLINE_set(cop, CopLINE(PL_curcop));
  3483.     else {
  3484.     CopLINE_set(cop, PL_copline);
  3485.         PL_copline = NOLINE;
  3486.     }
  3487. #ifdef USE_ITHREADS
  3488.     CopFILE_set(cop, CopFILE(PL_curcop));    /* XXXXX share in a pvtable? */
  3489. #else
  3490.     CopFILEGV_set(cop, (GV*)SvREFCNT_inc(CopFILEGV(PL_curcop)));
  3491. #endif
  3492.     CopSTASH_set(cop, PL_curstash);
  3493.  
  3494.     if (PERLDB_LINE && PL_curstash != PL_debstash) {
  3495.     SV **svp = av_fetch(CopFILEAV(PL_curcop), (I32)CopLINE(cop), FALSE);
  3496.     if (svp && *svp != &PL_sv_undef && !SvIOK(*svp)) {
  3497.         (void)SvIOK_on(*svp);
  3498.         SvIVX(*svp) = PTR2IV(cop);
  3499.     }
  3500.     }
  3501.  
  3502.     return prepend_elem(OP_LINESEQ, (OP*)cop, o);
  3503. }
  3504.  
  3505. /* "Introduce" my variables to visible status. */
  3506. U32
  3507. Perl_intro_my(pTHX)
  3508. {
  3509.     SV **svp;
  3510.     SV *sv;
  3511.     I32 i;
  3512.  
  3513.     if (! PL_min_intro_pending)
  3514.     return PL_cop_seqmax;
  3515.  
  3516.     svp = AvARRAY(PL_comppad_name);
  3517.     for (i = PL_min_intro_pending; i <= PL_max_intro_pending; i++) {
  3518.     if ((sv = svp[i]) && sv != &PL_sv_undef && !SvIVX(sv)) {
  3519.         SvIVX(sv) = PAD_MAX;    /* Don't know scope end yet. */
  3520.         SvNVX(sv) = (NV)PL_cop_seqmax;
  3521.     }
  3522.     }
  3523.     PL_min_intro_pending = 0;
  3524.     PL_comppad_name_fill = PL_max_intro_pending;    /* Needn't search higher */
  3525.     return PL_cop_seqmax++;
  3526. }
  3527.  
  3528. OP *
  3529. Perl_newLOGOP(pTHX_ I32 type, I32 flags, OP *first, OP *other)
  3530. {
  3531.     return new_logop(type, flags, &first, &other);
  3532. }
  3533.  
  3534. STATIC OP *
  3535. S_new_logop(pTHX_ I32 type, I32 flags, OP** firstp, OP** otherp)
  3536. {
  3537.     dTHR;
  3538.     LOGOP *logop;
  3539.     OP *o;
  3540.     OP *first = *firstp;
  3541.     OP *other = *otherp;
  3542.  
  3543.     if (type == OP_XOR)        /* Not short circuit, but here by precedence. */
  3544.     return newBINOP(type, flags, scalar(first), scalar(other));
  3545.  
  3546.     scalarboolean(first);
  3547.     /* optimize "!a && b" to "a || b", and "!a || b" to "a && b" */
  3548.     if (first->op_type == OP_NOT && (first->op_flags & OPf_SPECIAL)) {
  3549.     if (type == OP_AND || type == OP_OR) {
  3550.         if (type == OP_AND)
  3551.         type = OP_OR;
  3552.         else
  3553.         type = OP_AND;
  3554.         o = first;
  3555.         first = *firstp = cUNOPo->op_first;
  3556.         if (o->op_next)
  3557.         first->op_next = o->op_next;
  3558.         cUNOPo->op_first = Nullop;
  3559.         op_free(o);
  3560.     }
  3561.     }
  3562.     if (first->op_type == OP_CONST) {
  3563.     if (ckWARN(WARN_BAREWORD) && (first->op_private & OPpCONST_BARE))
  3564.         Perl_warner(aTHX_ WARN_BAREWORD, "Bareword found in conditional"); 
  3565.     if ((type == OP_AND) == (SvTRUE(((SVOP*)first)->op_sv))) {
  3566.         op_free(first);
  3567.         *firstp = Nullop;
  3568.         return other;
  3569.     }
  3570.     else {
  3571.         op_free(other);
  3572.         *otherp = Nullop;
  3573.         return first;
  3574.     }
  3575.     }
  3576.     else if (first->op_type == OP_WANTARRAY) {
  3577.     if (type == OP_AND)
  3578.         list(other);
  3579.     else
  3580.         scalar(other);
  3581.     }
  3582.     else if (ckWARN(WARN_MISC) && (first->op_flags & OPf_KIDS)) {
  3583.     OP *k1 = ((UNOP*)first)->op_first;
  3584.     OP *k2 = k1->op_sibling;
  3585.     OPCODE warnop = 0;
  3586.     switch (first->op_type)
  3587.     {
  3588.     case OP_NULL:
  3589.         if (k2 && k2->op_type == OP_READLINE
  3590.           && (k2->op_flags & OPf_STACKED)
  3591.           && ((k1->op_flags & OPf_WANT) == OPf_WANT_SCALAR)) 
  3592.         {
  3593.         warnop = k2->op_type;
  3594.         }
  3595.         break;
  3596.  
  3597.     case OP_SASSIGN:
  3598.         if (k1->op_type == OP_READDIR
  3599.           || k1->op_type == OP_GLOB
  3600.           || (k1->op_type == OP_NULL && k1->op_targ == OP_GLOB)
  3601.           || k1->op_type == OP_EACH)
  3602.         {
  3603.         warnop = ((k1->op_type == OP_NULL)
  3604.               ? k1->op_targ : k1->op_type);
  3605.         }
  3606.         break;
  3607.     }
  3608.     if (warnop) {
  3609.         line_t oldline = CopLINE(PL_curcop);
  3610.         CopLINE_set(PL_curcop, PL_copline);
  3611.         Perl_warner(aTHX_ WARN_MISC,
  3612.          "Value of %s%s can be \"0\"; test with defined()",
  3613.          PL_op_desc[warnop],
  3614.          ((warnop == OP_READLINE || warnop == OP_GLOB)
  3615.           ? " construct" : "() operator"));
  3616.         CopLINE_set(PL_curcop, oldline);
  3617.     }
  3618.     }
  3619.  
  3620.     if (!other)
  3621.     return first;
  3622.  
  3623.     if (type == OP_ANDASSIGN || type == OP_ORASSIGN)
  3624.     other->op_private |= OPpASSIGN_BACKWARDS;  /* other is an OP_SASSIGN */
  3625.  
  3626.     NewOp(1101, logop, 1, LOGOP);
  3627.  
  3628.     logop->op_type = type;
  3629.     logop->op_ppaddr = PL_ppaddr[type];
  3630.     logop->op_first = first;
  3631.     logop->op_flags = flags | OPf_KIDS;
  3632.     logop->op_other = LINKLIST(other);
  3633.     logop->op_private = 1 | (flags >> 8);
  3634.  
  3635.     /* establish postfix order */
  3636.     logop->op_next = LINKLIST(first);
  3637.     first->op_next = (OP*)logop;
  3638.     first->op_sibling = other;
  3639.  
  3640.     o = newUNOP(OP_NULL, 0, (OP*)logop);
  3641.     other->op_next = o;
  3642.  
  3643.     return o;
  3644. }
  3645.  
  3646. OP *
  3647. Perl_newCONDOP(pTHX_ I32 flags, OP *first, OP *trueop, OP *falseop)
  3648. {
  3649.     dTHR;
  3650.     LOGOP *logop;
  3651.     OP *start;
  3652.     OP *o;
  3653.  
  3654.     if (!falseop)
  3655.     return newLOGOP(OP_AND, 0, first, trueop);
  3656.     if (!trueop)
  3657.     return newLOGOP(OP_OR, 0, first, falseop);
  3658.  
  3659.     scalarboolean(first);
  3660.     if (first->op_type == OP_CONST) {
  3661.     if (SvTRUE(((SVOP*)first)->op_sv)) {
  3662.         op_free(first);
  3663.         op_free(falseop);
  3664.         return trueop;
  3665.     }
  3666.     else {
  3667.         op_free(first);
  3668.         op_free(trueop);
  3669.         return falseop;
  3670.     }
  3671.     }
  3672.     else if (first->op_type == OP_WANTARRAY) {
  3673.     list(trueop);
  3674.     scalar(falseop);
  3675.     }
  3676.     NewOp(1101, logop, 1, LOGOP);
  3677.     logop->op_type = OP_COND_EXPR;
  3678.     logop->op_ppaddr = PL_ppaddr[OP_COND_EXPR];
  3679.     logop->op_first = first;
  3680.     logop->op_flags = flags | OPf_KIDS;
  3681.     logop->op_private = 1 | (flags >> 8);
  3682.     logop->op_other = LINKLIST(trueop);
  3683.     logop->op_next = LINKLIST(falseop);
  3684.  
  3685.  
  3686.     /* establish postfix order */
  3687.     start = LINKLIST(first);
  3688.     first->op_next = (OP*)logop;
  3689.  
  3690.     first->op_sibling = trueop;
  3691.     trueop->op_sibling = falseop;
  3692.     o = newUNOP(OP_NULL, 0, (OP*)logop);
  3693.  
  3694.     trueop->op_next = falseop->op_next = o;
  3695.  
  3696.     o->op_next = start;
  3697.     return o;
  3698. }
  3699.  
  3700. OP *
  3701. Perl_newRANGE(pTHX_ I32 flags, OP *left, OP *right)
  3702. {
  3703.     dTHR;
  3704.     LOGOP *range;
  3705.     OP *flip;
  3706.     OP *flop;
  3707.     OP *leftstart;
  3708.     OP *o;
  3709.  
  3710.     NewOp(1101, range, 1, LOGOP);
  3711.  
  3712.     range->op_type = OP_RANGE;
  3713.     range->op_ppaddr = PL_ppaddr[OP_RANGE];
  3714.     range->op_first = left;
  3715.     range->op_flags = OPf_KIDS;
  3716.     leftstart = LINKLIST(left);
  3717.     range->op_other = LINKLIST(right);
  3718.     range->op_private = 1 | (flags >> 8);
  3719.  
  3720.     left->op_sibling = right;
  3721.  
  3722.     range->op_next = (OP*)range;
  3723.     flip = newUNOP(OP_FLIP, flags, (OP*)range);
  3724.     flop = newUNOP(OP_FLOP, 0, flip);
  3725.     o = newUNOP(OP_NULL, 0, flop);
  3726.     linklist(flop);
  3727.     range->op_next = leftstart;
  3728.  
  3729.     left->op_next = flip;
  3730.     right->op_next = flop;
  3731.  
  3732.     range->op_targ = pad_alloc(OP_RANGE, SVs_PADMY);
  3733.     sv_upgrade(PAD_SV(range->op_targ), SVt_PVNV);
  3734.     flip->op_targ = pad_alloc(OP_RANGE, SVs_PADMY);
  3735.     sv_upgrade(PAD_SV(flip->op_targ), SVt_PVNV);
  3736.  
  3737.     flip->op_private =  left->op_type == OP_CONST ? OPpFLIP_LINENUM : 0;
  3738.     flop->op_private = right->op_type == OP_CONST ? OPpFLIP_LINENUM : 0;
  3739.  
  3740.     flip->op_next = o;
  3741.     if (!flip->op_private || !flop->op_private)
  3742.     linklist(o);        /* blow off optimizer unless constant */
  3743.  
  3744.     return o;
  3745. }
  3746.  
  3747. OP *
  3748. Perl_newLOOPOP(pTHX_ I32 flags, I32 debuggable, OP *expr, OP *block)
  3749. {
  3750.     dTHR;
  3751.     OP* listop;
  3752.     OP* o;
  3753.     int once = block && block->op_flags & OPf_SPECIAL &&
  3754.       (block->op_type == OP_ENTERSUB || block->op_type == OP_NULL);
  3755.  
  3756.     if (expr) {
  3757.     if (once && expr->op_type == OP_CONST && !SvTRUE(((SVOP*)expr)->op_sv))
  3758.         return block;    /* do {} while 0 does once */
  3759.     if (expr->op_type == OP_READLINE || expr->op_type == OP_GLOB
  3760.         || (expr->op_type == OP_NULL && expr->op_targ == OP_GLOB)) {
  3761.         expr = newUNOP(OP_DEFINED, 0,
  3762.         newASSIGNOP(0, newDEFSVOP(), 0, expr) );
  3763.     } else if (expr->op_flags & OPf_KIDS) {
  3764.         OP *k1 = ((UNOP*)expr)->op_first;
  3765.         OP *k2 = (k1) ? k1->op_sibling : NULL;
  3766.         switch (expr->op_type) {
  3767.           case OP_NULL: 
  3768.         if (k2 && k2->op_type == OP_READLINE
  3769.               && (k2->op_flags & OPf_STACKED)
  3770.               && ((k1->op_flags & OPf_WANT) == OPf_WANT_SCALAR)) 
  3771.             expr = newUNOP(OP_DEFINED, 0, expr);
  3772.         break;                                
  3773.  
  3774.           case OP_SASSIGN:
  3775.         if (k1->op_type == OP_READDIR
  3776.               || k1->op_type == OP_GLOB
  3777.               || (k1->op_type == OP_NULL && k1->op_targ == OP_NULL)
  3778.               || k1->op_type == OP_EACH)
  3779.             expr = newUNOP(OP_DEFINED, 0, expr);
  3780.         break;
  3781.         }
  3782.     }
  3783.     }
  3784.  
  3785.     listop = append_elem(OP_LINESEQ, block, newOP(OP_UNSTACK, 0));
  3786.     o = new_logop(OP_AND, 0, &expr, &listop);
  3787.  
  3788.     if (listop)
  3789.     ((LISTOP*)listop)->op_last->op_next = LINKLIST(o);
  3790.  
  3791.     if (once && o != listop)
  3792.     o->op_next = ((LOGOP*)cUNOPo->op_first)->op_other;
  3793.  
  3794.     if (o == listop)
  3795.     o = newUNOP(OP_NULL, 0, o);    /* or do {} while 1 loses outer block */
  3796.  
  3797.     o->op_flags |= flags;
  3798.     o = scope(o);
  3799.     o->op_flags |= OPf_SPECIAL;    /* suppress POPBLOCK curpm restoration*/
  3800.     return o;
  3801. }
  3802.  
  3803. OP *
  3804. Perl_newWHILEOP(pTHX_ I32 flags, I32 debuggable, LOOP *loop, I32 whileline, OP *expr, OP *block, OP *cont)
  3805. {
  3806.     dTHR;
  3807.     OP *redo;
  3808.     OP *next = 0;
  3809.     OP *listop;
  3810.     OP *o;
  3811.     OP *condop;
  3812.     U8 loopflags = 0;
  3813.  
  3814.     if (expr && (expr->op_type == OP_READLINE || expr->op_type == OP_GLOB
  3815.          || (expr->op_type == OP_NULL && expr->op_targ == OP_GLOB))) {
  3816.     expr = newUNOP(OP_DEFINED, 0,
  3817.         newASSIGNOP(0, newDEFSVOP(), 0, expr) );
  3818.     } else if (expr && (expr->op_flags & OPf_KIDS)) {
  3819.     OP *k1 = ((UNOP*)expr)->op_first;
  3820.     OP *k2 = (k1) ? k1->op_sibling : NULL;
  3821.     switch (expr->op_type) {
  3822.       case OP_NULL: 
  3823.         if (k2 && k2->op_type == OP_READLINE
  3824.           && (k2->op_flags & OPf_STACKED)
  3825.           && ((k1->op_flags & OPf_WANT) == OPf_WANT_SCALAR)) 
  3826.         expr = newUNOP(OP_DEFINED, 0, expr);
  3827.         break;                                
  3828.  
  3829.       case OP_SASSIGN:
  3830.         if (k1->op_type == OP_READDIR
  3831.           || k1->op_type == OP_GLOB
  3832.           || (k1->op_type == OP_NULL && k1->op_targ == OP_GLOB)
  3833.           || k1->op_type == OP_EACH)
  3834.         expr = newUNOP(OP_DEFINED, 0, expr);
  3835.         break;
  3836.     }
  3837.     }
  3838.  
  3839.     if (!block)
  3840.     block = newOP(OP_NULL, 0);
  3841.     else if (cont) {
  3842.     block = scope(block);
  3843.     }
  3844.  
  3845.     if (cont) {
  3846.     next = LINKLIST(cont);
  3847.     loopflags |= OPpLOOP_CONTINUE;
  3848.     }
  3849.     if (expr) {
  3850.     cont = append_elem(OP_LINESEQ, cont, newOP(OP_UNSTACK, 0));
  3851.     if ((line_t)whileline != NOLINE) {
  3852.         PL_copline = whileline;
  3853.         cont = append_elem(OP_LINESEQ, cont,
  3854.                    newSTATEOP(0, Nullch, Nullop));
  3855.     }
  3856.     }
  3857.  
  3858.     listop = append_list(OP_LINESEQ, (LISTOP*)block, (LISTOP*)cont);
  3859.     redo = LINKLIST(listop);
  3860.  
  3861.     if (expr) {
  3862.     PL_copline = whileline;
  3863.     scalar(listop);
  3864.     o = new_logop(OP_AND, 0, &expr, &listop);
  3865.     if (o == expr && o->op_type == OP_CONST && !SvTRUE(cSVOPo->op_sv)) {
  3866.         op_free(expr);        /* oops, it's a while (0) */
  3867.         op_free((OP*)loop);
  3868.         return Nullop;        /* listop already freed by new_logop */
  3869.     }
  3870.     if (listop)
  3871.         ((LISTOP*)listop)->op_last->op_next = condop =
  3872.         (o == listop ? redo : LINKLIST(o));
  3873.     if (!next)
  3874.         next = condop;
  3875.     }
  3876.     else
  3877.     o = listop;
  3878.  
  3879.     if (!loop) {
  3880.     NewOp(1101,loop,1,LOOP);
  3881.     loop->op_type = OP_ENTERLOOP;
  3882.     loop->op_ppaddr = PL_ppaddr[OP_ENTERLOOP];
  3883.     loop->op_private = 0;
  3884.     loop->op_next = (OP*)loop;
  3885.     }
  3886.  
  3887.     o = newBINOP(OP_LEAVELOOP, 0, (OP*)loop, o);
  3888.  
  3889.     loop->op_redoop = redo;
  3890.     loop->op_lastop = o;
  3891.     o->op_private |= loopflags;
  3892.  
  3893.     if (next)
  3894.     loop->op_nextop = next;
  3895.     else
  3896.     loop->op_nextop = o;
  3897.  
  3898.     o->op_flags |= flags;
  3899.     o->op_private |= (flags >> 8);
  3900.     return o;
  3901. }
  3902.  
  3903. OP *
  3904. Perl_newFOROP(pTHX_ I32 flags,char *label,line_t forline,OP *sv,OP *expr,OP *block,OP *cont)
  3905. {
  3906.     LOOP *loop;
  3907.     OP *wop;
  3908.     int padoff = 0;
  3909.     I32 iterflags = 0;
  3910.  
  3911.     if (sv) {
  3912.     if (sv->op_type == OP_RV2SV) {    /* symbol table variable */
  3913.         sv->op_type = OP_RV2GV;
  3914.         sv->op_ppaddr = PL_ppaddr[OP_RV2GV];
  3915.     }
  3916.     else if (sv->op_type == OP_PADSV) { /* private variable */
  3917.         padoff = sv->op_targ;
  3918.         sv->op_targ = 0;
  3919.         op_free(sv);
  3920.         sv = Nullop;
  3921.     }
  3922.     else if (sv->op_type == OP_THREADSV) { /* per-thread variable */
  3923.         padoff = sv->op_targ;
  3924.         sv->op_targ = 0;
  3925.         iterflags |= OPf_SPECIAL;
  3926.         op_free(sv);
  3927.         sv = Nullop;
  3928.     }
  3929.     else
  3930.         Perl_croak(aTHX_ "Can't use %s for loop variable", PL_op_desc[sv->op_type]);
  3931.     }
  3932.     else {
  3933. #ifdef USE_THREADS
  3934.     padoff = find_threadsv("_");
  3935.     iterflags |= OPf_SPECIAL;
  3936. #else
  3937.     sv = newGVOP(OP_GV, 0, PL_defgv);
  3938. #endif
  3939.     }
  3940.     if (expr->op_type == OP_RV2AV || expr->op_type == OP_PADAV) {
  3941.     expr = mod(force_list(scalar(ref(expr, OP_ITER))), OP_GREPSTART);
  3942.     iterflags |= OPf_STACKED;
  3943.     }
  3944.     else if (expr->op_type == OP_NULL &&
  3945.              (expr->op_flags & OPf_KIDS) &&
  3946.              ((BINOP*)expr)->op_first->op_type == OP_FLOP)
  3947.     {
  3948.     /* Basically turn for($x..$y) into the same as for($x,$y), but we
  3949.      * set the STACKED flag to indicate that these values are to be
  3950.      * treated as min/max values by 'pp_iterinit'.
  3951.      */
  3952.     UNOP* flip = (UNOP*)((UNOP*)((BINOP*)expr)->op_first)->op_first;
  3953.     LOGOP* range = (LOGOP*) flip->op_first;
  3954.     OP* left  = range->op_first;
  3955.     OP* right = left->op_sibling;
  3956.     LISTOP* listop;
  3957.  
  3958.     range->op_flags &= ~OPf_KIDS;
  3959.     range->op_first = Nullop;
  3960.  
  3961.     listop = (LISTOP*)newLISTOP(OP_LIST, 0, left, right);
  3962.     listop->op_first->op_next = range->op_next;
  3963.     left->op_next = range->op_other;
  3964.     right->op_next = (OP*)listop;
  3965.     listop->op_next = listop->op_first;
  3966.  
  3967.     op_free(expr);
  3968.     expr = (OP*)(listop);
  3969.         null(expr);
  3970.     iterflags |= OPf_STACKED;
  3971.     }
  3972.     else {
  3973.         expr = mod(force_list(expr), OP_GREPSTART);
  3974.     }
  3975.  
  3976.  
  3977.     loop = (LOOP*)list(convert(OP_ENTERITER, iterflags,
  3978.                    append_elem(OP_LIST, expr, scalar(sv))));
  3979.     assert(!loop->op_next);
  3980. #ifdef PL_OP_SLAB_ALLOC
  3981.     {
  3982.     LOOP *tmp;
  3983.     NewOp(1234,tmp,1,LOOP);
  3984.     Copy(loop,tmp,1,LOOP);
  3985.     loop = tmp;
  3986.     }
  3987. #else
  3988.     Renew(loop, 1, LOOP);
  3989. #endif 
  3990.     loop->op_targ = padoff;
  3991.     wop = newWHILEOP(flags, 1, loop, forline, newOP(OP_ITER, 0), block, cont);
  3992.     PL_copline = forline;
  3993.     return newSTATEOP(0, label, wop);
  3994. }
  3995.  
  3996. OP*
  3997. Perl_newLOOPEX(pTHX_ I32 type, OP *label)
  3998. {
  3999.     dTHR;
  4000.     OP *o;
  4001.     STRLEN n_a;
  4002.  
  4003.     if (type != OP_GOTO || label->op_type == OP_CONST) {
  4004.     /* "last()" means "last" */
  4005.     if (label->op_type == OP_STUB && (label->op_flags & OPf_PARENS))
  4006.         o = newOP(type, OPf_SPECIAL);
  4007.     else {
  4008.         o = newPVOP(type, 0, savepv(label->op_type == OP_CONST
  4009.                     ? SvPVx(((SVOP*)label)->op_sv, n_a)
  4010.                     : ""));
  4011.     }
  4012.     op_free(label);
  4013.     }
  4014.     else {
  4015.     if (label->op_type == OP_ENTERSUB)
  4016.         label = newUNOP(OP_REFGEN, 0, mod(label, OP_REFGEN));
  4017.     o = newUNOP(type, OPf_STACKED, label);
  4018.     }
  4019.     PL_hints |= HINT_BLOCK_SCOPE;
  4020.     return o;
  4021. }
  4022.  
  4023. void
  4024. Perl_cv_undef(pTHX_ CV *cv)
  4025. {
  4026.     dTHR;
  4027. #ifdef USE_THREADS
  4028.     if (CvMUTEXP(cv)) {
  4029.     MUTEX_DESTROY(CvMUTEXP(cv));
  4030.     Safefree(CvMUTEXP(cv));
  4031.     CvMUTEXP(cv) = 0;
  4032.     }
  4033. #endif /* USE_THREADS */
  4034.  
  4035.     if (!CvXSUB(cv) && CvROOT(cv)) {
  4036. #ifdef USE_THREADS
  4037.     if (CvDEPTH(cv) || (CvOWNER(cv) && CvOWNER(cv) != thr))
  4038.         Perl_croak(aTHX_ "Can't undef active subroutine");
  4039. #else
  4040.     if (CvDEPTH(cv))
  4041.         Perl_croak(aTHX_ "Can't undef active subroutine");
  4042. #endif /* USE_THREADS */
  4043.     ENTER;
  4044.  
  4045.     SAVEVPTR(PL_curpad);
  4046.     PL_curpad = 0;
  4047.  
  4048.     if (!CvCLONED(cv))
  4049.         op_free(CvROOT(cv));
  4050.     CvROOT(cv) = Nullop;
  4051.     LEAVE;
  4052.     }
  4053.     SvPOK_off((SV*)cv);        /* forget prototype */
  4054.     CvFLAGS(cv) = 0;
  4055.     SvREFCNT_dec(CvGV(cv));
  4056.     CvGV(cv) = Nullgv;
  4057.     SvREFCNT_dec(CvOUTSIDE(cv));
  4058.     CvOUTSIDE(cv) = Nullcv;
  4059.     if (CvPADLIST(cv)) {
  4060.     /* may be during global destruction */
  4061.     if (SvREFCNT(CvPADLIST(cv))) {
  4062.         I32 i = AvFILLp(CvPADLIST(cv));
  4063.         while (i >= 0) {
  4064.         SV** svp = av_fetch(CvPADLIST(cv), i--, FALSE);
  4065.         SV* sv = svp ? *svp : Nullsv;
  4066.         if (!sv)
  4067.             continue;
  4068.         if (sv == (SV*)PL_comppad_name)
  4069.             PL_comppad_name = Nullav;
  4070.         else if (sv == (SV*)PL_comppad) {
  4071.             PL_comppad = Nullav;
  4072.             PL_curpad = Null(SV**);
  4073.         }
  4074.         SvREFCNT_dec(sv);
  4075.         }
  4076.         SvREFCNT_dec((SV*)CvPADLIST(cv));
  4077.     }
  4078.     CvPADLIST(cv) = Nullav;
  4079.     }
  4080. }
  4081.  
  4082. STATIC void
  4083. S_cv_dump(pTHX_ CV *cv)
  4084. {
  4085. #ifdef DEBUGGING
  4086.     CV *outside = CvOUTSIDE(cv);
  4087.     AV* padlist = CvPADLIST(cv);
  4088.     AV* pad_name;
  4089.     AV* pad;
  4090.     SV** pname;
  4091.     SV** ppad;
  4092.     I32 ix;
  4093.  
  4094.     PerlIO_printf(Perl_debug_log,
  4095.           "\tCV=0x%"UVxf" (%s), OUTSIDE=0x%"UVxf" (%s)\n",
  4096.           PTR2UV(cv),
  4097.           (CvANON(cv) ? "ANON"
  4098.            : (cv == PL_main_cv) ? "MAIN"
  4099.            : CvUNIQUE(cv) ? "UNIQUE"
  4100.            : CvGV(cv) ? GvNAME(CvGV(cv)) : "UNDEFINED"),
  4101.           PTR2UV(outside),
  4102.           (!outside ? "null"
  4103.            : CvANON(outside) ? "ANON"
  4104.            : (outside == PL_main_cv) ? "MAIN"
  4105.            : CvUNIQUE(outside) ? "UNIQUE"
  4106.            : CvGV(outside) ? GvNAME(CvGV(outside)) : "UNDEFINED"));
  4107.  
  4108.     if (!padlist)
  4109.     return;
  4110.  
  4111.     pad_name = (AV*)*av_fetch(padlist, 0, FALSE);
  4112.     pad = (AV*)*av_fetch(padlist, 1, FALSE);
  4113.     pname = AvARRAY(pad_name);
  4114.     ppad = AvARRAY(pad);
  4115.  
  4116.     for (ix = 1; ix <= AvFILLp(pad_name); ix++) {
  4117.     if (SvPOK(pname[ix]))
  4118.         PerlIO_printf(Perl_debug_log,
  4119.               "\t%4d. 0x%"UVxf" (%s\"%s\" %"IVdf"-%"IVdf")\n",
  4120.               (int)ix, PTR2UV(ppad[ix]),
  4121.               SvFAKE(pname[ix]) ? "FAKE " : "",
  4122.               SvPVX(pname[ix]),
  4123.               (IV)I_32(SvNVX(pname[ix])),
  4124.               SvIVX(pname[ix]));
  4125.     }
  4126. #endif /* DEBUGGING */
  4127. }
  4128.  
  4129. STATIC CV *
  4130. S_cv_clone2(pTHX_ CV *proto, CV *outside)
  4131. {
  4132.     dTHR;
  4133.     AV* av;
  4134.     I32 ix;
  4135.     AV* protopadlist = CvPADLIST(proto);
  4136.     AV* protopad_name = (AV*)*av_fetch(protopadlist, 0, FALSE);
  4137.     AV* protopad = (AV*)*av_fetch(protopadlist, 1, FALSE);
  4138.     SV** pname = AvARRAY(protopad_name);
  4139.     SV** ppad = AvARRAY(protopad);
  4140.     I32 fname = AvFILLp(protopad_name);
  4141.     I32 fpad = AvFILLp(protopad);
  4142.     AV* comppadlist;
  4143.     CV* cv;
  4144.  
  4145.     assert(!CvUNIQUE(proto));
  4146.  
  4147.     ENTER;
  4148.     SAVECOMPPAD();
  4149.     SAVESPTR(PL_comppad_name);
  4150.     SAVESPTR(PL_compcv);
  4151.  
  4152.     cv = PL_compcv = (CV*)NEWSV(1104,0);
  4153.     sv_upgrade((SV *)cv, SvTYPE(proto));
  4154.     CvFLAGS(cv) = CvFLAGS(proto) & ~CVf_CLONE;
  4155.     CvCLONED_on(cv);
  4156.  
  4157. #ifdef USE_THREADS
  4158.     New(666, CvMUTEXP(cv), 1, perl_mutex);
  4159.     MUTEX_INIT(CvMUTEXP(cv));
  4160.     CvOWNER(cv)        = 0;
  4161. #endif /* USE_THREADS */
  4162.     CvFILE(cv)        = CvFILE(proto);
  4163.     CvGV(cv)        = (GV*)SvREFCNT_inc(CvGV(proto));
  4164.     CvSTASH(cv)        = CvSTASH(proto);
  4165.     CvROOT(cv)        = CvROOT(proto);
  4166.     CvSTART(cv)        = CvSTART(proto);
  4167.     if (outside)
  4168.     CvOUTSIDE(cv)    = (CV*)SvREFCNT_inc(outside);
  4169.  
  4170.     if (SvPOK(proto))
  4171.     sv_setpvn((SV*)cv, SvPVX(proto), SvCUR(proto));
  4172.  
  4173.     PL_comppad_name = newAV();
  4174.     for (ix = fname; ix >= 0; ix--)
  4175.     av_store(PL_comppad_name, ix, SvREFCNT_inc(pname[ix]));
  4176.  
  4177.     PL_comppad = newAV();
  4178.  
  4179.     comppadlist = newAV();
  4180.     AvREAL_off(comppadlist);
  4181.     av_store(comppadlist, 0, (SV*)PL_comppad_name);
  4182.     av_store(comppadlist, 1, (SV*)PL_comppad);
  4183.     CvPADLIST(cv) = comppadlist;
  4184.     av_fill(PL_comppad, AvFILLp(protopad));
  4185.     PL_curpad = AvARRAY(PL_comppad);
  4186.  
  4187.     av = newAV();           /* will be @_ */
  4188.     av_extend(av, 0);
  4189.     av_store(PL_comppad, 0, (SV*)av);
  4190.     AvFLAGS(av) = AVf_REIFY;
  4191.  
  4192.     for (ix = fpad; ix > 0; ix--) {
  4193.     SV* namesv = (ix <= fname) ? pname[ix] : Nullsv;
  4194.     if (namesv && namesv != &PL_sv_undef) {
  4195.         char *name = SvPVX(namesv);    /* XXX */
  4196.         if (SvFLAGS(namesv) & SVf_FAKE) {   /* lexical from outside? */
  4197.         I32 off = pad_findlex(name, ix, SvIVX(namesv),
  4198.                       CvOUTSIDE(cv), cxstack_ix, 0, 0);
  4199.         if (!off)
  4200.             PL_curpad[ix] = SvREFCNT_inc(ppad[ix]);
  4201.         else if (off != ix)
  4202.             Perl_croak(aTHX_ "panic: cv_clone: %s", name);
  4203.         }
  4204.         else {                /* our own lexical */
  4205.         SV* sv;
  4206.         if (*name == '&') {
  4207.             /* anon code -- we'll come back for it */
  4208.             sv = SvREFCNT_inc(ppad[ix]);
  4209.         }
  4210.         else if (*name == '@')
  4211.             sv = (SV*)newAV();
  4212.         else if (*name == '%')
  4213.             sv = (SV*)newHV();
  4214.         else
  4215.             sv = NEWSV(0,0);
  4216.         if (!SvPADBUSY(sv))
  4217.             SvPADMY_on(sv);
  4218.         PL_curpad[ix] = sv;
  4219.         }
  4220.     }
  4221.     else if (IS_PADGV(ppad[ix]) || IS_PADCONST(ppad[ix])) {
  4222.         PL_curpad[ix] = SvREFCNT_inc(ppad[ix]);
  4223.     }
  4224.     else {
  4225.         SV* sv = NEWSV(0,0);
  4226.         SvPADTMP_on(sv);
  4227.         PL_curpad[ix] = sv;
  4228.     }
  4229.     }
  4230.  
  4231.     /* Now that vars are all in place, clone nested closures. */
  4232.  
  4233.     for (ix = fpad; ix > 0; ix--) {
  4234.     SV* namesv = (ix <= fname) ? pname[ix] : Nullsv;
  4235.     if (namesv
  4236.         && namesv != &PL_sv_undef
  4237.         && !(SvFLAGS(namesv) & SVf_FAKE)
  4238.         && *SvPVX(namesv) == '&'
  4239.         && CvCLONE(ppad[ix]))
  4240.     {
  4241.         CV *kid = cv_clone2((CV*)ppad[ix], cv);
  4242.         SvREFCNT_dec(ppad[ix]);
  4243.         CvCLONE_on(kid);
  4244.         SvPADMY_on(kid);
  4245.         PL_curpad[ix] = (SV*)kid;
  4246.     }
  4247.     }
  4248.  
  4249. #ifdef DEBUG_CLOSURES
  4250.     PerlIO_printf(Perl_debug_log, "Cloned inside:\n");
  4251.     cv_dump(outside);
  4252.     PerlIO_printf(Perl_debug_log, "  from:\n");
  4253.     cv_dump(proto);
  4254.     PerlIO_printf(Perl_debug_log, "   to:\n");
  4255.     cv_dump(cv);
  4256. #endif
  4257.  
  4258.     LEAVE;
  4259.     return cv;
  4260. }
  4261.  
  4262. CV *
  4263. Perl_cv_clone(pTHX_ CV *proto)
  4264. {
  4265.     CV *cv;
  4266.     LOCK_CRED_MUTEX;            /* XXX create separate mutex */
  4267.     cv = cv_clone2(proto, CvOUTSIDE(proto));
  4268.     UNLOCK_CRED_MUTEX;            /* XXX create separate mutex */
  4269.     return cv;
  4270. }
  4271.  
  4272. void
  4273. Perl_cv_ckproto(pTHX_ CV *cv, GV *gv, char *p)
  4274. {
  4275.     dTHR;
  4276.  
  4277.     if (((!p != !SvPOK(cv)) || (p && strNE(p, SvPVX(cv)))) && ckWARN_d(WARN_PROTOTYPE)) {
  4278.     SV* msg = sv_newmortal();
  4279.     SV* name = Nullsv;
  4280.  
  4281.     if (gv)
  4282.         gv_efullname3(name = sv_newmortal(), gv, Nullch);
  4283.     sv_setpv(msg, "Prototype mismatch:");
  4284.     if (name)
  4285.         Perl_sv_catpvf(aTHX_ msg, " sub %"SVf, name);
  4286.     if (SvPOK(cv))
  4287.         Perl_sv_catpvf(aTHX_ msg, " (%s)", SvPVX(cv));
  4288.     sv_catpv(msg, " vs ");
  4289.     if (p)
  4290.         Perl_sv_catpvf(aTHX_ msg, "(%s)", p);
  4291.     else
  4292.         sv_catpv(msg, "none");
  4293.     Perl_warner(aTHX_ WARN_PROTOTYPE, "%"SVf, msg);
  4294.     }
  4295. }
  4296.  
  4297. SV *
  4298. Perl_cv_const_sv(pTHX_ CV *cv)
  4299. {
  4300.     if (!cv || !SvPOK(cv) || SvCUR(cv))
  4301.     return Nullsv;
  4302.     return op_const_sv(CvSTART(cv), cv);
  4303. }
  4304.  
  4305. SV *
  4306. Perl_op_const_sv(pTHX_ OP *o, CV *cv)
  4307. {
  4308.     SV *sv = Nullsv;
  4309.  
  4310.     if (!o)
  4311.     return Nullsv;
  4312.  
  4313.     if (o->op_type == OP_LINESEQ && cLISTOPo->op_first) 
  4314.     o = cLISTOPo->op_first->op_sibling;
  4315.  
  4316.     for (; o; o = o->op_next) {
  4317.     OPCODE type = o->op_type;
  4318.  
  4319.     if (sv && o->op_next == o) 
  4320.         return sv;
  4321.     if (type == OP_NEXTSTATE || type == OP_NULL || type == OP_PUSHMARK)
  4322.         continue;
  4323.     if (type == OP_LEAVESUB || type == OP_RETURN)
  4324.         break;
  4325.     if (sv)
  4326.         return Nullsv;
  4327.     if (type == OP_CONST && cSVOPo->op_sv)
  4328.         sv = cSVOPo->op_sv;
  4329.     else if ((type == OP_PADSV || type == OP_CONST) && cv) {
  4330.         AV* padav = (AV*)(AvARRAY(CvPADLIST(cv))[1]);
  4331.         sv = padav ? AvARRAY(padav)[o->op_targ] : Nullsv;
  4332.         if (!sv || (!SvREADONLY(sv) && SvREFCNT(sv) > 1))
  4333.         return Nullsv;
  4334.     }
  4335.     else
  4336.         return Nullsv;
  4337.     }
  4338.     if (sv)
  4339.     SvREADONLY_on(sv);
  4340.     return sv;
  4341. }
  4342.  
  4343. void
  4344. Perl_newMYSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *attrs, OP *block)
  4345. {
  4346.     if (o)
  4347.     SAVEFREEOP(o);
  4348.     if (proto)
  4349.     SAVEFREEOP(proto);
  4350.     if (attrs)
  4351.     SAVEFREEOP(attrs);
  4352.     if (block)
  4353.     SAVEFREEOP(block);
  4354.     Perl_croak(aTHX_ "\"my sub\" not yet implemented");
  4355. }
  4356.  
  4357. CV *
  4358. Perl_newSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *block)
  4359. {
  4360.     return Perl_newATTRSUB(aTHX_ floor, o, proto, Nullop, block);
  4361. }
  4362.  
  4363. CV *
  4364. Perl_newATTRSUB(pTHX_ I32 floor, OP *o, OP *proto, OP *attrs, OP *block)
  4365. {
  4366.     dTHR;
  4367.     STRLEN n_a;
  4368.     char *name;
  4369.     char *aname;
  4370.     GV *gv;
  4371.     char *ps = proto ? SvPVx(((SVOP*)proto)->op_sv, n_a) : Nullch;
  4372.     register CV *cv=0;
  4373.     I32 ix;
  4374.  
  4375.     name = o ? SvPVx(cSVOPo->op_sv, n_a) : Nullch;
  4376.     if (!name && PERLDB_NAMEANON && CopLINE(PL_curcop)) {
  4377.     SV *sv = sv_newmortal();
  4378.     Perl_sv_setpvf(aTHX_ sv, "__ANON__[%s:%"IVdf"]",
  4379.                CopFILE(PL_curcop), (IV)CopLINE(PL_curcop));
  4380.     aname = SvPVX(sv);
  4381.     }
  4382.     else
  4383.     aname = Nullch;
  4384.     gv = gv_fetchpv(name ? name : (aname ? aname : "__ANON__"),
  4385.             GV_ADDMULTI | ((block || attrs) ? 0 : GV_NOINIT),
  4386.             SVt_PVCV);
  4387.  
  4388.     if (o)
  4389.     SAVEFREEOP(o);
  4390.     if (proto)
  4391.     SAVEFREEOP(proto);
  4392.     if (attrs)
  4393.     SAVEFREEOP(attrs);
  4394.  
  4395.     if (SvTYPE(gv) != SVt_PVGV) {    /* Maybe prototype now, and had at
  4396.                        maximum a prototype before. */
  4397.     if (SvTYPE(gv) > SVt_NULL) {
  4398.         if (!SvPOK((SV*)gv) && !(SvIOK((SV*)gv) && SvIVX((SV*)gv) == -1)
  4399.         && ckWARN_d(WARN_PROTOTYPE))
  4400.         {
  4401.         Perl_warner(aTHX_ WARN_PROTOTYPE, "Runaway prototype");
  4402.         }
  4403.         cv_ckproto((CV*)gv, NULL, ps);
  4404.     }
  4405.     if (ps)
  4406.         sv_setpv((SV*)gv, ps);
  4407.     else
  4408.         sv_setiv((SV*)gv, -1);
  4409.     SvREFCNT_dec(PL_compcv);
  4410.     cv = PL_compcv = NULL;
  4411.     PL_sub_generation++;
  4412.     goto noblock;
  4413.     }
  4414.  
  4415.     if (!name || GvCVGEN(gv))
  4416.     cv = Nullcv;
  4417.     else if ((cv = GvCV(gv))) {
  4418.     cv_ckproto(cv, gv, ps);
  4419.     /* already defined (or promised)? */
  4420.     if (CvROOT(cv) || CvXSUB(cv) || GvASSUMECV(gv)) {
  4421.         SV* const_sv;
  4422.         bool const_changed = TRUE;
  4423.         if (!block && !attrs) {
  4424.         /* just a "sub foo;" when &foo is already defined */
  4425.         SAVEFREESV(PL_compcv);
  4426.         goto done;
  4427.         }
  4428.         /* ahem, death to those who redefine active sort subs */
  4429.         if (PL_curstackinfo->si_type == PERLSI_SORT && PL_sortcop == CvSTART(cv))
  4430.         Perl_croak(aTHX_ "Can't redefine active sort subroutine %s", name);
  4431.         if (!block)
  4432.         goto withattrs;
  4433.         if ((const_sv = cv_const_sv(cv)))
  4434.         const_changed = sv_cmp(const_sv, op_const_sv(block, Nullcv));
  4435.         if ((const_sv || const_changed) && ckWARN(WARN_REDEFINE))
  4436.         {
  4437.         line_t oldline = CopLINE(PL_curcop);
  4438.         CopLINE_set(PL_curcop, PL_copline);
  4439.         Perl_warner(aTHX_ WARN_REDEFINE,
  4440.             const_sv ? "Constant subroutine %s redefined"
  4441.                  : "Subroutine %s redefined", name);
  4442.         CopLINE_set(PL_curcop, oldline);
  4443.         }
  4444.         SvREFCNT_dec(cv);
  4445.         cv = Nullcv;
  4446.     }
  4447.     }
  4448.   withattrs:
  4449.     if (attrs) {
  4450.     HV *stash;
  4451.     SV *rcv;
  4452.  
  4453.     /* Need to do a C<use attributes $stash_of_cv,\&cv,@attrs>
  4454.      * before we clobber PL_compcv.
  4455.      */
  4456.     if (cv && !block) {
  4457.         rcv = (SV*)cv;
  4458.         if (CvGV(cv) && GvSTASH(CvGV(cv)) && HvNAME(GvSTASH(CvGV(cv))))
  4459.         stash = GvSTASH(CvGV(cv));
  4460.         else if (CvSTASH(cv) && HvNAME(CvSTASH(cv)))
  4461.         stash = CvSTASH(cv);
  4462.         else
  4463.         stash = PL_curstash;
  4464.     }
  4465.     else {
  4466.         /* possibly about to re-define existing subr -- ignore old cv */
  4467.         rcv = (SV*)PL_compcv;
  4468.         if (name && GvSTASH(gv) && HvNAME(GvSTASH(gv)))
  4469.         stash = GvSTASH(gv);
  4470.         else
  4471.         stash = PL_curstash;
  4472.     }
  4473.     apply_attrs(stash, rcv, attrs);
  4474.     }
  4475.     if (cv) {                /* must reuse cv if autoloaded */
  4476.     if (!block) {
  4477.         /* got here with just attrs -- work done, so bug out */
  4478.         SAVEFREESV(PL_compcv);
  4479.         goto done;
  4480.     }
  4481.     cv_undef(cv);
  4482.     CvFLAGS(cv) = CvFLAGS(PL_compcv);
  4483.     CvOUTSIDE(cv) = CvOUTSIDE(PL_compcv);
  4484.     CvOUTSIDE(PL_compcv) = 0;
  4485.     CvPADLIST(cv) = CvPADLIST(PL_compcv);
  4486.     CvPADLIST(PL_compcv) = 0;
  4487.     if (SvREFCNT(PL_compcv) > 1) /* XXX Make closures transit through stub. */
  4488.         CvOUTSIDE(PL_compcv) = (CV*)SvREFCNT_inc((SV*)cv);
  4489.     SvREFCNT_dec(PL_compcv);
  4490.     }
  4491.     else {
  4492.     cv = PL_compcv;
  4493.     if (name) {
  4494.         GvCV(gv) = cv;
  4495.         GvCVGEN(gv) = 0;
  4496.         PL_sub_generation++;
  4497.     }
  4498.     }
  4499.     CvGV(cv) = (GV*)SvREFCNT_inc(gv);
  4500.     CvFILE(cv) = CopFILE(PL_curcop);
  4501.     CvSTASH(cv) = PL_curstash;
  4502. #ifdef USE_THREADS
  4503.     CvOWNER(cv) = 0;
  4504.     if (!CvMUTEXP(cv)) {
  4505.     New(666, CvMUTEXP(cv), 1, perl_mutex);
  4506.     MUTEX_INIT(CvMUTEXP(cv));
  4507.     }
  4508. #endif /* USE_THREADS */
  4509.  
  4510.     if (ps)
  4511.     sv_setpv((SV*)cv, ps);
  4512.  
  4513.     if (PL_error_count) {
  4514.     op_free(block);
  4515.     block = Nullop;
  4516.     if (name) {
  4517.         char *s = strrchr(name, ':');
  4518.         s = s ? s+1 : name;
  4519.         if (strEQ(s, "BEGIN")) {
  4520.         char *not_safe =
  4521.             "BEGIN not safe after errors--compilation aborted";
  4522.         if (PL_in_eval & EVAL_KEEPERR)
  4523.             Perl_croak(aTHX_ not_safe);
  4524.         else {
  4525.             /* force display of errors found but not reported */
  4526.             sv_catpv(ERRSV, not_safe);
  4527.             Perl_croak(aTHX_ "%s", SvPVx(ERRSV, n_a));
  4528.         }
  4529.         }
  4530.     }
  4531.     }
  4532.     if (!block) {
  4533.       noblock:
  4534.     PL_copline = NOLINE;
  4535.     LEAVE_SCOPE(floor);
  4536.     return cv;
  4537.     }
  4538.  
  4539.     if (AvFILLp(PL_comppad_name) < AvFILLp(PL_comppad))
  4540.     av_store(PL_comppad_name, AvFILLp(PL_comppad), Nullsv);
  4541.  
  4542.     if (CvLVALUE(cv)) {
  4543.     CvROOT(cv) = newUNOP(OP_LEAVESUBLV, 0, scalarseq(block));
  4544.     }
  4545.     else {
  4546.     CvROOT(cv) = newUNOP(OP_LEAVESUB, 0, scalarseq(block));
  4547.     }
  4548.     CvROOT(cv)->op_private |= OPpREFCOUNTED;
  4549.     OpREFCNT_set(CvROOT(cv), 1);
  4550.     CvSTART(cv) = LINKLIST(CvROOT(cv));
  4551.     CvROOT(cv)->op_next = 0;
  4552.     peep(CvSTART(cv));
  4553.  
  4554.     /* now that optimizer has done its work, adjust pad values */
  4555.     if (CvCLONE(cv)) {
  4556.     SV **namep = AvARRAY(PL_comppad_name);
  4557.     for (ix = AvFILLp(PL_comppad); ix > 0; ix--) {
  4558.         SV *namesv;
  4559.  
  4560.         if (SvIMMORTAL(PL_curpad[ix]) || IS_PADGV(PL_curpad[ix]) || IS_PADCONST(PL_curpad[ix]))
  4561.         continue;
  4562.         /*
  4563.          * The only things that a clonable function needs in its
  4564.          * pad are references to outer lexicals and anonymous subs.
  4565.          * The rest are created anew during cloning.
  4566.          */
  4567.         if (!((namesv = namep[ix]) != Nullsv &&
  4568.           namesv != &PL_sv_undef &&
  4569.           (SvFAKE(namesv) ||
  4570.            *SvPVX(namesv) == '&')))
  4571.         {
  4572.         SvREFCNT_dec(PL_curpad[ix]);
  4573.         PL_curpad[ix] = Nullsv;
  4574.         }
  4575.     }
  4576.     }
  4577.     else {
  4578.     AV *av = newAV();            /* Will be @_ */
  4579.     av_extend(av, 0);
  4580.     av_store(PL_comppad, 0, (SV*)av);
  4581.     AvFLAGS(av) = AVf_REIFY;
  4582.  
  4583.     for (ix = AvFILLp(PL_comppad); ix > 0; ix--) {
  4584.         if (SvIMMORTAL(PL_curpad[ix]) || IS_PADGV(PL_curpad[ix]) || IS_PADCONST(PL_curpad[ix]))
  4585.         continue;
  4586.         if (!SvPADMY(PL_curpad[ix]))
  4587.         SvPADTMP_on(PL_curpad[ix]);
  4588.     }
  4589.     }
  4590.  
  4591.     if (name || aname) {
  4592.     char *s;
  4593.     char *tname = (name ? name : aname);
  4594.  
  4595.     if (PERLDB_SUBLINE && PL_curstash != PL_debstash) {
  4596.         SV *sv = NEWSV(0,0);
  4597.         SV *tmpstr = sv_newmortal();
  4598.         GV *db_postponed = gv_fetchpv("DB::postponed", GV_ADDMULTI, SVt_PVHV);
  4599.         CV *pcv;
  4600.         HV *hv;
  4601.  
  4602.         Perl_sv_setpvf(aTHX_ sv, "%s:%ld-%ld",
  4603.                CopFILE(PL_curcop),
  4604.                (long)PL_subline, (long)CopLINE(PL_curcop));
  4605.         gv_efullname3(tmpstr, gv, Nullch);
  4606.         hv_store(GvHV(PL_DBsub), SvPVX(tmpstr), SvCUR(tmpstr), sv, 0);
  4607.         hv = GvHVn(db_postponed);
  4608.         if (HvFILL(hv) > 0 && hv_exists(hv, SvPVX(tmpstr), SvCUR(tmpstr))
  4609.         && (pcv = GvCV(db_postponed)))
  4610.         {
  4611.         dSP;
  4612.         PUSHMARK(SP);
  4613.         XPUSHs(tmpstr);
  4614.         PUTBACK;
  4615.         call_sv((SV*)pcv, G_DISCARD);
  4616.         }
  4617.     }
  4618.  
  4619.     if ((s = strrchr(tname,':')))
  4620.         s++;
  4621.     else
  4622.         s = tname;
  4623.  
  4624.     if (*s != 'B' && *s != 'E' && *s != 'C' && *s != 'I')
  4625.         goto done;
  4626.  
  4627.     if (strEQ(s, "BEGIN")) {
  4628.         I32 oldscope = PL_scopestack_ix;
  4629.         ENTER;
  4630.         SAVECOPFILE(&PL_compiling);
  4631.         SAVECOPLINE(&PL_compiling);
  4632.         save_svref(&PL_rs);
  4633.         sv_setsv(PL_rs, PL_nrs);
  4634.  
  4635.         if (!PL_beginav)
  4636.         PL_beginav = newAV();
  4637.         DEBUG_x( dump_sub(gv) );
  4638.         av_push(PL_beginav, SvREFCNT_inc(cv));
  4639.         GvCV(gv) = 0;
  4640.         call_list(oldscope, PL_beginav);
  4641.  
  4642.         PL_curcop = &PL_compiling;
  4643.         PL_compiling.op_private = PL_hints;
  4644.         LEAVE;
  4645.     }
  4646.     else if (strEQ(s, "END") && !PL_error_count) {
  4647.         if (!PL_endav)
  4648.         PL_endav = newAV();
  4649.         DEBUG_x( dump_sub(gv) );
  4650.         av_unshift(PL_endav, 1);
  4651.         av_store(PL_endav, 0, SvREFCNT_inc(cv));
  4652.         GvCV(gv) = 0;
  4653.     }
  4654.     else if (strEQ(s, "CHECK") && !PL_error_count) {
  4655.         if (!PL_checkav)
  4656.         PL_checkav = newAV();
  4657.         DEBUG_x( dump_sub(gv) );
  4658.         if (PL_main_start && ckWARN(WARN_VOID))
  4659.         Perl_warner(aTHX_ WARN_VOID, "Too late to run CHECK block");
  4660.         av_unshift(PL_checkav, 1);
  4661.         av_store(PL_checkav, 0, SvREFCNT_inc(cv));
  4662.         GvCV(gv) = 0;
  4663.     }
  4664.     else if (strEQ(s, "INIT") && !PL_error_count) {
  4665.         if (!PL_initav)
  4666.         PL_initav = newAV();
  4667.         DEBUG_x( dump_sub(gv) );
  4668.         if (PL_main_start && ckWARN(WARN_VOID))
  4669.         Perl_warner(aTHX_ WARN_VOID, "Too late to run INIT block");
  4670.         av_push(PL_initav, SvREFCNT_inc(cv));
  4671.         GvCV(gv) = 0;
  4672.     }
  4673.     }
  4674.  
  4675.   done:
  4676.     PL_copline = NOLINE;
  4677.     LEAVE_SCOPE(floor);
  4678.     return cv;
  4679. }
  4680.  
  4681. /* XXX unsafe for threads if eval_owner isn't held */
  4682. /*
  4683. =for apidoc newCONSTSUB
  4684.  
  4685. Creates a constant sub equivalent to Perl C<sub FOO () { 123 }> which is
  4686. eligible for inlining at compile-time.
  4687.  
  4688. =cut
  4689. */
  4690.  
  4691. void
  4692. Perl_newCONSTSUB(pTHX_ HV *stash, char *name, SV *sv)
  4693. {
  4694.     dTHR;
  4695.  
  4696.     ENTER;
  4697.     SAVECOPLINE(PL_curcop);
  4698.     SAVEHINTS();
  4699.  
  4700.     CopLINE_set(PL_curcop, PL_copline);
  4701.     PL_hints &= ~HINT_BLOCK_SCOPE;
  4702.  
  4703.     if (stash) {
  4704.     SAVESPTR(PL_curstash);
  4705.     SAVECOPSTASH(PL_curcop);
  4706.     PL_curstash = stash;
  4707. #ifdef USE_ITHREADS
  4708.     CopSTASHPV(PL_curcop) = stash ? HvNAME(stash) : Nullch;
  4709. #else
  4710.     CopSTASH(PL_curcop) = stash;
  4711. #endif
  4712.     }
  4713.  
  4714.     newATTRSUB(
  4715.     start_subparse(FALSE, 0),
  4716.     newSVOP(OP_CONST, 0, newSVpv(name,0)),
  4717.     newSVOP(OP_CONST, 0, &PL_sv_no),    /* SvPV(&PL_sv_no) == "" -- GMB */
  4718.     Nullop,
  4719.     newSTATEOP(0, Nullch, newSVOP(OP_CONST, 0, sv))
  4720.     );
  4721.  
  4722.     LEAVE;
  4723. }
  4724.  
  4725. /*
  4726. =for apidoc U||newXS
  4727.  
  4728. Used by C<xsubpp> to hook up XSUBs as Perl subs.
  4729.  
  4730. =cut
  4731. */
  4732.  
  4733. CV *
  4734. Perl_newXS(pTHX_ char *name, XSUBADDR_t subaddr, char *filename)
  4735. {
  4736.     dTHR;
  4737.     GV *gv = gv_fetchpv(name ? name : "__ANON__", GV_ADDMULTI, SVt_PVCV);
  4738.     register CV *cv;
  4739.  
  4740.     if ((cv = (name ? GvCV(gv) : Nullcv))) {
  4741.     if (GvCVGEN(gv)) {
  4742.         /* just a cached method */
  4743.         SvREFCNT_dec(cv);
  4744.         cv = 0;
  4745.     }
  4746.     else if (CvROOT(cv) || CvXSUB(cv) || GvASSUMECV(gv)) {
  4747.         /* already defined (or promised) */
  4748.         if (ckWARN(WARN_REDEFINE) && !(CvGV(cv) && GvSTASH(CvGV(cv))
  4749.                 && HvNAME(GvSTASH(CvGV(cv)))
  4750.                 && strEQ(HvNAME(GvSTASH(CvGV(cv))), "autouse"))) {
  4751.         line_t oldline = CopLINE(PL_curcop);
  4752.         if (PL_copline != NOLINE)
  4753.             CopLINE_set(PL_curcop, PL_copline);
  4754.         Perl_warner(aTHX_ WARN_REDEFINE, "Subroutine %s redefined",name);
  4755.         CopLINE_set(PL_curcop, oldline);
  4756.         }
  4757.         SvREFCNT_dec(cv);
  4758.         cv = 0;
  4759.     }
  4760.     }
  4761.  
  4762.     if (cv)                /* must reuse cv if autoloaded */
  4763.     cv_undef(cv);
  4764.     else {
  4765.     cv = (CV*)NEWSV(1105,0);
  4766.     sv_upgrade((SV *)cv, SVt_PVCV);
  4767.     if (name) {
  4768.         GvCV(gv) = cv;
  4769.         GvCVGEN(gv) = 0;
  4770.         PL_sub_generation++;
  4771.     }
  4772.     }
  4773.     CvGV(cv) = (GV*)SvREFCNT_inc(gv);
  4774. #ifdef USE_THREADS
  4775.     New(666, CvMUTEXP(cv), 1, perl_mutex);
  4776.     MUTEX_INIT(CvMUTEXP(cv));
  4777.     CvOWNER(cv) = 0;
  4778. #endif /* USE_THREADS */
  4779.     (void)gv_fetchfile(filename);
  4780.     CvFILE(cv) = filename;    /* NOTE: not copied, as it is expected to be
  4781.                    an external constant string */
  4782.     CvXSUB(cv) = subaddr;
  4783.  
  4784.     if (name) {
  4785.     char *s = strrchr(name,':');
  4786.     if (s)
  4787.         s++;
  4788.     else
  4789.         s = name;
  4790.  
  4791.     if (*s != 'B' && *s != 'E' && *s != 'C' && *s != 'I')
  4792.         goto done;
  4793.  
  4794.     if (strEQ(s, "BEGIN")) {
  4795.         if (!PL_beginav)
  4796.         PL_beginav = newAV();
  4797.         av_push(PL_beginav, SvREFCNT_inc(cv));
  4798.         GvCV(gv) = 0;
  4799.     }
  4800.     else if (strEQ(s, "END")) {
  4801.         if (!PL_endav)
  4802.         PL_endav = newAV();
  4803.         av_unshift(PL_endav, 1);
  4804.         av_store(PL_endav, 0, SvREFCNT_inc(cv));
  4805.         GvCV(gv) = 0;
  4806.     }
  4807.     else if (strEQ(s, "CHECK")) {
  4808.         if (!PL_checkav)
  4809.         PL_checkav = newAV();
  4810.         if (PL_main_start && ckWARN(WARN_VOID))
  4811.         Perl_warner(aTHX_ WARN_VOID, "Too late to run CHECK block");
  4812.         av_unshift(PL_checkav, 1);
  4813.         av_store(PL_checkav, 0, SvREFCNT_inc(cv));
  4814.         GvCV(gv) = 0;
  4815.     }
  4816.     else if (strEQ(s, "INIT")) {
  4817.         if (!PL_initav)
  4818.         PL_initav = newAV();
  4819.         if (PL_main_start && ckWARN(WARN_VOID))
  4820.         Perl_warner(aTHX_ WARN_VOID, "Too late to run INIT block");
  4821.         av_push(PL_initav, SvREFCNT_inc(cv));
  4822.         GvCV(gv) = 0;
  4823.     }
  4824.     }
  4825.     else
  4826.     CvANON_on(cv);
  4827.  
  4828. done:
  4829.     return cv;
  4830. }
  4831.  
  4832. void
  4833. Perl_newFORM(pTHX_ I32 floor, OP *o, OP *block)
  4834. {
  4835.     dTHR;
  4836.     register CV *cv;
  4837.     char *name;
  4838.     GV *gv;
  4839.     I32 ix;
  4840.     STRLEN n_a;
  4841.  
  4842.     if (o)
  4843.     name = SvPVx(cSVOPo->op_sv, n_a);
  4844.     else
  4845.     name = "STDOUT";
  4846.     gv = gv_fetchpv(name,TRUE, SVt_PVFM);
  4847.     GvMULTI_on(gv);
  4848.     if ((cv = GvFORM(gv))) {
  4849.     if (ckWARN(WARN_REDEFINE)) {
  4850.         line_t oldline = CopLINE(PL_curcop);
  4851.  
  4852.         CopLINE_set(PL_curcop, PL_copline);
  4853.         Perl_warner(aTHX_ WARN_REDEFINE, "Format %s redefined",name);
  4854.         CopLINE_set(PL_curcop, oldline);
  4855.     }
  4856.     SvREFCNT_dec(cv);
  4857.     }
  4858.     cv = PL_compcv;
  4859.     GvFORM(gv) = cv;
  4860.     CvGV(cv) = (GV*)SvREFCNT_inc(gv);
  4861.     CvFILE(cv) = CopFILE(PL_curcop);
  4862.  
  4863.     for (ix = AvFILLp(PL_comppad); ix > 0; ix--) {
  4864.     if (!SvPADMY(PL_curpad[ix]) && !SvIMMORTAL(PL_curpad[ix]))
  4865.         SvPADTMP_on(PL_curpad[ix]);
  4866.     }
  4867.  
  4868.     CvROOT(cv) = newUNOP(OP_LEAVEWRITE, 0, scalarseq(block));
  4869.     CvROOT(cv)->op_private |= OPpREFCOUNTED;
  4870.     OpREFCNT_set(CvROOT(cv), 1);
  4871.     CvSTART(cv) = LINKLIST(CvROOT(cv));
  4872.     CvROOT(cv)->op_next = 0;
  4873.     peep(CvSTART(cv));
  4874.     op_free(o);
  4875.     PL_copline = NOLINE;
  4876.     LEAVE_SCOPE(floor);
  4877. }
  4878.  
  4879. OP *
  4880. Perl_newANONLIST(pTHX_ OP *o)
  4881. {
  4882.     return newUNOP(OP_REFGEN, 0,
  4883.     mod(list(convert(OP_ANONLIST, 0, o)), OP_REFGEN));
  4884. }
  4885.  
  4886. OP *
  4887. Perl_newANONHASH(pTHX_ OP *o)
  4888. {
  4889.     return newUNOP(OP_REFGEN, 0,
  4890.     mod(list(convert(OP_ANONHASH, 0, o)), OP_REFGEN));
  4891. }
  4892.  
  4893. OP *
  4894. Perl_newANONSUB(pTHX_ I32 floor, OP *proto, OP *block)
  4895. {
  4896.     return newANONATTRSUB(floor, proto, Nullop, block);
  4897. }
  4898.  
  4899. OP *
  4900. Perl_newANONATTRSUB(pTHX_ I32 floor, OP *proto, OP *attrs, OP *block)
  4901. {
  4902.     return newUNOP(OP_REFGEN, 0,
  4903.     newSVOP(OP_ANONCODE, 0,
  4904.         (SV*)newATTRSUB(floor, 0, proto, attrs, block)));
  4905. }
  4906.  
  4907. OP *
  4908. Perl_oopsAV(pTHX_ OP *o)
  4909. {
  4910.     switch (o->op_type) {
  4911.     case OP_PADSV:
  4912.     o->op_type = OP_PADAV;
  4913.     o->op_ppaddr = PL_ppaddr[OP_PADAV];
  4914.     return ref(o, OP_RV2AV);
  4915.     
  4916.     case OP_RV2SV:
  4917.     o->op_type = OP_RV2AV;
  4918.     o->op_ppaddr = PL_ppaddr[OP_RV2AV];
  4919.     ref(o, OP_RV2AV);
  4920.     break;
  4921.  
  4922.     default:
  4923.     if (ckWARN_d(WARN_INTERNAL))
  4924.         Perl_warner(aTHX_ WARN_INTERNAL, "oops: oopsAV");
  4925.     break;
  4926.     }
  4927.     return o;
  4928. }
  4929.  
  4930. OP *
  4931. Perl_oopsHV(pTHX_ OP *o)
  4932. {
  4933.     dTHR;
  4934.     
  4935.     switch (o->op_type) {
  4936.     case OP_PADSV:
  4937.     case OP_PADAV:
  4938.     o->op_type = OP_PADHV;
  4939.     o->op_ppaddr = PL_ppaddr[OP_PADHV];
  4940.     return ref(o, OP_RV2HV);
  4941.  
  4942.     case OP_RV2SV:
  4943.     case OP_RV2AV:
  4944.     o->op_type = OP_RV2HV;
  4945.     o->op_ppaddr = PL_ppaddr[OP_RV2HV];
  4946.     ref(o, OP_RV2HV);
  4947.     break;
  4948.  
  4949.     default:
  4950.     if (ckWARN_d(WARN_INTERNAL))
  4951.         Perl_warner(aTHX_ WARN_INTERNAL, "oops: oopsHV");
  4952.     break;
  4953.     }
  4954.     return o;
  4955. }
  4956.  
  4957. OP *
  4958. Perl_newAVREF(pTHX_ OP *o)
  4959. {
  4960.     if (o->op_type == OP_PADANY) {
  4961.     o->op_type = OP_PADAV;
  4962.     o->op_ppaddr = PL_ppaddr[OP_PADAV];
  4963.     return o;
  4964.     }
  4965.     return newUNOP(OP_RV2AV, 0, scalar(o));
  4966. }
  4967.  
  4968. OP *
  4969. Perl_newGVREF(pTHX_ I32 type, OP *o)
  4970. {
  4971.     if (type == OP_MAPSTART || type == OP_GREPSTART || type == OP_SORT)
  4972.     return newUNOP(OP_NULL, 0, o);
  4973.     return ref(newUNOP(OP_RV2GV, OPf_REF, o), type);
  4974. }
  4975.  
  4976. OP *
  4977. Perl_newHVREF(pTHX_ OP *o)
  4978. {
  4979.     if (o->op_type == OP_PADANY) {
  4980.     o->op_type = OP_PADHV;
  4981.     o->op_ppaddr = PL_ppaddr[OP_PADHV];
  4982.     return o;
  4983.     }
  4984.     return newUNOP(OP_RV2HV, 0, scalar(o));
  4985. }
  4986.  
  4987. OP *
  4988. Perl_oopsCV(pTHX_ OP *o)
  4989. {
  4990.     Perl_croak(aTHX_ "NOT IMPL LINE %d",__LINE__);
  4991.     /* STUB */
  4992.     return o;
  4993. }
  4994.  
  4995. OP *
  4996. Perl_newCVREF(pTHX_ I32 flags, OP *o)
  4997. {
  4998.     return newUNOP(OP_RV2CV, flags, scalar(o));
  4999. }
  5000.  
  5001. OP *
  5002. Perl_newSVREF(pTHX_ OP *o)
  5003. {
  5004.     if (o->op_type == OP_PADANY) {
  5005.     o->op_type = OP_PADSV;
  5006.     o->op_ppaddr = PL_ppaddr[OP_PADSV];
  5007.     return o;
  5008.     }
  5009.     else if (o->op_type == OP_THREADSV && !(o->op_flags & OPpDONE_SVREF)) {
  5010.     o->op_flags |= OPpDONE_SVREF;
  5011.     return o;
  5012.     }
  5013.     return newUNOP(OP_RV2SV, 0, scalar(o));
  5014. }
  5015.  
  5016. /* Check routines. */
  5017.  
  5018. OP *
  5019. Perl_ck_anoncode(pTHX_ OP *o)
  5020. {
  5021.     PADOFFSET ix;
  5022.     SV* name;
  5023.  
  5024.     name = NEWSV(1106,0);
  5025.     sv_upgrade(name, SVt_PVNV);
  5026.     sv_setpvn(name, "&", 1);
  5027.     SvIVX(name) = -1;
  5028.     SvNVX(name) = 1;
  5029.     ix = pad_alloc(o->op_type, SVs_PADMY);
  5030.     av_store(PL_comppad_name, ix, name);
  5031.     av_store(PL_comppad, ix, cSVOPo->op_sv);
  5032.     SvPADMY_on(cSVOPo->op_sv);
  5033.     cSVOPo->op_sv = Nullsv;
  5034.     cSVOPo->op_targ = ix;
  5035.     return o;
  5036. }
  5037.  
  5038. OP *
  5039. Perl_ck_bitop(pTHX_ OP *o)
  5040. {
  5041.     o->op_private = PL_hints;
  5042.     return o;
  5043. }
  5044.  
  5045. OP *
  5046. Perl_ck_concat(pTHX_ OP *o)
  5047. {
  5048.     if (cUNOPo->op_first->op_type == OP_CONCAT)
  5049.     o->op_flags |= OPf_STACKED;
  5050.     return o;
  5051. }
  5052.  
  5053. OP *
  5054. Perl_ck_spair(pTHX_ OP *o)
  5055. {
  5056.     if (o->op_flags & OPf_KIDS) {
  5057.     OP* newop;
  5058.     OP* kid;
  5059.     OPCODE type = o->op_type;
  5060.     o = modkids(ck_fun(o), type);
  5061.     kid = cUNOPo->op_first;
  5062.     newop = kUNOP->op_first->op_sibling;
  5063.     if (newop &&
  5064.         (newop->op_sibling ||
  5065.          !(PL_opargs[newop->op_type] & OA_RETSCALAR) ||
  5066.          newop->op_type == OP_PADAV || newop->op_type == OP_PADHV ||
  5067.          newop->op_type == OP_RV2AV || newop->op_type == OP_RV2HV)) {
  5068.     
  5069.         return o;
  5070.     }
  5071.     op_free(kUNOP->op_first);
  5072.     kUNOP->op_first = newop;
  5073.     }
  5074.     o->op_ppaddr = PL_ppaddr[++o->op_type];
  5075.     return ck_fun(o);
  5076. }
  5077.  
  5078. OP *
  5079. Perl_ck_delete(pTHX_ OP *o)
  5080. {
  5081.     o = ck_fun(o);
  5082.     o->op_private = 0;
  5083.     if (o->op_flags & OPf_KIDS) {
  5084.     OP *kid = cUNOPo->op_first;
  5085.     switch (kid->op_type) {
  5086.     case OP_ASLICE:
  5087.         o->op_flags |= OPf_SPECIAL;
  5088.         /* FALL THROUGH */
  5089.     case OP_HSLICE:
  5090.         o->op_private |= OPpSLICE;
  5091.         break;
  5092.     case OP_AELEM:
  5093.         o->op_flags |= OPf_SPECIAL;
  5094.         /* FALL THROUGH */
  5095.     case OP_HELEM:
  5096.         break;
  5097.     default:
  5098.         Perl_croak(aTHX_ "%s argument is not a HASH or ARRAY element or slice",
  5099.           PL_op_desc[o->op_type]);
  5100.     }
  5101.     null(kid);
  5102.     }
  5103.     return o;
  5104. }
  5105.  
  5106. OP *
  5107. Perl_ck_eof(pTHX_ OP *o)
  5108. {
  5109.     I32 type = o->op_type;
  5110.  
  5111.     if (o->op_flags & OPf_KIDS) {
  5112.     if (cLISTOPo->op_first->op_type == OP_STUB) {
  5113.         op_free(o);
  5114.         o = newUNOP(type, OPf_SPECIAL,
  5115.         newGVOP(OP_GV, 0, gv_fetchpv("main::ARGV", TRUE, SVt_PVAV)));
  5116.     }
  5117.     return ck_fun(o);
  5118.     }
  5119.     return o;
  5120. }
  5121.  
  5122. OP *
  5123. Perl_ck_eval(pTHX_ OP *o)
  5124. {
  5125.     PL_hints |= HINT_BLOCK_SCOPE;
  5126.     if (o->op_flags & OPf_KIDS) {
  5127.     SVOP *kid = (SVOP*)cUNOPo->op_first;
  5128.  
  5129.     if (!kid) {
  5130.         o->op_flags &= ~OPf_KIDS;
  5131.         null(o);
  5132.     }
  5133.     else if (kid->op_type == OP_LINESEQ) {
  5134.         LOGOP *enter;
  5135.  
  5136.         kid->op_next = o->op_next;
  5137.         cUNOPo->op_first = 0;
  5138.         op_free(o);
  5139.  
  5140.         NewOp(1101, enter, 1, LOGOP);
  5141.         enter->op_type = OP_ENTERTRY;
  5142.         enter->op_ppaddr = PL_ppaddr[OP_ENTERTRY];
  5143.         enter->op_private = 0;
  5144.  
  5145.         /* establish postfix order */
  5146.         enter->op_next = (OP*)enter;
  5147.  
  5148.         o = prepend_elem(OP_LINESEQ, (OP*)enter, (OP*)kid);
  5149.         o->op_type = OP_LEAVETRY;
  5150.         o->op_ppaddr = PL_ppaddr[OP_LEAVETRY];
  5151.         enter->op_other = o;
  5152.         return o;
  5153.     }
  5154.     else
  5155.         scalar((OP*)kid);
  5156.     }
  5157.     else {
  5158.     op_free(o);
  5159.     o = newUNOP(OP_ENTEREVAL, 0, newDEFSVOP());
  5160.     }
  5161.     o->op_targ = (PADOFFSET)PL_hints;
  5162.     return o;
  5163. }
  5164.  
  5165. OP *
  5166. Perl_ck_exit(pTHX_ OP *o)
  5167. {
  5168. #ifdef VMS
  5169.     HV *table = GvHV(PL_hintgv);
  5170.     if (table) {
  5171.        SV **svp = hv_fetch(table, "vmsish_exit", 11, FALSE);
  5172.        if (svp && *svp && SvTRUE(*svp))
  5173.            o->op_private |= OPpEXIT_VMSISH;
  5174.     }
  5175. #endif
  5176.     return ck_fun(o);
  5177. }
  5178.  
  5179. OP *
  5180. Perl_ck_exec(pTHX_ OP *o)
  5181. {
  5182.     OP *kid;
  5183.     if (o->op_flags & OPf_STACKED) {
  5184.     o = ck_fun(o);
  5185.     kid = cUNOPo->op_first->op_sibling;
  5186.     if (kid->op_type == OP_RV2GV)
  5187.         null(kid);
  5188.     }
  5189.     else
  5190.     o = listkids(o);
  5191.     return o;
  5192. }
  5193.  
  5194. OP *
  5195. Perl_ck_exists(pTHX_ OP *o)
  5196. {
  5197.     o = ck_fun(o);
  5198.     if (o->op_flags & OPf_KIDS) {
  5199.     OP *kid = cUNOPo->op_first;
  5200.     if (kid->op_type == OP_ENTERSUB) {
  5201.         (void) ref(kid, o->op_type);
  5202.         if (kid->op_type != OP_RV2CV && !PL_error_count)
  5203.         Perl_croak(aTHX_ "%s argument is not a subroutine name",
  5204.                PL_op_desc[o->op_type]);
  5205.         o->op_private |= OPpEXISTS_SUB;
  5206.     }
  5207.     else if (kid->op_type == OP_AELEM)
  5208.         o->op_flags |= OPf_SPECIAL;
  5209.     else if (kid->op_type != OP_HELEM)
  5210.         Perl_croak(aTHX_ "%s argument is not a HASH or ARRAY element",
  5211.                PL_op_desc[o->op_type]);
  5212.     null(kid);
  5213.     }
  5214.     return o;
  5215. }
  5216.  
  5217. #if 0
  5218. OP *
  5219. Perl_ck_gvconst(pTHX_ register OP *o)
  5220. {
  5221.     o = fold_constants(o);
  5222.     if (o->op_type == OP_CONST)
  5223.     o->op_type = OP_GV;
  5224.     return o;
  5225. }
  5226. #endif
  5227.  
  5228. OP *
  5229. Perl_ck_rvconst(pTHX_ register OP *o)
  5230. {
  5231.     dTHR;
  5232.     SVOP *kid = (SVOP*)cUNOPo->op_first;
  5233.  
  5234.     o->op_private |= (PL_hints & HINT_STRICT_REFS);
  5235.     if (kid->op_type == OP_CONST) {
  5236.     char *name;
  5237.     int iscv;
  5238.     GV *gv;
  5239.     SV *kidsv = kid->op_sv;
  5240.     STRLEN n_a;
  5241.  
  5242.     /* Is it a constant from cv_const_sv()? */
  5243.     if (SvROK(kidsv) && SvREADONLY(kidsv)) {
  5244.         SV *rsv = SvRV(kidsv);
  5245.         int svtype = SvTYPE(rsv);
  5246.         char *badtype = Nullch;
  5247.  
  5248.         switch (o->op_type) {
  5249.         case OP_RV2SV:
  5250.         if (svtype > SVt_PVMG)
  5251.             badtype = "a SCALAR";
  5252.         break;
  5253.         case OP_RV2AV:
  5254.         if (svtype != SVt_PVAV)
  5255.             badtype = "an ARRAY";
  5256.         break;
  5257.         case OP_RV2HV:
  5258.         if (svtype != SVt_PVHV) {
  5259.             if (svtype == SVt_PVAV) {    /* pseudohash? */
  5260.             SV **ksv = av_fetch((AV*)rsv, 0, FALSE);
  5261.             if (ksv && SvROK(*ksv)
  5262.                 && SvTYPE(SvRV(*ksv)) == SVt_PVHV)
  5263.             {
  5264.                 break;
  5265.             }
  5266.             }
  5267.             badtype = "a HASH";
  5268.         }
  5269.         break;
  5270.         case OP_RV2CV:
  5271.         if (svtype != SVt_PVCV)
  5272.             badtype = "a CODE";
  5273.         break;
  5274.         }
  5275.         if (badtype)
  5276.         Perl_croak(aTHX_ "Constant is not %s reference", badtype);
  5277.         return o;
  5278.     }
  5279.     name = SvPV(kidsv, n_a);
  5280.     if ((PL_hints & HINT_STRICT_REFS) && (kid->op_private & OPpCONST_BARE)) {
  5281.         char *badthing = Nullch;
  5282.         switch (o->op_type) {
  5283.         case OP_RV2SV:
  5284.         badthing = "a SCALAR";
  5285.         break;
  5286.         case OP_RV2AV:
  5287.         badthing = "an ARRAY";
  5288.         break;
  5289.         case OP_RV2HV:
  5290.         badthing = "a HASH";
  5291.         break;
  5292.         }
  5293.         if (badthing)
  5294.         Perl_croak(aTHX_ 
  5295.       "Can't use bareword (\"%s\") as %s ref while \"strict refs\" in use",
  5296.               name, badthing);
  5297.     }
  5298.     /*
  5299.      * This is a little tricky.  We only want to add the symbol if we
  5300.      * didn't add it in the lexer.  Otherwise we get duplicate strict
  5301.      * warnings.  But if we didn't add it in the lexer, we must at
  5302.      * least pretend like we wanted to add it even if it existed before,
  5303.      * or we get possible typo warnings.  OPpCONST_ENTERED says
  5304.      * whether the lexer already added THIS instance of this symbol.
  5305.      */
  5306.     iscv = (o->op_type == OP_RV2CV) * 2;
  5307.     do {
  5308.         gv = gv_fetchpv(name,
  5309.         iscv | !(kid->op_private & OPpCONST_ENTERED),
  5310.         iscv
  5311.             ? SVt_PVCV
  5312.             : o->op_type == OP_RV2SV
  5313.             ? SVt_PV
  5314.             : o->op_type == OP_RV2AV
  5315.                 ? SVt_PVAV
  5316.                 : o->op_type == OP_RV2HV
  5317.                 ? SVt_PVHV
  5318.                 : SVt_PVGV);
  5319.     } while (!gv && !(kid->op_private & OPpCONST_ENTERED) && !iscv++);
  5320.     if (gv) {
  5321.         kid->op_type = OP_GV;
  5322.         SvREFCNT_dec(kid->op_sv);
  5323. #ifdef USE_ITHREADS
  5324.         /* XXX hack: dependence on sizeof(PADOP) <= sizeof(SVOP) */
  5325.         kPADOP->op_padix = pad_alloc(OP_GV, SVs_PADTMP);
  5326.         GvIN_PAD_on(gv);
  5327.         PL_curpad[kPADOP->op_padix] = SvREFCNT_inc(gv);
  5328. #else
  5329.         kid->op_sv = SvREFCNT_inc(gv);
  5330. #endif
  5331.         kid->op_ppaddr = PL_ppaddr[OP_GV];
  5332.     }
  5333.     }
  5334.     return o;
  5335. }
  5336.  
  5337. OP *
  5338. Perl_ck_ftst(pTHX_ OP *o)
  5339. {
  5340.     dTHR;
  5341.     I32 type = o->op_type;
  5342.  
  5343.     if (o->op_flags & OPf_REF) {
  5344.     /* nothing */
  5345.     }
  5346.     else if (o->op_flags & OPf_KIDS && cUNOPo->op_first->op_type != OP_STUB) {
  5347.     SVOP *kid = (SVOP*)cUNOPo->op_first;
  5348.  
  5349.     if (kid->op_type == OP_CONST && (kid->op_private & OPpCONST_BARE)) {
  5350.         STRLEN n_a;
  5351.         OP *newop = newGVOP(type, OPf_REF,
  5352.         gv_fetchpv(SvPVx(kid->op_sv, n_a), TRUE, SVt_PVIO));
  5353.         op_free(o);
  5354.         o = newop;
  5355.     }
  5356.     }
  5357.     else {
  5358.     op_free(o);
  5359.     if (type == OP_FTTTY)
  5360.            o =  newGVOP(type, OPf_REF, gv_fetchpv("main::STDIN", TRUE,
  5361.                 SVt_PVIO));
  5362.     else
  5363.         o = newUNOP(type, 0, newDEFSVOP());
  5364.     }
  5365. #ifdef USE_LOCALE
  5366.     if (type == OP_FTTEXT || type == OP_FTBINARY) {
  5367.     o->op_private = 0;
  5368.     if (PL_hints & HINT_LOCALE)
  5369.         o->op_private |= OPpLOCALE;
  5370.     }
  5371. #endif
  5372.     return o;
  5373. }
  5374.  
  5375. OP *
  5376. Perl_ck_fun(pTHX_ OP *o)
  5377. {
  5378.     dTHR;
  5379.     register OP *kid;
  5380.     OP **tokid;
  5381.     OP *sibl;
  5382.     I32 numargs = 0;
  5383.     int type = o->op_type;
  5384.     register I32 oa = PL_opargs[type] >> OASHIFT;
  5385.  
  5386.     if (o->op_flags & OPf_STACKED) {
  5387.     if ((oa & OA_OPTIONAL) && (oa >> 4) && !((oa >> 4) & OA_OPTIONAL))
  5388.         oa &= ~OA_OPTIONAL;
  5389.     else
  5390.         return no_fh_allowed(o);
  5391.     }
  5392.  
  5393.     if (o->op_flags & OPf_KIDS) {
  5394.     STRLEN n_a;
  5395.     tokid = &cLISTOPo->op_first;
  5396.     kid = cLISTOPo->op_first;
  5397.     if (kid->op_type == OP_PUSHMARK ||
  5398.         (kid->op_type == OP_NULL && kid->op_targ == OP_PUSHMARK))
  5399.     {
  5400.         tokid = &kid->op_sibling;
  5401.         kid = kid->op_sibling;
  5402.     }
  5403.     if (!kid && PL_opargs[type] & OA_DEFGV)
  5404.         *tokid = kid = newDEFSVOP();
  5405.  
  5406.     while (oa && kid) {
  5407.         numargs++;
  5408.         sibl = kid->op_sibling;
  5409.         switch (oa & 7) {
  5410.         case OA_SCALAR:
  5411.         /* list seen where single (scalar) arg expected? */
  5412.         if (numargs == 1 && !(oa >> 4)
  5413.             && kid->op_type == OP_LIST && type != OP_SCALAR)
  5414.         {
  5415.             return too_many_arguments(o,PL_op_desc[type]);
  5416.         }
  5417.         scalar(kid);
  5418.         break;
  5419.         case OA_LIST:
  5420.         if (oa < 16) {
  5421.             kid = 0;
  5422.             continue;
  5423.         }
  5424.         else
  5425.             list(kid);
  5426.         break;
  5427.         case OA_AVREF:
  5428.         if (kid->op_type == OP_CONST &&
  5429.             (kid->op_private & OPpCONST_BARE))
  5430.         {
  5431.             char *name = SvPVx(((SVOP*)kid)->op_sv, n_a);
  5432.             OP *newop = newAVREF(newGVOP(OP_GV, 0,
  5433.             gv_fetchpv(name, TRUE, SVt_PVAV) ));
  5434.             if (ckWARN(WARN_DEPRECATED))
  5435.             Perl_warner(aTHX_ WARN_DEPRECATED,
  5436.                 "Array @%s missing the @ in argument %"IVdf" of %s()",
  5437.                 name, (IV)numargs, PL_op_desc[type]);
  5438.             op_free(kid);
  5439.             kid = newop;
  5440.             kid->op_sibling = sibl;
  5441.             *tokid = kid;
  5442.         }
  5443.         else if (kid->op_type != OP_RV2AV && kid->op_type != OP_PADAV)
  5444.             bad_type(numargs, "array", PL_op_desc[type], kid);
  5445.         mod(kid, type);
  5446.         break;
  5447.         case OA_HVREF:
  5448.         if (kid->op_type == OP_CONST &&
  5449.             (kid->op_private & OPpCONST_BARE))
  5450.         {
  5451.             char *name = SvPVx(((SVOP*)kid)->op_sv, n_a);
  5452.             OP *newop = newHVREF(newGVOP(OP_GV, 0,
  5453.             gv_fetchpv(name, TRUE, SVt_PVHV) ));
  5454.             if (ckWARN(WARN_DEPRECATED))
  5455.             Perl_warner(aTHX_ WARN_DEPRECATED,
  5456.                 "Hash %%%s missing the %% in argument %"IVdf" of %s()",
  5457.                 name, (IV)numargs, PL_op_desc[type]);
  5458.             op_free(kid);
  5459.             kid = newop;
  5460.             kid->op_sibling = sibl;
  5461.             *tokid = kid;
  5462.         }
  5463.         else if (kid->op_type != OP_RV2HV && kid->op_type != OP_PADHV)
  5464.             bad_type(numargs, "hash", PL_op_desc[type], kid);
  5465.         mod(kid, type);
  5466.         break;
  5467.         case OA_CVREF:
  5468.         {
  5469.             OP *newop = newUNOP(OP_NULL, 0, kid);
  5470.             kid->op_sibling = 0;
  5471.             linklist(kid);
  5472.             newop->op_next = newop;
  5473.             kid = newop;
  5474.             kid->op_sibling = sibl;
  5475.             *tokid = kid;
  5476.         }
  5477.         break;
  5478.         case OA_FILEREF:
  5479.         if (kid->op_type != OP_GV && kid->op_type != OP_RV2GV) {
  5480.             if (kid->op_type == OP_CONST &&
  5481.             (kid->op_private & OPpCONST_BARE))
  5482.             {
  5483.             OP *newop = newGVOP(OP_GV, 0,
  5484.                 gv_fetchpv(SvPVx(((SVOP*)kid)->op_sv, n_a), TRUE,
  5485.                     SVt_PVIO) );
  5486.             op_free(kid);
  5487.             kid = newop;
  5488.             }
  5489.             else if (kid->op_type == OP_READLINE) {
  5490.             /* neophyte patrol: open(<FH>), close(<FH>) etc. */
  5491.             bad_type(numargs, "HANDLE", PL_op_desc[o->op_type], kid);
  5492.             }
  5493.             else {
  5494.             I32 flags = OPf_SPECIAL;
  5495.             I32 priv = 0;
  5496.             PADOFFSET targ = 0;
  5497.  
  5498.             /* is this op a FH constructor? */
  5499.             if (is_handle_constructor(o,numargs)) {
  5500.                 char *name = Nullch;
  5501.                 STRLEN len;
  5502.  
  5503.                 flags = 0;
  5504.                 /* Set a flag to tell rv2gv to vivify
  5505.                  * need to "prove" flag does not mean something
  5506.                  * else already - NI-S 1999/05/07
  5507.                  */
  5508.                 priv = OPpDEREF;
  5509.                 if (kid->op_type == OP_PADSV) {
  5510.                 SV **namep = av_fetch(PL_comppad_name,
  5511.                               kid->op_targ, 4);
  5512.                 if (namep && *namep)
  5513.                     name = SvPV(*namep, len);
  5514.                 }
  5515.                 else if (kid->op_type == OP_RV2SV
  5516.                      && kUNOP->op_first->op_type == OP_GV)
  5517.                 {
  5518.                 GV *gv = cGVOPx_gv(kUNOP->op_first);
  5519.                 name = GvNAME(gv);
  5520.                 len = GvNAMELEN(gv);
  5521.                 }
  5522.                 else if (kid->op_type == OP_AELEM
  5523.                      || kid->op_type == OP_HELEM)
  5524.                 {
  5525.                 name = "__ANONIO__";
  5526.                 len = 10;
  5527.                 mod(kid,type);
  5528.                 }
  5529.                 if (name) {
  5530.                 SV *namesv;
  5531.                 targ = pad_alloc(OP_RV2GV, SVs_PADTMP);
  5532.                 namesv = PL_curpad[targ];
  5533.                 (void)SvUPGRADE(namesv, SVt_PV);
  5534.                 if (*name != '$')
  5535.                     sv_setpvn(namesv, "$", 1);
  5536.                 sv_catpvn(namesv, name, len);
  5537.                 }
  5538.             }
  5539.             kid->op_sibling = 0;
  5540.             kid = newUNOP(OP_RV2GV, flags, scalar(kid));
  5541.             kid->op_targ = targ;
  5542.             kid->op_private |= priv;
  5543.             }
  5544.             kid->op_sibling = sibl;
  5545.             *tokid = kid;
  5546.         }
  5547.         scalar(kid);
  5548.         break;
  5549.         case OA_SCALARREF:
  5550.         mod(scalar(kid), type);
  5551.         break;
  5552.         }
  5553.         oa >>= 4;
  5554.         tokid = &kid->op_sibling;
  5555.         kid = kid->op_sibling;
  5556.     }
  5557.     o->op_private |= numargs;
  5558.     if (kid)
  5559.         return too_many_arguments(o,PL_op_desc[o->op_type]);
  5560.     listkids(o);
  5561.     }
  5562.     else if (PL_opargs[type] & OA_DEFGV) {
  5563.     op_free(o);
  5564.     return newUNOP(type, 0, newDEFSVOP());
  5565.     }
  5566.  
  5567.     if (oa) {
  5568.     while (oa & OA_OPTIONAL)
  5569.         oa >>= 4;
  5570.     if (oa && oa != OA_LIST)
  5571.         return too_few_arguments(o,PL_op_desc[o->op_type]);
  5572.     }
  5573.     return o;
  5574. }
  5575.  
  5576. OP *
  5577. Perl_ck_glob(pTHX_ OP *o)
  5578. {
  5579.     GV *gv;
  5580.  
  5581.     o = ck_fun(o);
  5582.     if ((o->op_flags & OPf_KIDS) && !cLISTOPo->op_first->op_sibling)
  5583.     append_elem(OP_GLOB, o, newDEFSVOP());
  5584.  
  5585.     if (!((gv = gv_fetchpv("glob", FALSE, SVt_PVCV)) && GvIMPORTED_CV(gv)))
  5586.     gv = gv_fetchpv("CORE::GLOBAL::glob", FALSE, SVt_PVCV);
  5587.  
  5588. #if !defined(PERL_EXTERNAL_GLOB)
  5589.     /* XXX this can be tightened up and made more failsafe. */
  5590.     if (!gv) {
  5591.     ENTER;
  5592.     Perl_load_module(aTHX_ 0, newSVpvn("File::Glob", 10), Nullsv,
  5593.              /* null-terminated import list */
  5594.              newSVpvn(":globally", 9), Nullsv);
  5595.     gv = gv_fetchpv("CORE::GLOBAL::glob", FALSE, SVt_PVCV);
  5596.     LEAVE;
  5597.     }
  5598. #endif /* PERL_EXTERNAL_GLOB */
  5599.  
  5600.     if (gv && GvIMPORTED_CV(gv)) {
  5601.     append_elem(OP_GLOB, o,
  5602.             newSVOP(OP_CONST, 0, newSViv(PL_glob_index++)));
  5603.     o->op_type = OP_LIST;
  5604.     o->op_ppaddr = PL_ppaddr[OP_LIST];
  5605.     cLISTOPo->op_first->op_type = OP_PUSHMARK;
  5606.     cLISTOPo->op_first->op_ppaddr = PL_ppaddr[OP_PUSHMARK];
  5607.     o = newUNOP(OP_ENTERSUB, OPf_STACKED,
  5608.             append_elem(OP_LIST, o,
  5609.                 scalar(newUNOP(OP_RV2CV, 0,
  5610.                            newGVOP(OP_GV, 0, gv)))));
  5611.     o = newUNOP(OP_NULL, 0, ck_subr(o));
  5612.     o->op_targ = OP_GLOB;        /* hint at what it used to be */
  5613.     return o;
  5614.     }
  5615.     gv = newGVgen("main");
  5616.     gv_IOadd(gv);
  5617.     append_elem(OP_GLOB, o, newGVOP(OP_GV, 0, gv));
  5618.     scalarkids(o);
  5619.     return o;
  5620. }
  5621.  
  5622. OP *
  5623. Perl_ck_grep(pTHX_ OP *o)
  5624. {
  5625.     LOGOP *gwop;
  5626.     OP *kid;
  5627.     OPCODE type = o->op_type == OP_GREPSTART ? OP_GREPWHILE : OP_MAPWHILE;
  5628.  
  5629.     o->op_ppaddr = PL_ppaddr[OP_GREPSTART];
  5630.     NewOp(1101, gwop, 1, LOGOP);
  5631.  
  5632.     if (o->op_flags & OPf_STACKED) {
  5633.     OP* k;
  5634.     o = ck_sort(o);
  5635.         kid = cLISTOPo->op_first->op_sibling;
  5636.     for (k = cLISTOPo->op_first->op_sibling->op_next; k; k = k->op_next) {
  5637.         kid = k;
  5638.     }
  5639.     kid->op_next = (OP*)gwop;
  5640.     o->op_flags &= ~OPf_STACKED;
  5641.     }
  5642.     kid = cLISTOPo->op_first->op_sibling;
  5643.     if (type == OP_MAPWHILE)
  5644.     list(kid);
  5645.     else
  5646.     scalar(kid);
  5647.     o = ck_fun(o);
  5648.     if (PL_error_count)
  5649.     return o;
  5650.     kid = cLISTOPo->op_first->op_sibling;
  5651.     if (kid->op_type != OP_NULL)
  5652.     Perl_croak(aTHX_ "panic: ck_grep");
  5653.     kid = kUNOP->op_first;
  5654.  
  5655.     gwop->op_type = type;
  5656.     gwop->op_ppaddr = PL_ppaddr[type];
  5657.     gwop->op_first = listkids(o);
  5658.     gwop->op_flags |= OPf_KIDS;
  5659.     gwop->op_private = 1;
  5660.     gwop->op_other = LINKLIST(kid);
  5661.     gwop->op_targ = pad_alloc(type, SVs_PADTMP);
  5662.     kid->op_next = (OP*)gwop;
  5663.  
  5664.     kid = cLISTOPo->op_first->op_sibling;
  5665.     if (!kid || !kid->op_sibling)
  5666.     return too_few_arguments(o,PL_op_desc[o->op_type]);
  5667.     for (kid = kid->op_sibling; kid; kid = kid->op_sibling)
  5668.     mod(kid, OP_GREPSTART);
  5669.  
  5670.     return (OP*)gwop;
  5671. }
  5672.  
  5673. OP *
  5674. Perl_ck_index(pTHX_ OP *o)
  5675. {
  5676.     if (o->op_flags & OPf_KIDS) {
  5677.     OP *kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
  5678.     if (kid)
  5679.         kid = kid->op_sibling;            /* get past "big" */
  5680.     if (kid && kid->op_type == OP_CONST)
  5681.         fbm_compile(((SVOP*)kid)->op_sv, 0);
  5682.     }
  5683.     return ck_fun(o);
  5684. }
  5685.  
  5686. OP *
  5687. Perl_ck_lengthconst(pTHX_ OP *o)
  5688. {
  5689.     /* XXX length optimization goes here */
  5690.     return ck_fun(o);
  5691. }
  5692.  
  5693. OP *
  5694. Perl_ck_lfun(pTHX_ OP *o)
  5695. {
  5696.     OPCODE type = o->op_type;
  5697.     return modkids(ck_fun(o), type);
  5698. }
  5699.  
  5700. OP *
  5701. Perl_ck_defined(pTHX_ OP *o)        /* 19990527 MJD */
  5702. {
  5703.     dTHR;
  5704.     if ((o->op_flags & OPf_KIDS) && ckWARN(WARN_DEPRECATED)) {
  5705.     switch (cUNOPo->op_first->op_type) {
  5706.     case OP_RV2AV:
  5707.         break;                      /* Globals via GV can be undef */ 
  5708.     case OP_PADAV:
  5709.     case OP_AASSIGN:        /* Is this a good idea? */
  5710.         Perl_warner(aTHX_ WARN_DEPRECATED,
  5711.             "defined(@array) is deprecated");
  5712.         Perl_warner(aTHX_ WARN_DEPRECATED,
  5713.             "\t(Maybe you should just omit the defined()?)\n");
  5714.     break;
  5715.     case OP_RV2HV:
  5716.         break;                      /* Globals via GV can be undef */ 
  5717.     case OP_PADHV:
  5718.         Perl_warner(aTHX_ WARN_DEPRECATED,
  5719.             "defined(%%hash) is deprecated");
  5720.         Perl_warner(aTHX_ WARN_DEPRECATED,
  5721.             "\t(Maybe you should just omit the defined()?)\n");
  5722.         break;
  5723.     default:
  5724.         /* no warning */
  5725.         break;
  5726.     }
  5727.     }
  5728.     return ck_rfun(o);
  5729. }
  5730.  
  5731. OP *
  5732. Perl_ck_rfun(pTHX_ OP *o)
  5733. {
  5734.     OPCODE type = o->op_type;
  5735.     return refkids(ck_fun(o), type);
  5736. }
  5737.  
  5738. OP *
  5739. Perl_ck_listiob(pTHX_ OP *o)
  5740. {
  5741.     register OP *kid;
  5742.  
  5743.     kid = cLISTOPo->op_first;
  5744.     if (!kid) {
  5745.     o = force_list(o);
  5746.     kid = cLISTOPo->op_first;
  5747.     }
  5748.     if (kid->op_type == OP_PUSHMARK)
  5749.     kid = kid->op_sibling;
  5750.     if (kid && o->op_flags & OPf_STACKED)
  5751.     kid = kid->op_sibling;
  5752.     else if (kid && !kid->op_sibling) {        /* print HANDLE; */
  5753.     if (kid->op_type == OP_CONST && kid->op_private & OPpCONST_BARE) {
  5754.         o->op_flags |= OPf_STACKED;    /* make it a filehandle */
  5755.         kid = newUNOP(OP_RV2GV, OPf_REF, scalar(kid));
  5756.         cLISTOPo->op_first->op_sibling = kid;
  5757.         cLISTOPo->op_last = kid;
  5758.         kid = kid->op_sibling;
  5759.     }
  5760.     }
  5761.     
  5762.     if (!kid)
  5763.     append_elem(o->op_type, o, newDEFSVOP());
  5764.  
  5765.     o = listkids(o);
  5766.  
  5767.     o->op_private = 0;
  5768. #ifdef USE_LOCALE
  5769.     if (PL_hints & HINT_LOCALE)
  5770.     o->op_private |= OPpLOCALE;
  5771. #endif
  5772.  
  5773.     return o;
  5774. }
  5775.  
  5776. OP *
  5777. Perl_ck_fun_locale(pTHX_ OP *o)
  5778. {
  5779.     o = ck_fun(o);
  5780.  
  5781.     o->op_private = 0;
  5782. #ifdef USE_LOCALE
  5783.     if (PL_hints & HINT_LOCALE)
  5784.     o->op_private |= OPpLOCALE;
  5785. #endif
  5786.  
  5787.     return o;
  5788. }
  5789.  
  5790. OP *
  5791. Perl_ck_sassign(pTHX_ OP *o)
  5792. {
  5793.     OP *kid = cLISTOPo->op_first;
  5794.     /* has a disposable target? */
  5795.     if ((PL_opargs[kid->op_type] & OA_TARGLEX)
  5796.     && !(kid->op_flags & OPf_STACKED)
  5797.     /* Cannot steal the second time! */
  5798.     && !(kid->op_private & OPpTARGET_MY))
  5799.     {
  5800.     OP *kkid = kid->op_sibling;
  5801.  
  5802.     /* Can just relocate the target. */
  5803.     if (kkid && kkid->op_type == OP_PADSV
  5804.         && !(kkid->op_private & OPpLVAL_INTRO))
  5805.     {
  5806.         kid->op_targ = kkid->op_targ;
  5807.         kkid->op_targ = 0;
  5808.         /* Now we do not need PADSV and SASSIGN. */
  5809.         kid->op_sibling = o->op_sibling;    /* NULL */
  5810.         cLISTOPo->op_first = NULL;
  5811.         op_free(o);
  5812.         op_free(kkid);
  5813.         kid->op_private |= OPpTARGET_MY;    /* Used for context settings */
  5814.         return kid;
  5815.     }
  5816.     }
  5817.     return o;
  5818. }
  5819.  
  5820. OP *
  5821. Perl_ck_scmp(pTHX_ OP *o)
  5822. {
  5823.     o->op_private = 0;
  5824. #ifdef USE_LOCALE
  5825.     if (PL_hints & HINT_LOCALE)
  5826.     o->op_private |= OPpLOCALE;
  5827. #endif
  5828.  
  5829.     return o;
  5830. }
  5831.  
  5832. OP *
  5833. Perl_ck_match(pTHX_ OP *o)
  5834. {
  5835.     o->op_private |= OPpRUNTIME;
  5836.     return o;
  5837. }
  5838.  
  5839. OP *
  5840. Perl_ck_method(pTHX_ OP *o)
  5841. {
  5842.     OP *kid = cUNOPo->op_first;
  5843.     if (kid->op_type == OP_CONST) {
  5844.     SV* sv = kSVOP->op_sv;
  5845.     if (!(strchr(SvPVX(sv), ':') || strchr(SvPVX(sv), '\''))) {
  5846.         OP *cmop;
  5847.         (void)SvUPGRADE(sv, SVt_PVIV);
  5848.         (void)SvIOK_on(sv);
  5849.         PERL_HASH(SvUVX(sv), SvPVX(sv), SvCUR(sv));
  5850.         cmop = newSVOP(OP_METHOD_NAMED, 0, sv);
  5851.         kSVOP->op_sv = Nullsv;
  5852.         op_free(o);
  5853.         return cmop;
  5854.     }
  5855.     }
  5856.     return o;
  5857. }
  5858.  
  5859. OP *
  5860. Perl_ck_null(pTHX_ OP *o)
  5861. {
  5862.     return o;
  5863. }
  5864.  
  5865. OP *
  5866. Perl_ck_open(pTHX_ OP *o)
  5867. {
  5868.     HV *table = GvHV(PL_hintgv);
  5869.     if (table) {
  5870.     SV **svp;
  5871.     I32 mode;
  5872.     svp = hv_fetch(table, "open_IN", 7, FALSE);
  5873.     if (svp && *svp) {
  5874.         mode = mode_from_discipline(*svp);
  5875.         if (mode & O_BINARY)
  5876.         o->op_private |= OPpOPEN_IN_RAW;
  5877.         else if (mode & O_TEXT)
  5878.         o->op_private |= OPpOPEN_IN_CRLF;
  5879.     }
  5880.  
  5881.     svp = hv_fetch(table, "open_OUT", 8, FALSE);
  5882.     if (svp && *svp) {
  5883.         mode = mode_from_discipline(*svp);
  5884.         if (mode & O_BINARY)
  5885.         o->op_private |= OPpOPEN_OUT_RAW;
  5886.         else if (mode & O_TEXT)
  5887.         o->op_private |= OPpOPEN_OUT_CRLF;
  5888.     }
  5889.     }
  5890.     if (o->op_type == OP_BACKTICK)
  5891.     return o;
  5892.     return ck_fun(o);
  5893. }
  5894.  
  5895. OP *
  5896. Perl_ck_repeat(pTHX_ OP *o)
  5897. {
  5898.     if (cBINOPo->op_first->op_flags & OPf_PARENS) {
  5899.     o->op_private |= OPpREPEAT_DOLIST;
  5900.     cBINOPo->op_first = force_list(cBINOPo->op_first);
  5901.     }
  5902.     else
  5903.     scalar(o);
  5904.     return o;
  5905. }
  5906.  
  5907. OP *
  5908. Perl_ck_require(pTHX_ OP *o)
  5909. {
  5910.     if (o->op_flags & OPf_KIDS) {    /* Shall we supply missing .pm? */
  5911.     SVOP *kid = (SVOP*)cUNOPo->op_first;
  5912.  
  5913.     if (kid->op_type == OP_CONST && (kid->op_private & OPpCONST_BARE)) {
  5914.         char *s;
  5915.         for (s = SvPVX(kid->op_sv); *s; s++) {
  5916.         if (*s == ':' && s[1] == ':') {
  5917.             *s = '/';
  5918.             Move(s+2, s+1, strlen(s+2)+1, char);
  5919.             --SvCUR(kid->op_sv);
  5920.         }
  5921.         }
  5922.         if (SvREADONLY(kid->op_sv)) {
  5923.         SvREADONLY_off(kid->op_sv);
  5924.         sv_catpvn(kid->op_sv, ".pm", 3);
  5925.         SvREADONLY_on(kid->op_sv);
  5926.         }
  5927.         else
  5928.         sv_catpvn(kid->op_sv, ".pm", 3);
  5929.     }
  5930.     }
  5931.     return ck_fun(o);
  5932. }
  5933.  
  5934. #if 0
  5935. OP *
  5936. Perl_ck_retarget(pTHX_ OP *o)
  5937. {
  5938.     Perl_croak(aTHX_ "NOT IMPL LINE %d",__LINE__);
  5939.     /* STUB */
  5940.     return o;
  5941. }
  5942. #endif
  5943.  
  5944. OP *
  5945. Perl_ck_select(pTHX_ OP *o)
  5946. {
  5947.     OP* kid;
  5948.     if (o->op_flags & OPf_KIDS) {
  5949.     kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
  5950.     if (kid && kid->op_sibling) {
  5951.         o->op_type = OP_SSELECT;
  5952.         o->op_ppaddr = PL_ppaddr[OP_SSELECT];
  5953.         o = ck_fun(o);
  5954.         return fold_constants(o);
  5955.     }
  5956.     }
  5957.     o = ck_fun(o);
  5958.     kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
  5959.     if (kid && kid->op_type == OP_RV2GV)
  5960.     kid->op_private &= ~HINT_STRICT_REFS;
  5961.     return o;
  5962. }
  5963.  
  5964. OP *
  5965. Perl_ck_shift(pTHX_ OP *o)
  5966. {
  5967.     I32 type = o->op_type;
  5968.  
  5969.     if (!(o->op_flags & OPf_KIDS)) {
  5970.     OP *argop;
  5971.     
  5972.     op_free(o);
  5973. #ifdef USE_THREADS
  5974.     if (!CvUNIQUE(PL_compcv)) {
  5975.         argop = newOP(OP_PADAV, OPf_REF);
  5976.         argop->op_targ = 0;        /* PL_curpad[0] is @_ */
  5977.     }
  5978.     else {
  5979.         argop = newUNOP(OP_RV2AV, 0,
  5980.         scalar(newGVOP(OP_GV, 0,
  5981.             gv_fetchpv("ARGV", TRUE, SVt_PVAV))));
  5982.     }
  5983. #else
  5984.     argop = newUNOP(OP_RV2AV, 0,
  5985.         scalar(newGVOP(OP_GV, 0, !CvUNIQUE(PL_compcv) ?
  5986.                PL_defgv : gv_fetchpv("ARGV", TRUE, SVt_PVAV))));
  5987. #endif /* USE_THREADS */
  5988.     return newUNOP(type, 0, scalar(argop));
  5989.     }
  5990.     return scalar(modkids(ck_fun(o), type));
  5991. }
  5992.  
  5993. OP *
  5994. Perl_ck_sort(pTHX_ OP *o)
  5995. {
  5996.     o->op_private = 0;
  5997. #ifdef USE_LOCALE
  5998.     if (PL_hints & HINT_LOCALE)
  5999.     o->op_private |= OPpLOCALE;
  6000. #endif
  6001.  
  6002.     if (o->op_type == OP_SORT && o->op_flags & OPf_STACKED)
  6003.     simplify_sort(o);
  6004.     if (o->op_flags & OPf_STACKED) {             /* may have been cleared */
  6005.     OP *kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
  6006.     OP *k;
  6007.     kid = kUNOP->op_first;                /* get past null */
  6008.  
  6009.     if (kid->op_type == OP_SCOPE || kid->op_type == OP_LEAVE) {
  6010.         linklist(kid);
  6011.         if (kid->op_type == OP_SCOPE) {
  6012.         k = kid->op_next;
  6013.         kid->op_next = 0;
  6014.         }
  6015.         else if (kid->op_type == OP_LEAVE) {
  6016.         if (o->op_type == OP_SORT) {
  6017.             null(kid);            /* wipe out leave */
  6018.             kid->op_next = kid;
  6019.  
  6020.             for (k = kLISTOP->op_first->op_next; k; k = k->op_next) {
  6021.             if (k->op_next == kid)
  6022.                 k->op_next = 0;
  6023.             /* don't descend into loops */
  6024.             else if (k->op_type == OP_ENTERLOOP
  6025.                  || k->op_type == OP_ENTERITER)
  6026.             {
  6027.                 k = cLOOPx(k)->op_lastop;
  6028.             }
  6029.             }
  6030.         }
  6031.         else
  6032.             kid->op_next = 0;        /* just disconnect the leave */
  6033.         k = kLISTOP->op_first;
  6034.         }
  6035.         peep(k);
  6036.  
  6037.         kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
  6038.         if (o->op_type == OP_SORT)
  6039.         kid->op_next = kid;
  6040.         else
  6041.         kid->op_next = k;
  6042.         o->op_flags |= OPf_SPECIAL;
  6043.     }
  6044.     else if (kid->op_type == OP_RV2SV || kid->op_type == OP_PADSV)
  6045.         null(cLISTOPo->op_first->op_sibling);
  6046.     }
  6047.  
  6048.     return o;
  6049. }
  6050.  
  6051. STATIC void
  6052. S_simplify_sort(pTHX_ OP *o)
  6053. {
  6054.     dTHR;
  6055.     register OP *kid = cLISTOPo->op_first->op_sibling;    /* get past pushmark */
  6056.     OP *k;
  6057.     int reversed;
  6058.     GV *gv;
  6059.     if (!(o->op_flags & OPf_STACKED))
  6060.     return;
  6061.     GvMULTI_on(gv_fetchpv("a", TRUE, SVt_PV)); 
  6062.     GvMULTI_on(gv_fetchpv("b", TRUE, SVt_PV)); 
  6063.     kid = kUNOP->op_first;                /* get past null */
  6064.     if (kid->op_type != OP_SCOPE)
  6065.     return;
  6066.     kid = kLISTOP->op_last;                /* get past scope */
  6067.     switch(kid->op_type) {
  6068.     case OP_NCMP:
  6069.     case OP_I_NCMP:
  6070.     case OP_SCMP:
  6071.         break;
  6072.     default:
  6073.         return;
  6074.     }
  6075.     k = kid;                        /* remember this node*/
  6076.     if (kBINOP->op_first->op_type != OP_RV2SV)
  6077.     return;
  6078.     kid = kBINOP->op_first;                /* get past cmp */
  6079.     if (kUNOP->op_first->op_type != OP_GV)
  6080.     return;
  6081.     kid = kUNOP->op_first;                /* get past rv2sv */
  6082.     gv = kGVOP_gv;
  6083.     if (GvSTASH(gv) != PL_curstash)
  6084.     return;
  6085.     if (strEQ(GvNAME(gv), "a"))
  6086.     reversed = 0;
  6087.     else if (strEQ(GvNAME(gv), "b"))
  6088.     reversed = 1;
  6089.     else
  6090.     return;
  6091.     kid = k;                        /* back to cmp */
  6092.     if (kBINOP->op_last->op_type != OP_RV2SV)
  6093.     return;
  6094.     kid = kBINOP->op_last;                /* down to 2nd arg */
  6095.     if (kUNOP->op_first->op_type != OP_GV)
  6096.     return;
  6097.     kid = kUNOP->op_first;                /* get past rv2sv */
  6098.     gv = kGVOP_gv;
  6099.     if (GvSTASH(gv) != PL_curstash
  6100.     || ( reversed
  6101.         ? strNE(GvNAME(gv), "a")
  6102.         : strNE(GvNAME(gv), "b")))
  6103.     return;
  6104.     o->op_flags &= ~(OPf_STACKED | OPf_SPECIAL);
  6105.     if (reversed)
  6106.     o->op_private |= OPpSORT_REVERSE;
  6107.     if (k->op_type == OP_NCMP)
  6108.     o->op_private |= OPpSORT_NUMERIC;
  6109.     if (k->op_type == OP_I_NCMP)
  6110.     o->op_private |= OPpSORT_NUMERIC | OPpSORT_INTEGER;
  6111.     kid = cLISTOPo->op_first->op_sibling;
  6112.     cLISTOPo->op_first->op_sibling = kid->op_sibling; /* bypass old block */
  6113.     op_free(kid);                      /* then delete it */
  6114.     cLISTOPo->op_children--;
  6115. }
  6116.  
  6117. OP *
  6118. Perl_ck_split(pTHX_ OP *o)
  6119. {
  6120.     register OP *kid;
  6121.  
  6122.     if (o->op_flags & OPf_STACKED)
  6123.     return no_fh_allowed(o);
  6124.  
  6125.     kid = cLISTOPo->op_first;
  6126.     if (kid->op_type != OP_NULL)
  6127.     Perl_croak(aTHX_ "panic: ck_split");
  6128.     kid = kid->op_sibling;
  6129.     op_free(cLISTOPo->op_first);
  6130.     cLISTOPo->op_first = kid;
  6131.     if (!kid) {
  6132.     cLISTOPo->op_first = kid = newSVOP(OP_CONST, 0, newSVpvn(" ", 1));
  6133.     cLISTOPo->op_last = kid; /* There was only one element previously */
  6134.     }
  6135.  
  6136.     if (kid->op_type != OP_MATCH) {
  6137.     OP *sibl = kid->op_sibling;
  6138.     kid->op_sibling = 0;
  6139.     kid = pmruntime( newPMOP(OP_MATCH, OPf_SPECIAL), kid, Nullop);
  6140.     if (cLISTOPo->op_first == cLISTOPo->op_last)
  6141.         cLISTOPo->op_last = kid;
  6142.     cLISTOPo->op_first = kid;
  6143.     kid->op_sibling = sibl;
  6144.     }
  6145.  
  6146.     kid->op_type = OP_PUSHRE;
  6147.     kid->op_ppaddr = PL_ppaddr[OP_PUSHRE];
  6148.     scalar(kid);
  6149.  
  6150.     if (!kid->op_sibling)
  6151.     append_elem(OP_SPLIT, o, newDEFSVOP());
  6152.  
  6153.     kid = kid->op_sibling;
  6154.     scalar(kid);
  6155.  
  6156.     if (!kid->op_sibling)
  6157.     append_elem(OP_SPLIT, o, newSVOP(OP_CONST, 0, newSViv(0)));
  6158.  
  6159.     kid = kid->op_sibling;
  6160.     scalar(kid);
  6161.  
  6162.     if (kid->op_sibling)
  6163.     return too_many_arguments(o,PL_op_desc[o->op_type]);
  6164.  
  6165.     return o;
  6166. }
  6167.  
  6168. OP *
  6169. Perl_ck_join(pTHX_ OP *o) 
  6170. {
  6171.     if (ckWARN(WARN_SYNTAX)) {
  6172.     OP *kid = cLISTOPo->op_first->op_sibling;
  6173.     if (kid && kid->op_type == OP_MATCH) {
  6174.         char *pmstr = "STRING";
  6175.         if (kPMOP->op_pmregexp)
  6176.         pmstr = kPMOP->op_pmregexp->precomp;
  6177.         Perl_warner(aTHX_ WARN_SYNTAX,
  6178.             "/%s/ should probably be written as \"%s\"",
  6179.             pmstr, pmstr);
  6180.     }
  6181.     }
  6182.     return ck_fun(o);
  6183. }
  6184.  
  6185. OP *
  6186. Perl_ck_subr(pTHX_ OP *o)
  6187. {
  6188.     dTHR;
  6189.     OP *prev = ((cUNOPo->op_first->op_sibling)
  6190.          ? cUNOPo : ((UNOP*)cUNOPo->op_first))->op_first;
  6191.     OP *o2 = prev->op_sibling;
  6192.     OP *cvop;
  6193.     char *proto = 0;
  6194.     CV *cv = 0;
  6195.     GV *namegv = 0;
  6196.     int optional = 0;
  6197.     I32 arg = 0;
  6198.     STRLEN n_a;
  6199.  
  6200.     o->op_private |= OPpENTERSUB_HASTARG;
  6201.     for (cvop = o2; cvop->op_sibling; cvop = cvop->op_sibling) ;
  6202.     if (cvop->op_type == OP_RV2CV) {
  6203.     SVOP* tmpop;
  6204.     o->op_private |= (cvop->op_private & OPpENTERSUB_AMPER);
  6205.     null(cvop);        /* disable rv2cv */
  6206.     tmpop = (SVOP*)((UNOP*)cvop)->op_first;
  6207.     if (tmpop->op_type == OP_GV && !(o->op_private & OPpENTERSUB_AMPER)) {
  6208.         GV *gv = cGVOPx_gv(tmpop);
  6209.         cv = GvCVu(gv);
  6210.         if (!cv)
  6211.         tmpop->op_private |= OPpEARLY_CV;
  6212.         else if (SvPOK(cv)) {
  6213.         namegv = CvANON(cv) ? gv : CvGV(cv);
  6214.         proto = SvPV((SV*)cv, n_a);
  6215.         }
  6216.     }
  6217.     }
  6218.     else if (cvop->op_type == OP_METHOD || cvop->op_type == OP_METHOD_NAMED) {
  6219.     if (o2->op_type == OP_CONST)
  6220.         o2->op_private &= ~OPpCONST_STRICT;
  6221.     else if (o2->op_type == OP_LIST) {
  6222.         OP *o = ((UNOP*)o2)->op_first->op_sibling;
  6223.         if (o && o->op_type == OP_CONST)
  6224.         o->op_private &= ~OPpCONST_STRICT;
  6225.     }
  6226.     }
  6227.     o->op_private |= (PL_hints & HINT_STRICT_REFS);
  6228.     if (PERLDB_SUB && PL_curstash != PL_debstash)
  6229.     o->op_private |= OPpENTERSUB_DB;
  6230.     while (o2 != cvop) {
  6231.     if (proto) {
  6232.         switch (*proto) {
  6233.         case '\0':
  6234.         return too_many_arguments(o, gv_ename(namegv));
  6235.         case ';':
  6236.         optional = 1;
  6237.         proto++;
  6238.         continue;
  6239.         case '$':
  6240.         proto++;
  6241.         arg++;
  6242.         scalar(o2);
  6243.         break;
  6244.         case '%':
  6245.         case '@':
  6246.         list(o2);
  6247.         arg++;
  6248.         break;
  6249.         case '&':
  6250.         proto++;
  6251.         arg++;
  6252.         if (o2->op_type != OP_REFGEN && o2->op_type != OP_UNDEF)
  6253.             bad_type(arg, "block", gv_ename(namegv), o2);
  6254.         break;
  6255.         case '*':
  6256.         /* '*' allows any scalar type, including bareword */
  6257.         proto++;
  6258.         arg++;
  6259.         if (o2->op_type == OP_RV2GV)
  6260.             goto wrapref;    /* autoconvert GLOB -> GLOBref */
  6261.         else if (o2->op_type == OP_CONST)
  6262.             o2->op_private &= ~OPpCONST_STRICT;
  6263.         else if (o2->op_type == OP_ENTERSUB) {
  6264.             /* accidental subroutine, revert to bareword */
  6265.             OP *gvop = ((UNOP*)o2)->op_first;
  6266.             if (gvop && gvop->op_type == OP_NULL) {
  6267.             gvop = ((UNOP*)gvop)->op_first;
  6268.             if (gvop) {
  6269.                 for (; gvop->op_sibling; gvop = gvop->op_sibling)
  6270.                 ;
  6271.                 if (gvop &&
  6272.                 (gvop->op_private & OPpENTERSUB_NOPAREN) &&
  6273.                 (gvop = ((UNOP*)gvop)->op_first) &&
  6274.                 gvop->op_type == OP_GV)
  6275.                 {
  6276.                 GV *gv = cGVOPx_gv(gvop);
  6277.                 OP *sibling = o2->op_sibling;
  6278.                 SV *n = newSVpvn("",0);
  6279.                 op_free(o2);
  6280.                 gv_fullname3(n, gv, "");
  6281.                 if (SvCUR(n)>6 && strnEQ(SvPVX(n),"main::",6))
  6282.                     sv_chop(n, SvPVX(n)+6);
  6283.                 o2 = newSVOP(OP_CONST, 0, n);
  6284.                 prev->op_sibling = o2;
  6285.                 o2->op_sibling = sibling;
  6286.                 }
  6287.             }
  6288.             }
  6289.         }
  6290.         scalar(o2);
  6291.         break;
  6292.         case '\\':
  6293.         proto++;
  6294.         arg++;
  6295.         switch (*proto++) {
  6296.         case '*':
  6297.             if (o2->op_type != OP_RV2GV)
  6298.             bad_type(arg, "symbol", gv_ename(namegv), o2);
  6299.             goto wrapref;
  6300.         case '&':
  6301.             if (o2->op_type != OP_RV2CV)
  6302.             bad_type(arg, "sub", gv_ename(namegv), o2);
  6303.             goto wrapref;
  6304.         case '$':
  6305.             if (o2->op_type != OP_RV2SV
  6306.             && o2->op_type != OP_PADSV
  6307.             && o2->op_type != OP_HELEM
  6308.             && o2->op_type != OP_AELEM
  6309.             && o2->op_type != OP_THREADSV)
  6310.             {
  6311.             bad_type(arg, "scalar", gv_ename(namegv), o2);
  6312.             }
  6313.             goto wrapref;
  6314.         case '@':
  6315.             if (o2->op_type != OP_RV2AV && o2->op_type != OP_PADAV)
  6316.             bad_type(arg, "array", gv_ename(namegv), o2);
  6317.             goto wrapref;
  6318.         case '%':
  6319.             if (o2->op_type != OP_RV2HV && o2->op_type != OP_PADHV)
  6320.             bad_type(arg, "hash", gv_ename(namegv), o2);
  6321.           wrapref:
  6322.             {
  6323.             OP* kid = o2;
  6324.             OP* sib = kid->op_sibling;
  6325.             kid->op_sibling = 0;
  6326.             o2 = newUNOP(OP_REFGEN, 0, kid);
  6327.             o2->op_sibling = sib;
  6328.             prev->op_sibling = o2;
  6329.             }
  6330.             break;
  6331.         default: goto oops;
  6332.         }
  6333.         break;
  6334.         case ' ':
  6335.         proto++;
  6336.         continue;
  6337.         default:
  6338.           oops:
  6339.         Perl_croak(aTHX_ "Malformed prototype for %s: %s",
  6340.             gv_ename(namegv), SvPV((SV*)cv, n_a));
  6341.         }
  6342.     }
  6343.     else
  6344.         list(o2);
  6345.     mod(o2, OP_ENTERSUB);
  6346.     prev = o2;
  6347.     o2 = o2->op_sibling;
  6348.     }
  6349.     if (proto && !optional &&
  6350.       (*proto && *proto != '@' && *proto != '%' && *proto != ';'))
  6351.     return too_few_arguments(o, gv_ename(namegv));
  6352.     return o;
  6353. }
  6354.  
  6355. OP *
  6356. Perl_ck_svconst(pTHX_ OP *o)
  6357. {
  6358.     SvREADONLY_on(cSVOPo->op_sv);
  6359.     return o;
  6360. }
  6361.  
  6362. OP *
  6363. Perl_ck_trunc(pTHX_ OP *o)
  6364. {
  6365.     if (o->op_flags & OPf_KIDS) {
  6366.     SVOP *kid = (SVOP*)cUNOPo->op_first;
  6367.  
  6368.     if (kid->op_type == OP_NULL)
  6369.         kid = (SVOP*)kid->op_sibling;
  6370.     if (kid && kid->op_type == OP_CONST &&
  6371.         (kid->op_private & OPpCONST_BARE))
  6372.     {
  6373.         o->op_flags |= OPf_SPECIAL;
  6374.         kid->op_private &= ~OPpCONST_STRICT;
  6375.     }
  6376.     }
  6377.     return ck_fun(o);
  6378. }
  6379.  
  6380. /* A peephole optimizer.  We visit the ops in the order they're to execute. */
  6381.  
  6382. void
  6383. Perl_peep(pTHX_ register OP *o)
  6384. {
  6385.     dTHR;
  6386.     register OP* oldop = 0;
  6387.     STRLEN n_a;
  6388.     OP *last_composite = Nullop;
  6389.  
  6390.     if (!o || o->op_seq)
  6391.     return;
  6392.     ENTER;
  6393.     SAVEOP();
  6394.     SAVEVPTR(PL_curcop);
  6395.     for (; o; o = o->op_next) {
  6396.     if (o->op_seq)
  6397.         break;
  6398.     if (!PL_op_seqmax)
  6399.         PL_op_seqmax++;
  6400.     PL_op = o;
  6401.     switch (o->op_type) {
  6402.     case OP_SETSTATE:
  6403.     case OP_NEXTSTATE:
  6404.     case OP_DBSTATE:
  6405.         PL_curcop = ((COP*)o);        /* for warnings */
  6406.         o->op_seq = PL_op_seqmax++;
  6407.         last_composite = Nullop;
  6408.         break;
  6409.  
  6410.     case OP_CONST:
  6411.         if (cSVOPo->op_private & OPpCONST_STRICT)
  6412.         no_bareword_allowed(o);
  6413. #ifdef USE_ITHREADS
  6414.         /* Relocate sv to the pad for thread safety.
  6415.          * Despite being a "constant", the SV is written to,
  6416.          * for reference counts, sv_upgrade() etc. */
  6417.         if (cSVOP->op_sv) {
  6418.         PADOFFSET ix = pad_alloc(OP_CONST, SVs_PADTMP);
  6419.         SvREFCNT_dec(PL_curpad[ix]);
  6420.         SvPADTMP_on(cSVOPo->op_sv);
  6421.         PL_curpad[ix] = cSVOPo->op_sv;
  6422.         cSVOPo->op_sv = Nullsv;
  6423.         o->op_targ = ix;
  6424.         }
  6425. #endif
  6426.         o->op_seq = PL_op_seqmax++;
  6427.         break;
  6428.  
  6429.     case OP_CONCAT:
  6430.         if (o->op_next && o->op_next->op_type == OP_STRINGIFY) {
  6431.         if (o->op_next->op_private & OPpTARGET_MY) {
  6432.             if (o->op_flags & OPf_STACKED) /* chained concats */
  6433.             goto ignore_optimization;
  6434.             else {
  6435.             /* assert(PL_opargs[o->op_type] & OA_TARGLEX); */
  6436.             o->op_targ = o->op_next->op_targ;
  6437.             o->op_next->op_targ = 0;
  6438.             o->op_private |= OPpTARGET_MY;
  6439.             }
  6440.         }
  6441.         null(o->op_next);
  6442.         }
  6443.       ignore_optimization:
  6444.         o->op_seq = PL_op_seqmax++;
  6445.         break;
  6446.     case OP_STUB:
  6447.         if ((o->op_flags & OPf_WANT) != OPf_WANT_LIST) {
  6448.         o->op_seq = PL_op_seqmax++;
  6449.         break; /* Scalar stub must produce undef.  List stub is noop */
  6450.         }
  6451.         goto nothin;
  6452.     case OP_NULL:
  6453.         if (o->op_targ == OP_NEXTSTATE
  6454.         || o->op_targ == OP_DBSTATE
  6455.         || o->op_targ == OP_SETSTATE)
  6456.         {
  6457.         PL_curcop = ((COP*)o);
  6458.         }
  6459.         goto nothin;
  6460.     case OP_SCALAR:
  6461.     case OP_LINESEQ:
  6462.     case OP_SCOPE:
  6463.       nothin:
  6464.         if (oldop && o->op_next) {
  6465.         oldop->op_next = o->op_next;
  6466.         continue;
  6467.         }
  6468.         o->op_seq = PL_op_seqmax++;
  6469.         break;
  6470.  
  6471.     case OP_GV:
  6472.         if (o->op_next->op_type == OP_RV2SV) {
  6473.         if (!(o->op_next->op_private & OPpDEREF)) {
  6474.             null(o->op_next);
  6475.             o->op_private |= o->op_next->op_private & (OPpLVAL_INTRO
  6476.                                    | OPpOUR_INTRO);
  6477.             o->op_next = o->op_next->op_next;
  6478.             o->op_type = OP_GVSV;
  6479.             o->op_ppaddr = PL_ppaddr[OP_GVSV];
  6480.         }
  6481.         }
  6482.         else if (o->op_next->op_type == OP_RV2AV) {
  6483.         OP* pop = o->op_next->op_next;
  6484.         IV i;
  6485.         if (pop->op_type == OP_CONST &&
  6486.             (PL_op = pop->op_next) &&
  6487.             pop->op_next->op_type == OP_AELEM &&
  6488.             !(pop->op_next->op_private &
  6489.               (OPpLVAL_INTRO|OPpLVAL_DEFER|OPpDEREF)) &&
  6490.             (i = SvIV(((SVOP*)pop)->op_sv) - PL_compiling.cop_arybase)
  6491.                 <= 255 &&
  6492.             i >= 0)
  6493.         {
  6494.             GV *gv;
  6495.             null(o->op_next);
  6496.             null(pop->op_next);
  6497.             null(pop);
  6498.             o->op_flags |= pop->op_next->op_flags & OPf_MOD;
  6499.             o->op_next = pop->op_next->op_next;
  6500.             o->op_type = OP_AELEMFAST;
  6501.             o->op_ppaddr = PL_ppaddr[OP_AELEMFAST];
  6502.             o->op_private = (U8)i;
  6503.             gv = cGVOPo_gv;
  6504.             GvAVn(gv);
  6505.         }
  6506.         }
  6507.         else if ((o->op_private & OPpEARLY_CV) && ckWARN(WARN_PROTOTYPE)) {
  6508.         GV *gv = cGVOPo_gv;
  6509.         if (SvTYPE(gv) == SVt_PVGV && GvCV(gv) && SvPVX(GvCV(gv))) {
  6510.             /* XXX could check prototype here instead of just carping */
  6511.             SV *sv = sv_newmortal();
  6512.             gv_efullname3(sv, gv, Nullch);
  6513.             Perl_warner(aTHX_ WARN_PROTOTYPE,
  6514.                 "%s() called too early to check prototype",
  6515.                 SvPV_nolen(sv));
  6516.         }
  6517.         }
  6518.  
  6519.         o->op_seq = PL_op_seqmax++;
  6520.         break;
  6521.  
  6522.     case OP_MAPWHILE:
  6523.     case OP_GREPWHILE:
  6524.     case OP_AND:
  6525.     case OP_OR:
  6526.     case OP_ANDASSIGN:
  6527.     case OP_ORASSIGN:
  6528.     case OP_COND_EXPR:
  6529.     case OP_RANGE:
  6530.         o->op_seq = PL_op_seqmax++;
  6531.         while (cLOGOP->op_other->op_type == OP_NULL)
  6532.         cLOGOP->op_other = cLOGOP->op_other->op_next;
  6533.         peep(cLOGOP->op_other);
  6534.         break;
  6535.  
  6536.     case OP_ENTERLOOP:
  6537.         o->op_seq = PL_op_seqmax++;
  6538.         peep(cLOOP->op_redoop);
  6539.         peep(cLOOP->op_nextop);
  6540.         peep(cLOOP->op_lastop);
  6541.         break;
  6542.  
  6543.     case OP_QR:
  6544.     case OP_MATCH:
  6545.     case OP_SUBST:
  6546.         o->op_seq = PL_op_seqmax++;
  6547.         peep(cPMOP->op_pmreplstart);
  6548.         break;
  6549.  
  6550.     case OP_EXEC:
  6551.         o->op_seq = PL_op_seqmax++;
  6552.         if (ckWARN(WARN_SYNTAX) && o->op_next 
  6553.         && o->op_next->op_type == OP_NEXTSTATE) {
  6554.         if (o->op_next->op_sibling &&
  6555.             o->op_next->op_sibling->op_type != OP_EXIT &&
  6556.             o->op_next->op_sibling->op_type != OP_WARN &&
  6557.             o->op_next->op_sibling->op_type != OP_DIE) {
  6558.             line_t oldline = CopLINE(PL_curcop);
  6559.  
  6560.             CopLINE_set(PL_curcop, CopLINE((COP*)o->op_next));
  6561.             Perl_warner(aTHX_ WARN_EXEC,
  6562.                 "Statement unlikely to be reached");
  6563.             Perl_warner(aTHX_ WARN_EXEC,
  6564.                 "\t(Maybe you meant system() when you said exec()?)\n");
  6565.             CopLINE_set(PL_curcop, oldline);
  6566.         }
  6567.         }
  6568.         break;
  6569.     
  6570.     case OP_HELEM: {
  6571.         UNOP *rop;
  6572.         SV *lexname;
  6573.         GV **fields;
  6574.         SV **svp, **indsvp, *sv;
  6575.         I32 ind;
  6576.         char *key;
  6577.         STRLEN keylen;
  6578.     
  6579.         o->op_seq = PL_op_seqmax++;
  6580.         if ((o->op_private & (OPpLVAL_INTRO))
  6581.         || ((BINOP*)o)->op_last->op_type != OP_CONST)
  6582.         break;
  6583.         rop = (UNOP*)((BINOP*)o)->op_first;
  6584.         if (rop->op_type != OP_RV2HV || rop->op_first->op_type != OP_PADSV)
  6585.         break;
  6586.         lexname = *av_fetch(PL_comppad_name, rop->op_first->op_targ, TRUE);
  6587.         if (!SvOBJECT(lexname))
  6588.         break;
  6589.         fields = (GV**)hv_fetch(SvSTASH(lexname), "FIELDS", 6, FALSE);
  6590.         if (!fields || !GvHV(*fields))
  6591.         break;
  6592.         svp = cSVOPx_svp(((BINOP*)o)->op_last);
  6593.         key = SvPV(*svp, keylen);
  6594.         indsvp = hv_fetch(GvHV(*fields), key, keylen, FALSE);
  6595.         if (!indsvp) {
  6596.         Perl_croak(aTHX_ "No such pseudo-hash field \"%s\" in variable %s of type %s",
  6597.               key, SvPV(lexname, n_a), HvNAME(SvSTASH(lexname)));
  6598.         }
  6599.         ind = SvIV(*indsvp);
  6600.         if (ind < 1)
  6601.         Perl_croak(aTHX_ "Bad index while coercing array into hash");
  6602.         rop->op_type = OP_RV2AV;
  6603.         rop->op_ppaddr = PL_ppaddr[OP_RV2AV];
  6604.         o->op_type = OP_AELEM;
  6605.         o->op_ppaddr = PL_ppaddr[OP_AELEM];
  6606.         sv = newSViv(ind);
  6607.         if (SvREADONLY(*svp))
  6608.         SvREADONLY_on(sv);
  6609.         SvFLAGS(sv) |= (SvFLAGS(*svp)
  6610.                 & (SVs_PADBUSY|SVs_PADTMP|SVs_PADMY));
  6611.         SvREFCNT_dec(*svp);
  6612.         *svp = sv;
  6613.         break;
  6614.     }
  6615.     
  6616.     case OP_HSLICE: {
  6617.         UNOP *rop;
  6618.         SV *lexname;
  6619.         GV **fields;
  6620.         SV **svp, **indsvp, *sv;
  6621.         I32 ind;
  6622.         char *key;
  6623.         STRLEN keylen;
  6624.         SVOP *first_key_op, *key_op;
  6625.  
  6626.         o->op_seq = PL_op_seqmax++;
  6627.         if ((o->op_private & (OPpLVAL_INTRO))
  6628.         /* I bet there's always a pushmark... */
  6629.         || ((LISTOP*)o)->op_first->op_sibling->op_type != OP_LIST)
  6630.         /* hmmm, no optimization if list contains only one key. */
  6631.         break;
  6632.         rop = (UNOP*)((LISTOP*)o)->op_last;
  6633.         if (rop->op_type != OP_RV2HV || rop->op_first->op_type != OP_PADSV)
  6634.         break;
  6635.         lexname = *av_fetch(PL_comppad_name, rop->op_first->op_targ, TRUE);
  6636.         if (!SvOBJECT(lexname))
  6637.         break;
  6638.         fields = (GV**)hv_fetch(SvSTASH(lexname), "FIELDS", 6, FALSE);
  6639.         if (!fields || !GvHV(*fields))
  6640.         break;
  6641.         /* Again guessing that the pushmark can be jumped over.... */
  6642.         first_key_op = (SVOP*)((LISTOP*)((LISTOP*)o)->op_first->op_sibling)
  6643.         ->op_first->op_sibling;
  6644.         /* Check that the key list contains only constants. */
  6645.         for (key_op = first_key_op; key_op;
  6646.          key_op = (SVOP*)key_op->op_sibling)
  6647.         if (key_op->op_type != OP_CONST)
  6648.             break;
  6649.         if (key_op)
  6650.         break;
  6651.         rop->op_type = OP_RV2AV;
  6652.         rop->op_ppaddr = PL_ppaddr[OP_RV2AV];
  6653.         o->op_type = OP_ASLICE;
  6654.         o->op_ppaddr = PL_ppaddr[OP_ASLICE];
  6655.         for (key_op = first_key_op; key_op;
  6656.          key_op = (SVOP*)key_op->op_sibling) {
  6657.         svp = cSVOPx_svp(key_op);
  6658.         key = SvPV(*svp, keylen);
  6659.         indsvp = hv_fetch(GvHV(*fields), key, keylen, FALSE);
  6660.         if (!indsvp) {
  6661.             Perl_croak(aTHX_ "No such pseudo-hash field \"%s\" "
  6662.                    "in variable %s of type %s",
  6663.               key, SvPV(lexname, n_a), HvNAME(SvSTASH(lexname)));
  6664.         }
  6665.         ind = SvIV(*indsvp);
  6666.         if (ind < 1)
  6667.             Perl_croak(aTHX_ "Bad index while coercing array into hash");
  6668.         sv = newSViv(ind);
  6669.         if (SvREADONLY(*svp))
  6670.             SvREADONLY_on(sv);
  6671.         SvFLAGS(sv) |= (SvFLAGS(*svp)
  6672.                 & (SVs_PADBUSY|SVs_PADTMP|SVs_PADMY));
  6673.         SvREFCNT_dec(*svp);
  6674.         *svp = sv;
  6675.         }
  6676.         break;
  6677.     }
  6678.  
  6679.     case OP_RV2AV:
  6680.     case OP_RV2HV:
  6681.         if (!(o->op_flags & OPf_WANT)
  6682.         || (o->op_flags & OPf_WANT) == OPf_WANT_LIST)
  6683.         {
  6684.         last_composite = o;
  6685.         }
  6686.         o->op_seq = PL_op_seqmax++;
  6687.         break;
  6688.  
  6689.     case OP_RETURN:
  6690.         if (o->op_next && o->op_next->op_type != OP_LEAVESUBLV) {
  6691.         o->op_seq = PL_op_seqmax++;
  6692.         break;
  6693.         }
  6694.         /* FALL THROUGH */
  6695.  
  6696.     case OP_LEAVESUBLV:
  6697.         if (last_composite) {
  6698.         OP *r = last_composite;
  6699.  
  6700.         while (r->op_sibling)
  6701.            r = r->op_sibling;
  6702.         if (r->op_next == o 
  6703.             || (r->op_next->op_type == OP_LIST
  6704.             && r->op_next->op_next == o))
  6705.         {
  6706.             if (last_composite->op_type == OP_RV2AV)
  6707.             yyerror("Lvalue subs returning arrays not implemented yet");
  6708.             else
  6709.             yyerror("Lvalue subs returning hashes not implemented yet");
  6710.             ;
  6711.         }        
  6712.         }
  6713.         /* FALL THROUGH */
  6714.  
  6715.     default:
  6716.         o->op_seq = PL_op_seqmax++;
  6717.         break;
  6718.     }
  6719.     oldop = o;
  6720.     }
  6721.     LEAVE;
  6722. }
  6723.