Updated Doxygen markup in several .php files triggering warnings when mwdocgen.php is executed. Removed obsolete settings MSCGEN_PATH and TCL_SUBST from Doxyfile. The former would generate a warning in 1.8.16 while TCL support was removed in 1.8.18. Since TCL_SUBST was blank anyway, it was removed prior to getting to .18 in production. Increased DOT_GRAPH_MAX_NODES from 50 to 200 since Doxygen complained about it being too low for API and Maintenance. Bug: T248706 Change-Id: I9c67f0807d1b43089d351263d4f591dee5501f36
96 lines
2 KiB
PHP
96 lines
2 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Rest\HeaderParser;
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
class HeaderParserBase {
|
|
/**
|
|
* @var string The input string being processed
|
|
*/
|
|
protected $input;
|
|
|
|
/**
|
|
* @var int The position within $input
|
|
*/
|
|
protected $pos;
|
|
|
|
/**
|
|
* @var int The length of $input
|
|
*/
|
|
protected $inputLength;
|
|
|
|
/**
|
|
* Set the input, and derived convenience properties
|
|
*
|
|
* @param string $input
|
|
*/
|
|
protected function setInput( $input ) {
|
|
$this->input = $input;
|
|
$this->pos = 0;
|
|
$this->inputLength = strlen( $input );
|
|
}
|
|
|
|
/**
|
|
* Consume a specified string, or throw an exception.
|
|
*
|
|
* @param string $s
|
|
* @throws HeaderParserError
|
|
*/
|
|
protected function consumeString( $s ) {
|
|
if ( $this->pos >= $this->inputLength ) {
|
|
$this->error( "Expected \"$s\" but got end of string" );
|
|
}
|
|
if ( substr_compare( $this->input, $s, $this->pos, strlen( $s ) ) === 0 ) {
|
|
$this->pos += strlen( $s );
|
|
} else {
|
|
$this->error( "Expected \"$s\"" );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Skip whitespace at the input position (OWS)
|
|
*/
|
|
protected function skipWhitespace() {
|
|
$this->pos += strspn( $this->input, " \t", $this->pos );
|
|
}
|
|
|
|
/**
|
|
* Throw an exception to indicate a parse error
|
|
*
|
|
* @param string $message
|
|
* @throws HeaderParserError
|
|
*/
|
|
protected function error( $message ) {
|
|
throw new HeaderParserError( "$message at {$this->pos}" );
|
|
}
|
|
|
|
/**
|
|
* Consume a specified number of digits, or throw an exception
|
|
*
|
|
* @param int $numDigits
|
|
* @return string
|
|
* @throws HeaderParserError
|
|
*/
|
|
protected function consumeFixedDigits( $numDigits ) {
|
|
$digits = substr( $this->input, $this->pos, $numDigits );
|
|
if ( strlen( $digits ) !== $numDigits || !preg_match( '/^[0-9]*$/', $digits ) ) {
|
|
$this->error( "expected $numDigits digits" );
|
|
}
|
|
$this->pos += $numDigits;
|
|
return $digits;
|
|
}
|
|
|
|
/**
|
|
* If the position is not at the end of the input string, raise an error,
|
|
* complaining of trailing characters.
|
|
*
|
|
* @throws HeaderParserError
|
|
*/
|
|
protected function assertEnd() {
|
|
if ( $this->pos !== $this->inputLength ) {
|
|
$this->error( "trailing characters" );
|
|
}
|
|
}
|
|
}
|