Implements automatic creation of required plugin pages (Community Login, Trainer Registration, Trainer Dashboard) upon plugin activation. This addresses E2E test failures caused by missing pages in the test environment. - Adds activation hook in `hvac-community-events.php` to call `hvac_ce_create_required_pages`. - The callback function checks for existing pages by slug and creates them using `wp_insert_post` if missing. Includes debug logging. Also fixes issues identified during E2E test debugging: - Corrects fatal error in `includes/community/class-login-handler.php` by replacing undefined constant `HVAC_COMMUNITY_EVENTS_PATH` with `HVAC_CE_PLUGIN_DIR`. - Updates `tests/e2e/tests/login.spec.ts` to use the correct selector `#wp-submit` for the login form submit button instead of `button[type="submit"]`. Documentation updates: - Adds `docs/automatic-page-creation-plan.md`. - Updates `README.md` regarding automatic page creation. - Updates Memory Bank files (`decisionLog.md`, `progress.md`, `activeContext.md`). Note: Activation hook logging did not appear during WP-CLI activation, requiring further investigation if page creation issues persist. E2E test confirmation pending.
93 lines
2.2 KiB
PHP
93 lines
2.2 KiB
PHP
<?php declare(strict_types = 1);
|
|
namespace TheSeer\Tokenizer;
|
|
|
|
class TokenCollection implements \ArrayAccess, \Iterator, \Countable {
|
|
|
|
/** @var Token[] */
|
|
private $tokens = [];
|
|
|
|
/** @var int */
|
|
private $pos;
|
|
|
|
public function addToken(Token $token): void {
|
|
$this->tokens[] = $token;
|
|
}
|
|
|
|
public function current(): Token {
|
|
return \current($this->tokens);
|
|
}
|
|
|
|
public function key(): int {
|
|
return \key($this->tokens);
|
|
}
|
|
|
|
public function next(): void {
|
|
\next($this->tokens);
|
|
$this->pos++;
|
|
}
|
|
|
|
public function valid(): bool {
|
|
return $this->count() > $this->pos;
|
|
}
|
|
|
|
public function rewind(): void {
|
|
\reset($this->tokens);
|
|
$this->pos = 0;
|
|
}
|
|
|
|
public function count(): int {
|
|
return \count($this->tokens);
|
|
}
|
|
|
|
public function offsetExists($offset): bool {
|
|
return isset($this->tokens[$offset]);
|
|
}
|
|
|
|
/**
|
|
* @throws TokenCollectionException
|
|
*/
|
|
public function offsetGet($offset): Token {
|
|
if (!$this->offsetExists($offset)) {
|
|
throw new TokenCollectionException(
|
|
\sprintf('No Token at offest %s', $offset)
|
|
);
|
|
}
|
|
|
|
return $this->tokens[$offset];
|
|
}
|
|
|
|
/**
|
|
* @param Token $value
|
|
*
|
|
* @throws TokenCollectionException
|
|
*/
|
|
public function offsetSet($offset, $value): void {
|
|
if (!\is_int($offset)) {
|
|
$type = \gettype($offset);
|
|
|
|
throw new TokenCollectionException(
|
|
\sprintf(
|
|
'Offset must be of type integer, %s given',
|
|
$type === 'object' ? \get_class($value) : $type
|
|
)
|
|
);
|
|
}
|
|
|
|
if (!$value instanceof Token) {
|
|
$type = \gettype($value);
|
|
|
|
throw new TokenCollectionException(
|
|
\sprintf(
|
|
'Value must be of type %s, %s given',
|
|
Token::class,
|
|
$type === 'object' ? \get_class($value) : $type
|
|
)
|
|
);
|
|
}
|
|
$this->tokens[$offset] = $value;
|
|
}
|
|
|
|
public function offsetUnset($offset): void {
|
|
unset($this->tokens[$offset]);
|
|
}
|
|
}
|