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.
82 lines
1.9 KiB
PHP
82 lines
1.9 KiB
PHP
<?php declare(strict_types=1);
|
|
/*
|
|
* This file is part of sebastian/lines-of-code.
|
|
*
|
|
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
namespace SebastianBergmann\LinesOfCode;
|
|
|
|
use function array_merge;
|
|
use function array_unique;
|
|
use function count;
|
|
use PhpParser\Comment;
|
|
use PhpParser\Node;
|
|
use PhpParser\Node\Expr;
|
|
use PhpParser\NodeVisitorAbstract;
|
|
|
|
final class LineCountingVisitor extends NodeVisitorAbstract
|
|
{
|
|
/**
|
|
* @var int
|
|
*/
|
|
private $linesOfCode;
|
|
|
|
/**
|
|
* @var Comment[]
|
|
*/
|
|
private $comments = [];
|
|
|
|
/**
|
|
* @var int[]
|
|
*/
|
|
private $linesWithStatements = [];
|
|
|
|
public function __construct(int $linesOfCode)
|
|
{
|
|
$this->linesOfCode = $linesOfCode;
|
|
}
|
|
|
|
public function enterNode(Node $node): void
|
|
{
|
|
$this->comments = array_merge($this->comments, $node->getComments());
|
|
|
|
if (!$node instanceof Expr) {
|
|
return;
|
|
}
|
|
|
|
$this->linesWithStatements[] = $node->getStartLine();
|
|
}
|
|
|
|
public function result(): LinesOfCode
|
|
{
|
|
$commentLinesOfCode = 0;
|
|
|
|
foreach ($this->comments() as $comment) {
|
|
$commentLinesOfCode += ($comment->getEndLine() - $comment->getStartLine() + 1);
|
|
}
|
|
|
|
return new LinesOfCode(
|
|
$this->linesOfCode,
|
|
$commentLinesOfCode,
|
|
$this->linesOfCode - $commentLinesOfCode,
|
|
count(array_unique($this->linesWithStatements))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return Comment[]
|
|
*/
|
|
private function comments(): array
|
|
{
|
|
$comments = [];
|
|
|
|
foreach ($this->comments as $comment) {
|
|
$comments[$comment->getStartLine() . '_' . $comment->getStartTokenPos() . '_' . $comment->getEndLine() . '_' . $comment->getEndTokenPos()] = $comment;
|
|
}
|
|
|
|
return $comments;
|
|
}
|
|
}
|