regen config* stuff for windows
[p5sagit/p5-mst-13.2.git] / run.c
CommitLineData
a0d0e21e 1/* run.c
2 *
4eb8286e 3 * Copyright (c) 1991-1999, Larry Wall
a0d0e21e 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
79072805 10#include "EXTERN.h"
864dbfa3 11#define PERL_IN_RUN_C
79072805 12#include "perl.h"
13
a0d0e21e 14/*
15 * "Away now, Shadowfax! Run, greatheart, run as you have never run before!
16 * Now we are come to the lands where you were foaled, and every stone you
17 * know. Run now! Hope is in speed!" --Gandalf
18 */
19
a0d0e21e 20int
864dbfa3 21Perl_runops_standard(pTHX)
17c3b450 22{
11343788 23 dTHR;
a0d0e21e 24
fc0dc3b3 25 while ( PL_op = CALL_FPTR(PL_op->op_ppaddr)(aTHX) ) ;
fd18d308 26
27 TAINT_NOT;
a0d0e21e 28 return 0;
79072805 29}
30
a0d0e21e 31int
864dbfa3 32Perl_runops_debug(pTHX)
35ff7856 33{
34#ifdef DEBUGGING
11343788 35 dTHR;
f248d071 36 if (!PL_op) {
37 if (ckWARN_d(WARN_DEBUGGING))
38 Perl_warner(aTHX_ WARN_DEBUGGING, "NULL OP IN RUN");
a0d0e21e 39 return 0;
79072805 40 }
a0d0e21e 41
79072805 42 do {
3280af22 43 if (PL_debug) {
22c35a8c 44 if (PL_watchaddr != 0 && *PL_watchaddr != PL_watchok)
b900a521 45 PerlIO_printf(Perl_debug_log,
46 "WARNING: %"UVxf" changed from %"UVxf" to %"UVxf"\n",
47 PTR2UV(PL_watchaddr), PTR2UV(PL_watchok), (UV)*PL_watchaddr);
79072805 48 DEBUG_s(debstack());
533c011a 49 DEBUG_t(debop(PL_op));
50 DEBUG_P(debprof(PL_op));
79072805 51 }
fc0dc3b3 52 } while ( PL_op = CALL_FPTR(PL_op->op_ppaddr)(aTHX) );
fd18d308 53
54 TAINT_NOT;
a0d0e21e 55 return 0;
35ff7856 56#else
57 return runops_standard();
17c3b450 58#endif /* DEBUGGING */
79072805 59}
60
79072805 61I32
864dbfa3 62Perl_debop(pTHX_ OP *o)
79072805 63{
35ff7856 64#ifdef DEBUGGING
79072805 65 SV *sv;
2d8e6c8d 66 STRLEN n_a;
cea2e8a9 67 Perl_deb(aTHX_ "%s", PL_op_name[o->op_type]);
11343788 68 switch (o->op_type) {
79072805 69 case OP_CONST:
5dc0d613 70 PerlIO_printf(Perl_debug_log, "(%s)", SvPEEK(cSVOPo->op_sv));
79072805 71 break;
72 case OP_GVSV:
73 case OP_GV:
11343788 74 if (cGVOPo->op_gv) {
79072805 75 sv = NEWSV(0,0);
5dc0d613 76 gv_fullname3(sv, cGVOPo->op_gv, Nullch);
2d8e6c8d 77 PerlIO_printf(Perl_debug_log, "(%s)", SvPV(sv, n_a));
8990e307 78 SvREFCNT_dec(sv);
79072805 79 }
80 else
760ac839 81 PerlIO_printf(Perl_debug_log, "(NULL)");
79072805 82 break;
a0d0e21e 83 default:
84 break;
79072805 85 }
760ac839 86 PerlIO_printf(Perl_debug_log, "\n");
17c3b450 87#endif /* DEBUGGING */
79072805 88 return 0;
89}
90
91void
864dbfa3 92Perl_watch(pTHX_ char **addr)
79072805 93{
35ff7856 94#ifdef DEBUGGING
22c35a8c 95 dTHR;
96 PL_watchaddr = addr;
97 PL_watchok = *addr;
b900a521 98 PerlIO_printf(Perl_debug_log, "WATCHING, %"UVxf" is currently %"UVxf"\n",
99 PTR2UV(PL_watchaddr), PTR2UV(PL_watchok));
17c3b450 100#endif /* DEBUGGING */
79072805 101}
a0d0e21e 102
76e3520e 103STATIC void
cea2e8a9 104S_debprof(pTHX_ OP *o)
a0d0e21e 105{
35ff7856 106#ifdef DEBUGGING
3280af22 107 if (!PL_profiledata)
108 Newz(000, PL_profiledata, MAXO, U32);
109 ++PL_profiledata[o->op_type];
35ff7856 110#endif /* DEBUGGING */
a0d0e21e 111}
112
113void
864dbfa3 114Perl_debprofdump(pTHX)
a0d0e21e 115{
35ff7856 116#ifdef DEBUGGING
9607fc9c 117 unsigned i;
3280af22 118 if (!PL_profiledata)
a0d0e21e 119 return;
120 for (i = 0; i < MAXO; i++) {
3280af22 121 if (PL_profiledata[i])
9607fc9c 122 PerlIO_printf(Perl_debug_log,
3280af22 123 "%5lu %s\n", (unsigned long)PL_profiledata[i],
22c35a8c 124 PL_op_name[i]);
a0d0e21e 125 }
17c3b450 126#endif /* DEBUGGING */
35ff7856 127}