<?php
class CFlexibleIntervalParser extends CParser {
private $simple_interval_parser;
private $time_period_parser;
private $update_interval;
private $time_period;
private $options = [
'usermacros' => false,
'lldmacros' => false
];
public function __construct($options = []) {
if (array_key_exists('usermacros', $options)) {
$this->options['usermacros'] = $options['usermacros'];
}
if (array_key_exists('lldmacros', $options)) {
$this->options['lldmacros'] = $options['lldmacros'];
}
$this->simple_interval_parser = new CSimpleIntervalParser([
'usermacros' => $this->options['usermacros'],
'lldmacros' => $this->options['lldmacros']
]);
$this->time_period_parser = new CTimePeriodParser([
'usermacros' => $this->options['usermacros'],
'lldmacros' => $this->options['lldmacros']
]);
}
public function parse($source, $pos = 0) {
$this->length = 0;
$this->match = '';
$this->update_interval = '';
$this->time_period = '';
$p = $pos;
if ($this->simple_interval_parser->parse($source, $p) == self::PARSE_FAIL) {
return self::PARSE_FAIL;
}
$update_interval = $this->simple_interval_parser->getMatch();
$p += $this->simple_interval_parser->getLength();
if (!isset($source[$p]) || $source[$p] !== '/') {
return self::PARSE_FAIL;
}
$p++;
if ($this->time_period_parser->parse($source, $p) == self::PARSE_FAIL) {
return self::PARSE_FAIL;
}
$this->update_interval = $update_interval;
$this->time_period = $this->time_period_parser->getMatch();
$p += $this->time_period_parser->getLength();
$this->length = $p - $pos;
$this->match = substr($source, $pos, $this->length);
return isset($source[$p]) ? self::PARSE_SUCCESS_CONT : self::PARSE_SUCCESS;
}