2016-12-17 17:52:36 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Abuse filter parser.
|
|
|
|
* Copyright © Victor Vasiliev, 2008.
|
|
|
|
* Based on ideas by Andrew Garrett
|
|
|
|
* Distributed under GNU GPL v2 terms.
|
|
|
|
*
|
|
|
|
* Types of token:
|
|
|
|
* * T_NONE - special-purpose token
|
|
|
|
* * T_BRACE - ( or )
|
|
|
|
* * T_COMMA - ,
|
|
|
|
* * T_OP - operator like + or ^
|
|
|
|
* * T_NUMBER - number
|
|
|
|
* * T_STRING - string, in "" or ''
|
|
|
|
* * T_KEYWORD - keyword
|
|
|
|
* * T_ID - identifier
|
|
|
|
* * T_STATEMENT_SEPARATOR - ;
|
|
|
|
* * T_SQUARE_BRACKETS - [ or ]
|
|
|
|
*
|
|
|
|
* Levels of parsing:
|
|
|
|
* * Entry - catches unexpected characters
|
|
|
|
* * Semicolon - ;
|
|
|
|
* * Set - :=
|
2018-06-30 18:35:49 +00:00
|
|
|
* * Conditionals (IF) - if-then-else-end, cond ? a :b
|
2016-12-17 17:52:36 +00:00
|
|
|
* * BoolOps (BO) - &, |, ^
|
|
|
|
* * CompOps (CO) - ==, !=, ===, !==, >, <, >=, <=
|
|
|
|
* * SumRel (SR) - +, -
|
|
|
|
* * MulRel (MR) - *, /, %
|
|
|
|
* * Pow (P) - **
|
|
|
|
* * BoolNeg (BN) - ! operation
|
|
|
|
* * SpecialOperators (SO) - in and like
|
|
|
|
* * Unarys (U) - plus and minus in cases like -5 or -(2 * +2)
|
2018-04-16 15:37:10 +00:00
|
|
|
* * ArrayElement (AE) - array[number]
|
2016-12-17 17:52:36 +00:00
|
|
|
* * Braces (B) - ( and )
|
|
|
|
* * Functions (F)
|
|
|
|
* * Atom (A) - return value
|
|
|
|
*/
|
|
|
|
class AFPToken {
|
|
|
|
const TNONE = 'T_NONE';
|
|
|
|
const TID = 'T_ID';
|
|
|
|
const TKEYWORD = 'T_KEYWORD';
|
|
|
|
const TSTRING = 'T_STRING';
|
|
|
|
const TINT = 'T_INT';
|
|
|
|
const TFLOAT = 'T_FLOAT';
|
|
|
|
const TOP = 'T_OP';
|
|
|
|
const TBRACE = 'T_BRACE';
|
|
|
|
const TSQUAREBRACKET = 'T_SQUARE_BRACKET';
|
|
|
|
const TCOMMA = 'T_COMMA';
|
|
|
|
const TSTATEMENTSEPARATOR = 'T_STATEMENT_SEPARATOR';
|
|
|
|
|
2018-11-08 14:34:32 +00:00
|
|
|
/**
|
|
|
|
* @var string One of the T* constant from this class
|
|
|
|
*/
|
2016-12-17 17:52:36 +00:00
|
|
|
public $type;
|
2018-11-08 14:34:32 +00:00
|
|
|
/**
|
|
|
|
* @var mixed|null The actual value of the token
|
|
|
|
*/
|
2016-12-17 17:52:36 +00:00
|
|
|
public $value;
|
2018-11-08 14:34:32 +00:00
|
|
|
/**
|
|
|
|
* @var int The code offset where this token is found
|
|
|
|
*/
|
2016-12-17 17:52:36 +00:00
|
|
|
public $pos;
|
|
|
|
|
2018-04-04 21:14:25 +00:00
|
|
|
/**
|
2018-04-29 17:52:45 +00:00
|
|
|
* @param string $type
|
2018-10-03 12:02:00 +00:00
|
|
|
* @param mixed|null $value
|
2018-04-04 21:14:25 +00:00
|
|
|
* @param int $pos
|
|
|
|
*/
|
2016-12-17 17:52:36 +00:00
|
|
|
public function __construct( $type = self::TNONE, $value = null, $pos = 0 ) {
|
|
|
|
$this->type = $type;
|
|
|
|
$this->value = $value;
|
|
|
|
$this->pos = $pos;
|
|
|
|
}
|
|
|
|
}
|