<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">
require 5;
package Pod::Simple::PullParserStartToken;
use Pod::Simple::PullParserToken ();
use strict;
use vars qw(@ISA $VERSION);
@ISA = ('Pod::Simple::PullParserToken');
$VERSION = '3.35';

sub new {  # Class-&gt;new(tagname, optional_attrhash);
  my $class = shift;
  return bless ['start', @_], ref($class) || $class;
}

# Purely accessors:

sub tagname   { (@_ == 2) ? ($_[0][1] = $_[1]) : $_[0][1] }
sub tag { shift-&gt;tagname(@_) }

sub is_tagname { $_[0][1] eq $_[1] }
sub is_tag { shift-&gt;is_tagname(@_) }


sub attr_hash { $_[0][2] ||= {} }

sub attr      {
  if(@_ == 2) {      # Reading: $token-&gt;attr('attrname')
    ${$_[0][2] || return undef}{ $_[1] };
  } elsif(@_ &gt; 2) {  # Writing: $token-&gt;attr('attrname', 'newval')
    ${$_[0][2] ||= {}}{ $_[1] } = $_[2];
  } else {
    require Carp;
    Carp::croak(
      'usage: $object-&gt;attr("val") or $object-&gt;attr("key", "newval")');
    return undef;
  }
}

1;


__END__

=head1 NAME

Pod::Simple::PullParserStartToken -- start-tokens from Pod::Simple::PullParser

=head1 SYNOPSIS

(See L&lt;Pod::Simple::PullParser&gt;)

=head1 DESCRIPTION

When you do $parser-&gt;get_token on a L&lt;Pod::Simple::PullParser&gt; object, you might
get an object of this class.

This is a subclass of L&lt;Pod::Simple::PullParserToken&gt; and inherits all its methods,
and adds these methods:

=over

=item $token-&gt;tagname

This returns the tagname for this start-token object.
For example, parsing a "=head1 ..." line will give you
a start-token with the tagname of "head1", token(s) for its
content, and then an end-token with the tagname of "head1".

=item $token-&gt;tagname(I&lt;somestring&gt;)

This changes the tagname for this start-token object.
You probably won't need
to do this.

=item $token-&gt;tag(...)

A shortcut for $token-&gt;tagname(...)

=item $token-&gt;is_tag(I&lt;somestring&gt;) or $token-&gt;is_tagname(I&lt;somestring&gt;)

These are shortcuts for C&lt;&lt; $token-&gt;tag() eq I&lt;somestring&gt; &gt;&gt;

=item $token-&gt;attr(I&lt;attrname&gt;)

This returns the value of the I&lt;attrname&gt; attribute for this start-token
object, or undef.

For example, parsing a LZ&lt;&gt;&lt;Foo/"Bar"&gt; link will produce a start-token
with a "to" attribute with the value "Foo", a "type" attribute with the
value "pod", and a "section" attribute with the value "Bar".

=item $token-&gt;attr(I&lt;attrname&gt;, I&lt;newvalue&gt;)

This sets the I&lt;attrname&gt; attribute for this start-token object to
I&lt;newvalue&gt;.  You probably won't need to do this.

=item $token-&gt;attr_hash

This returns the hashref that is the attribute set for this start-token.
This is useful if (for example) you want to ask what all the attributes
are -- you can just do C&lt;&lt; keys %{$token-&gt;attr_hash} &gt;&gt;

=back


You're unlikely to ever need to construct an object of this class for
yourself, but if you want to, call
C&lt;&lt;
Pod::Simple::PullParserStartToken-&gt;new( I&lt;tagname&gt;, I&lt;attrhash&gt; )
&gt;&gt;

=head1 SEE ALSO

L&lt;Pod::Simple::PullParserToken&gt;, L&lt;Pod::Simple&gt;, L&lt;Pod::Simple::Subclassing&gt;

=head1 SEE ALSO

L&lt;Pod::Simple::PullParserToken&gt;, L&lt;Pod::Simple&gt;, L&lt;Pod::Simple::Subclassing&gt;

=head1 SUPPORT

Questions or discussion about POD and Pod::Simple should be sent to the
pod-people@perl.org mail list. Send an empty email to
pod-people-subscribe@perl.org to subscribe.

This module is managed in an open GitHub repository,
L&lt;https://github.com/perl-pod/pod-simple/&gt;. Feel free to fork and contribute, or
to clone L&lt;git://github.com/perl-pod/pod-simple.git&gt; and send patches!

Patches against Pod::Simple are welcome. Please send bug reports to
&lt;bug-pod-simple@rt.cpan.org&gt;.

=head1 COPYRIGHT AND DISCLAIMERS

Copyright (c) 2002 Sean M. Burke.

This library is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.

This program is distributed in the hope that it will be useful, but
without any warranty; without even the implied warranty of
merchantability or fitness for a particular purpose.

=head1 AUTHOR

Pod::Simple was created by Sean M. Burke &lt;sburke@cpan.org&gt;.
But don't bother him, he's retired.

Pod::Simple is maintained by:

=over

=item * Allison Randal C&lt;allison@perl.org&gt;

=item * Hans Dieter Pearcey C&lt;hdp@cpan.org&gt;

=item * David E. Wheeler C&lt;dwheeler@cpan.org&gt;

=back

=cut
</pre></body></html>