diff options
author | Tassilo von Parseval <tassilo.parseval@post.rwth-aachen.de> | 2003-12-06 12:50:59 +0100 |
---|---|---|
committer | Rafael Garcia-Suarez <rgarciasuarez@gmail.com> | 2003-12-06 19:50:07 +0000 |
commit | a3bcc51ebd4e201d85a37d8410b7a375b8d94244 (patch) | |
tree | 57797ca6128a5011622a6e805fb66f6d2a0fbaa5 /pod | |
parent | 5c98da1c029548d157089bc95672bf854902dd76 (diff) | |
download | perl-a3bcc51ebd4e201d85a37d8410b7a375b8d94244.tar.gz |
SCALAR/FIRSTKEY for tied hashes in scalar context
Message-id: <20031206105059.GA13989@ethan>
p4raw-id: //depot/perl@21855
Diffstat (limited to 'pod')
-rw-r--r-- | pod/perlapi.pod | 9 | ||||
-rw-r--r-- | pod/perlfunc.pod | 1 | ||||
-rw-r--r-- | pod/perltie.pod | 24 |
3 files changed, 33 insertions, 1 deletions
diff --git a/pod/perlapi.pod b/pod/perlapi.pod index 5532e63cd2..5a1bc57667 100644 --- a/pod/perlapi.pod +++ b/pod/perlapi.pod @@ -1280,6 +1280,15 @@ Adds magic to a hash. See C<sv_magic>. =for hackers Found in file hv.c +=item hv_scalar + +Evaluates the hash in scalar context and returns the result. Handles magic when the hash is tied. + + SV* hv_scalar(HV* hv) + +=for hackers +Found in file hv.c + =item hv_store Stores an SV in a hash. The hash key is specified as C<key> and C<klen> is diff --git a/pod/perlfunc.pod b/pod/perlfunc.pod index 2dbe74057c..7c69ff6028 100644 --- a/pod/perlfunc.pod +++ b/pod/perlfunc.pod @@ -5871,6 +5871,7 @@ A class implementing a hash should have the following methods: EXISTS this, key FIRSTKEY this NEXTKEY this, lastkey + SCALAR this DESTROY this UNTIE this diff --git a/pod/perltie.pod b/pod/perltie.pod index b81a51b464..468855c685 100644 --- a/pod/perltie.pod +++ b/pod/perltie.pod @@ -474,7 +474,8 @@ the constructor. FETCH and STORE access the key and value pairs. EXISTS reports whether a key is present in the hash, and DELETE deletes one. CLEAR empties the hash by deleting all the key and value pairs. FIRSTKEY and NEXTKEY implement the keys() and each() functions to iterate over all -the keys. UNTIE is called when C<untie> happens, and DESTROY is called when +the keys. SCALAR is triggered when the tied hash is evaluated in scalar +context. UNTIE is called when C<untie> happens, and DESTROY is called when the tied variable is garbage collected. If this seems like a lot, then feel free to inherit from merely the @@ -757,6 +758,25 @@ thing, but we'll have to go through the LIST field indirectly. return each %{ $self->{LIST} } } +=item SCALAR this + +This is called when the hash is evaluated in scalar context. In order +to mimic the behaviour of untied hashes, this method should return a +false value when the tied hash is considered empty. If this method does +not exist, perl will make some educated guesses and return false when +the hash is not inside an iteration. In this case, FIRSTKEY is called +and the result will be a false value if FIRSTKEY returns the empty list, +true otherwise. + +In our example we can just call C<scalar> on the underlying hash +referenced by C<$self-E<gt>{LIST}>: + + sub SCALAR { + carp &whowasi if $DEBUG; + my $self = shift; + return scalar %{ $self->{LIST} } + } + =item UNTIE this This is called when C<untie> occurs. See L<The C<untie> Gotcha> below. @@ -1107,4 +1127,6 @@ TIEHANDLE by Sven Verdoolaege <F<skimo@dns.ufsia.ac.be>> and Doug MacEachern <F< UNTIE by Nick Ing-Simmons <F<nick@ing-simmons.net>> +SCALAR by Tassilo von Parseval <F<tassilo.von.parseval@rwth-aachen.de>> + Tying Arrays by Casey West <F<casey@geeknest.com>> |