=head1 NAME PPIx::Regexp::Structure::Code - Represent one of the code structures. =head1 SYNOPSIS use PPIx::Regexp::Dumper; PPIx::Regexp::Dumper->new( 'qr{(?{print "hello sailor\n")}smx' ) ->print(); =head1 INHERITANCE C is a L. C has no descendants. =head1 DESCRIPTION This class represents one of the code structures, either (?{ code }) or (??{ code }) =head1 METHODS This class provides no public methods beyond those provided by its superclass. =cut package PPIx::Regexp::Structure::Code; use strict; use warnings; use base qw{ PPIx::Regexp::Structure }; use PPIx::Regexp::Constant qw{ @CARP_NOT }; our $VERSION = '0.088'; # The only child of this structure should be a single # PPIx::Regexp::Token::Code. Anything else gets turned into the # appropriate ::Unknown object. sub __PPIX_LEXER__finalize { my ( $self ) = @_; # $lexer unused my $count; my $errors = 0; foreach my $kid ( $self->children() ) { if ( $kid->isa( 'PPIx::Regexp::Token::Code' ) ) { $count++ or next; $errors++; $kid->__error( 'Code structure can contain only one code token' ); } else { $errors++; $kid->__error( 'Code structure may not contain a ' . ref $kid ); } } return $errors; } 1; __END__ =head1 SUPPORT Support is by the author. Please file bug reports at L, L, or in electronic mail to the author. =head1 AUTHOR Thomas R. Wyant, III F =head1 COPYRIGHT AND LICENSE Copyright (C) 2009-2023 by Thomas R. Wyant, III This program is free software; you can redistribute it and/or modify it under the same terms as Perl 5.10.0. For more details, see the full text of the licenses in the directory LICENSES. 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. =cut # ex: set textwidth=72 :