Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
5 / 5
CRAP
100.00% covered (success)
100.00%
41 / 41
AfterBody
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
5 / 5
9
100.00% covered (success)
100.00%
41 / 41
 characters
100.00% covered (success)
100.00%
1 / 1
2
100.00% covered (success)
100.00%
12 / 12
 startTag
100.00% covered (success)
100.00%
1 / 1
2
100.00% covered (success)
100.00%
11 / 11
 endTag
100.00% covered (success)
100.00%
1 / 1
3
100.00% covered (success)
100.00%
13 / 13
 endDocument
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
2 / 2
 comment
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
3 / 3
<?php
namespace RemexHtml\TreeBuilder;
use RemexHtml\Tokenizer\Attributes;
/**
 * The "after body" insertion mode
 */
class AfterBody extends InsertionMode {
    public function characters( $text, $start, $length, $sourceStart, $sourceLength ) {
        list( $part1, $part2 ) = $this->splitInitialMatch(
            true, "\t\n\f\r ", $text, $start, $length, $sourceStart, $sourceLength );
        list( $start, $length, $sourceStart, $sourceLength ) = $part1;
        if ( $length ) {
            $this->dispatcher->inBody->characters(
                $text, $start, $length, $sourceStart, $sourceLength );
        }
        list( $start, $length, $sourceStart, $sourceLength ) = $part2;
        $this->builder->error( "unexpected non-whitespace character after body",
            $sourceStart );
        $this->dispatcher->switchMode( Dispatcher::IN_BODY )
            ->characters( $text, $start, $length, $sourceStart, $sourceLength );
    }
    public function startTag( $name, Attributes $attrs, $selfClose, $sourceStart, $sourceLength ) {
        $builder = $this->builder;
        $dispatcher = $this->dispatcher;
        switch ( $name ) {
        case 'html':
            $dispatcher->inBody->startTag(
                $name, $attrs, $selfClose, $sourceStart, $sourceLength );
            break;
        default:
            $builder->error( "unexpected start tag after body", $sourceStart );
            $dispatcher->switchMode( Dispatcher::IN_BODY )
                ->startTag( $name, $attrs, $selfClose, $sourceStart, $sourceLength );
        }
    }
    public function endTag( $name, $sourceStart, $sourceLength ) {
        $builder = $this->builder;
        $dispatcher = $this->dispatcher;
        switch ( $name ) {
        case 'html':
            if ( $builder->isFragment ) {
                $builder->error( "unexpected </html> in fragment", $sourceStart );
                return;
            }
            $dispatcher->switchMode( Dispatcher::AFTER_AFTER_BODY );
            break;
        default:
            $builder->error( "unexpected end tag after body", $sourceStart );
            $dispatcher->switchMode( Dispatcher::IN_BODY )
                ->endTag( $name, $sourceStart, $sourceLength );
        }
    }
    public function endDocument( $pos ) {
        $this->builder->stopParsing( $pos );
    }
    public function comment( $text, $sourceStart, $sourceLength ) {
        $this->builder->comment( [ TreeBuilder::UNDER, $this->builder->stack->item( 0 ) ],
            $text, $sourceStart, $sourceLength );
    }
}