1 /* $RCSfile: op.c,v $$Revision: 4.1 $$Date: 92/08/07 17:19:16 $
3 * Copyright (c) 1991, Larry Wall
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.
9 * Revision 4.1 92/08/07 17:19:16 lwall
12 * Revision 4.0.1.5 92/06/08 12:00:39 lwall
13 * patch20: the switch optimizer didn't do anything in subroutines
14 * patch20: removed implicit int declarations on funcions
16 * Revision 4.0.1.4 91/11/11 16:29:33 lwall
17 * patch19: do {$foo ne "bar";} returned wrong value
18 * patch19: some earlier patches weren't propagated to alternate 286 code
20 * Revision 4.0.1.3 91/11/05 16:07:43 lwall
21 * patch11: random cleanup
22 * patch11: "foo\0" eq "foo" was sometimes optimized to true
23 * patch11: foreach on null list could spring memory leak
25 * Revision 4.0.1.2 91/06/07 10:26:45 lwall
26 * patch4: new copyright notice
27 * patch4: made some allowances for "semi-standard" C
29 * Revision 4.0.1.1 91/04/11 17:36:16 lwall
30 * patch1: you may now use "die" and "caller" in a signal handler
32 * Revision 4.0 91/03/20 01:04:18 lwall
48 void deb(pat,a1,a2,a3,a4,a5,a6,a7,a8)
53 fprintf(stderr,"%-4ld",(long)curop->cop_line);
54 for (i=0; i<dlevel; i++)
55 fprintf(stderr,"%c%c ",debname[i],debdelim[i]);
56 fprintf(stderr,pat,a1,a2,a3,a4,a5,a6,a7,a8);
61 void deb(char *pat,...)
72 fprintf(stderr,"%-4ld",(long)curcop->cop_line);
73 for (i=0; i<dlevel; i++)
74 fprintf(stderr,"%c%c ",debname[i],debdelim[i]);
76 pat = va_arg(args, char *);
77 (void) vfprintf(stderr,pat,args);
86 Renew(debname, dlmax, char);
87 Renew(debdelim, dlmax, char);
93 fprintf(stderr, "%8lx %8lx %8ld %8ld %8ld\n",
94 stack, stack_base, *markstack_ptr, stack_sp-stack_base, stack_max-stack_base);
95 fprintf(stderr, "%8lx %8lx %8ld %l8d %8ld\n",
96 mainstack, AvARRAY(stack), mainstack, AvFILL(stack), AvMAX(stack));
104 I32 markoff = markstack_ptr > markstack ? *markstack_ptr : -1;
106 fprintf(stderr, " =>");
107 if (stack_base[0] || stack_sp < stack_base)
108 fprintf(stderr, " [STACK UNDERFLOW!!!]\n");
109 for (i = 1; i <= 30; i++) {
110 if (stack_sp >= &stack_base[i])
112 fprintf(stderr, "\t%-4s%s%s", SvPEEK(stack_base[i]),
113 markoff == i ? " [" : "",
114 stack_sp == &stack_base[i] ?
115 (markoff == i ? "]" : " ]") : "");
118 fprintf(stderr, "\n");