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.
110 lines
3 KiB
PHP
110 lines
3 KiB
PHP
<?php declare(strict_types=1);
|
|
/*
|
|
* This file is part of sebastian/diff.
|
|
*
|
|
* (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\Diff;
|
|
|
|
use function array_pop;
|
|
use function count;
|
|
use function max;
|
|
use function preg_match;
|
|
use function preg_split;
|
|
|
|
/**
|
|
* Unified diff parser.
|
|
*/
|
|
final class Parser
|
|
{
|
|
/**
|
|
* @return Diff[]
|
|
*/
|
|
public function parse(string $string): array
|
|
{
|
|
$lines = preg_split('(\r\n|\r|\n)', $string);
|
|
|
|
if (!empty($lines) && $lines[count($lines) - 1] === '') {
|
|
array_pop($lines);
|
|
}
|
|
|
|
$lineCount = count($lines);
|
|
$diffs = [];
|
|
$diff = null;
|
|
$collected = [];
|
|
|
|
for ($i = 0; $i < $lineCount; ++$i) {
|
|
if (preg_match('#^---\h+"?(?P<file>[^\\v\\t"]+)#', $lines[$i], $fromMatch) &&
|
|
preg_match('#^\\+\\+\\+\\h+"?(?P<file>[^\\v\\t"]+)#', $lines[$i + 1], $toMatch)) {
|
|
if ($diff !== null) {
|
|
$this->parseFileDiff($diff, $collected);
|
|
|
|
$diffs[] = $diff;
|
|
$collected = [];
|
|
}
|
|
|
|
$diff = new Diff($fromMatch['file'], $toMatch['file']);
|
|
|
|
++$i;
|
|
} else {
|
|
if (preg_match('/^(?:diff --git |index [\da-f\.]+|[+-]{3} [ab])/', $lines[$i])) {
|
|
continue;
|
|
}
|
|
|
|
$collected[] = $lines[$i];
|
|
}
|
|
}
|
|
|
|
if ($diff !== null && count($collected)) {
|
|
$this->parseFileDiff($diff, $collected);
|
|
|
|
$diffs[] = $diff;
|
|
}
|
|
|
|
return $diffs;
|
|
}
|
|
|
|
private function parseFileDiff(Diff $diff, array $lines): void
|
|
{
|
|
$chunks = [];
|
|
$chunk = null;
|
|
$diffLines = [];
|
|
|
|
foreach ($lines as $line) {
|
|
if (preg_match('/^@@\s+-(?P<start>\d+)(?:,\s*(?P<startrange>\d+))?\s+\+(?P<end>\d+)(?:,\s*(?P<endrange>\d+))?\s+@@/', $line, $match)) {
|
|
$chunk = new Chunk(
|
|
(int) $match['start'],
|
|
isset($match['startrange']) ? max(1, (int) $match['startrange']) : 1,
|
|
(int) $match['end'],
|
|
isset($match['endrange']) ? max(1, (int) $match['endrange']) : 1
|
|
);
|
|
|
|
$chunks[] = $chunk;
|
|
$diffLines = [];
|
|
|
|
continue;
|
|
}
|
|
|
|
if (preg_match('/^(?P<type>[+ -])?(?P<line>.*)/', $line, $match)) {
|
|
$type = Line::UNCHANGED;
|
|
|
|
if ($match['type'] === '+') {
|
|
$type = Line::ADDED;
|
|
} elseif ($match['type'] === '-') {
|
|
$type = Line::REMOVED;
|
|
}
|
|
|
|
$diffLines[] = new Line($type, $match['line']);
|
|
|
|
if (null !== $chunk) {
|
|
$chunk->setLines($diffLines);
|
|
}
|
|
}
|
|
}
|
|
|
|
$diff->setChunks($chunks);
|
|
}
|
|
}
|