summaryrefslogtreecommitdiff
path: root/pod/perlhack.pod
diff options
context:
space:
mode:
authorDave Mitchell <davem@fdisolutions.com>2006-05-23 22:16:28 +0000
committerDave Mitchell <davem@fdisolutions.com>2006-05-23 22:16:28 +0000
commited233832c7fe4d71f1f536650d0566b2e87ea46c (patch)
treeb0966fb565ae0ed2a5fa7323b9283176a6d28ea8 /pod/perlhack.pod
parent206f4df72938095bd90fa94ec6df5dde9dad5df1 (diff)
downloadperl-ed233832c7fe4d71f1f536650d0566b2e87ea46c.tar.gz
correct POPSTACK/POPMARK confusion in perlhack.pod
p4raw-id: //depot/perl@28292
Diffstat (limited to 'pod/perlhack.pod')
-rw-r--r--pod/perlhack.pod8
1 files changed, 4 insertions, 4 deletions
diff --git a/pod/perlhack.pod b/pod/perlhack.pod
index a976c77c84..df76d0f810 100644
--- a/pod/perlhack.pod
+++ b/pod/perlhack.pod
@@ -1344,8 +1344,8 @@ stack usable by each function. For instance, when dealing with a tied
variable, (internally, something with "P" magic) Perl has to call
methods for accesses to the tied variables. However, we need to separate
the arguments exposed to the method to the argument exposed to the
-original function - the store or fetch or whatever it may be. Here's how
-the tied C<push> is implemented; see C<av_push> in F<av.c>:
+original function - the store or fetch or whatever it may be. Here's
+roughly how the tied C<push> is implemented; see C<av_push> in F<av.c>:
1 PUSHMARK(SP);
2 EXTEND(SP,2);
@@ -1355,7 +1355,7 @@ the tied C<push> is implemented; see C<av_push> in F<av.c>:
6 ENTER;
7 call_method("PUSH", G_SCALAR|G_DISCARD);
8 LEAVE;
- 9 POPSTACK;
+ 9 (void)POPMARK;
The lines which concern the mark stack are the first, fifth and last
lines: they save away, restore and remove the current position of the
@@ -1397,7 +1397,7 @@ Perl space: C<call_method> takes care of that, and it's described in
L<perlcall>. We call the C<PUSH> method in scalar context, and we're
going to discard its return value.
- 9 POPSTACK;
+ 9 (void)POPMARK;
Finally, we remove the value we placed on the mark stack, since we
don't need it any more.