Skip to content

Commit

Permalink
Allow some inlinenodes to have child nodes
Browse files Browse the repository at this point in the history
Markdown supports more nesting on nodes than RST does. To support this
we needed to add support for compound nodes. We tried to be backward compatible
for people building their own template. This layer will be removed in v2 and
therfor we do trigger deprecations. See #1161

Fixes: #1160
  • Loading branch information
jaapio committed Oct 25, 2024
1 parent e68d1c4 commit e0068c2
Show file tree
Hide file tree
Showing 35 changed files with 237 additions and 70 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
use phpDocumentor\Guides\Cli\Config\Configuration;
use phpDocumentor\Guides\Cli\Config\XmlFileLoader;
use phpDocumentor\Guides\DependencyInjection\GuidesExtension;
use phpDocumentor\Guides\Markdown\DependencyInjection\MarkdownExtension;
use phpDocumentor\Guides\RestructuredText\DependencyInjection\ReStructuredTextExtension;
use Symfony\Component\Config\Definition\Processor;
use Symfony\Component\Config\FileLocator;
Expand Down Expand Up @@ -51,7 +52,7 @@ public function __construct(array $defaultExtensions = [])
$this->container = new ContainerBuilder();
$this->configLoader = new XmlFileLoader(new FileLocator());

foreach ([new GuidesExtension(), new ReStructuredTextExtension(), ...$defaultExtensions] as $extension) {
foreach ([new GuidesExtension(), new ReStructuredTextExtension(), new MarkdownExtension(), ...$defaultExtensions] as $extension) {
$this->registerExtension($extension, []);
}
}
Expand Down
4 changes: 2 additions & 2 deletions packages/guides-code/src/Code/Twig/CodeExtension.php
Original file line number Diff line number Diff line change
Expand Up @@ -37,13 +37,13 @@ public function getFilters(): array
}

/** @param array<string, mixed> $context */
public function highlight(array $context, string $code, string $language = 'text'): string
public function highlight(array $context, string $code, string|null $language = 'text'): string
{
$debugInformation = $context['debugInformation'] ?? [];
if (!is_array($debugInformation)) {
$debugInformation = [];
}

return ($this->highlighter)($language, $code, $debugInformation)->code;
return ($this->highlighter)($language ?? 'text', $code, $debugInformation)->code;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@
use League\CommonMark\Node\NodeWalker;
use phpDocumentor\Guides\Markdown\ParserInterface;
use phpDocumentor\Guides\MarkupLanguageParser;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;

/**
* @template TValue as InlineNode
* @template TValue as InlineNodeInterface
* @implements ParserInterface<TValue>
*/
abstract class AbstractInlineParser implements ParserInterface
{
abstract public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNode;
abstract public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNodeInterface;
}
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,16 @@
use League\CommonMark\Node\NodeWalkerEvent;
use phpDocumentor\Guides\MarkupLanguageParser;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\Nodes\Inline\PlainTextInlineNode;
use Psr\Log\LoggerInterface;
use RuntimeException;

use function count;
use function sprintf;
use function var_export;

/**
* @template TValue as InlineNode
* @template TValue as InlineNodeInterface
* @extends AbstractInlineParser<TValue>
*/
abstract class AbstractInlineTextDecoratorParser extends AbstractInlineParser
Expand All @@ -40,7 +40,7 @@ public function __construct(
}

/** @return TValue */
public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNode
public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNodeInterface
{
$content = [];

Expand All @@ -66,12 +66,10 @@ public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMa

if ($this->supportsCommonMarkNode($commonMarkNode)) {
if (count($content) === 1 && $content[0] instanceof PlainTextInlineNode) {
return $this->createInlineNode($commonMarkNode, $content[0]->getValue());
return $this->createInlineNode($commonMarkNode, $content[0]->getValue(), $content);

Check failure on line 69 in packages/guides-markdown/src/Markdown/Parsers/InlineParsers/AbstractInlineTextDecoratorParser.php

View workflow job for this annotation

GitHub Actions / Static analysis / Static Code Analysis (8.2)

Method phpDocumentor\Guides\Markdown\Parsers\InlineParsers\AbstractInlineTextDecoratorParser<TValue of phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface>::createInlineNode() invoked with 3 parameters, 2 required.
}

$this->logger->warning(sprintf('%s CONTEXT: Content of emphasis could not be interpreted: %s', $this->getType(), var_export($content, true)));

return $this->createInlineNode($commonMarkNode, null);
return $this->createInlineNode($commonMarkNode, null, $content);

Check failure on line 72 in packages/guides-markdown/src/Markdown/Parsers/InlineParsers/AbstractInlineTextDecoratorParser.php

View workflow job for this annotation

GitHub Actions / Static analysis / Static Code Analysis (8.2)

Method phpDocumentor\Guides\Markdown\Parsers\InlineParsers\AbstractInlineTextDecoratorParser<TValue of phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface>::createInlineNode() invoked with 3 parameters, 2 required.
}

$this->logger->warning(sprintf('%s context does not allow a %s node', $this->getType(), $commonMarkNode::class));
Expand All @@ -83,7 +81,7 @@ public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMa
abstract protected function getType(): string;

/** @return TValue */
abstract protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNode;
abstract protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNodeInterface;

abstract protected function supportsCommonMarkNode(CommonMarkNode $commonMarkNode): bool;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
use League\CommonMark\Node\Node as CommonMarkNode;
use phpDocumentor\Guides\Nodes\Inline\EmphasisInlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use Psr\Log\LoggerInterface;

/** @extends AbstractInlineTextDecoratorParser<EmphasisInlineNode> */
Expand All @@ -35,9 +36,10 @@ protected function getType(): string
return 'Emphasis';
}

protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNode
/** @param InlineNodeInterface[] $children */
protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content, array $children = []): InlineNodeInterface
{
return new EmphasisInlineNode($content ?? '');
return new EmphasisInlineNode($content ?? '', $children);
}

protected function supportsCommonMarkNode(CommonMarkNode $commonMarkNode): bool
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,14 +18,15 @@
use League\CommonMark\Node\NodeWalker;
use League\CommonMark\Node\NodeWalkerEvent;
use phpDocumentor\Guides\MarkupLanguageParser;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\Nodes\Inline\LiteralInlineNode;

use function assert;

/** @extends AbstractInlineParser<LiteralInlineNode> */
final class InlineCodeParser extends AbstractInlineParser
{
public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): LiteralInlineNode
public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNodeInterface
{
assert($current instanceof Code);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
use League\CommonMark\Node\Node as CommonMarkNode;
use phpDocumentor\Guides\Nodes\Inline\ImageInlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use Psr\Log\LoggerInterface;

use function assert;
Expand All @@ -38,7 +39,7 @@ protected function getType(): string
return 'Image';
}

protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNode
protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNodeInterface
{
assert($commonMarkNode instanceof Image);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
use League\CommonMark\Node\Node as CommonMarkNode;
use phpDocumentor\Guides\Nodes\Inline\HyperLinkNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use Psr\Log\LoggerInterface;

use function assert;
Expand All @@ -42,7 +43,8 @@ protected function getType(): string
return 'Link';
}

protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNode
/** @param InlineNodeInterface[] $children */
protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content, array $children = []): InlineNodeInterface
{
assert($commonMarkNode instanceof Link);

Expand All @@ -52,7 +54,7 @@ protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null
$url = substr($url, 0, -3);
}

return new HyperLinkNode($content, $url);
return new HyperLinkNode($content, $url, $children);
}

protected function supportsCommonMarkNode(CommonMarkNode $commonMarkNode): bool
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
use League\CommonMark\Node\NodeWalker;
use League\CommonMark\Node\NodeWalkerEvent;
use phpDocumentor\Guides\MarkupLanguageParser;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\Nodes\Inline\PlainTextInlineNode;

/** @extends AbstractInlineParser<PlainTextInlineNode> */
Expand All @@ -28,7 +28,7 @@ public function __construct()
{
}

public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNode
public function parse(MarkupLanguageParser $parser, NodeWalker $walker, CommonMarkNode $current): InlineNodeInterface
{
return new PlainTextInlineNode(' ');
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
use League\CommonMark\Extension\CommonMark\Node\Inline\Strong;
use League\CommonMark\Node\Node as CommonMarkNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\Nodes\Inline\StrongInlineNode;
use Psr\Log\LoggerInterface;

Expand All @@ -35,9 +36,10 @@ protected function getType(): string
return 'StrongDecorator';
}

protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content): InlineNode
/** @param InlineNodeInterface[] $children */
protected function createInlineNode(CommonMarkNode $commonMarkNode, string|null $content, array $children = []): InlineNodeInterface
{
return new StrongInlineNode($content ?? '');
return new StrongInlineNode($content ?? '', $children);
}

protected function supportsCommonMarkNode(CommonMarkNode $commonMarkNode): bool
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;

Expand All @@ -27,7 +27,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::BACKTICK;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$text = '';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\EmphasisInlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;

Expand All @@ -28,7 +28,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::EMPHASIS_DELIMITER;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$text = '';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,15 +13,15 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;

interface InlineRule
{
public function applies(InlineLexer $lexer): bool;

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null;
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null;

public function getPriority(): int;
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;

Expand All @@ -24,7 +24,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::UNDERSCORE;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$text = '';
$initialPosition = $lexer->token?->position;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;
use phpDocumentor\Guides\RestructuredText\Parser\References\EmbeddedReferenceParser;
Expand All @@ -37,7 +37,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::BACKTICK;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$value = '';
$initialPosition = $lexer->token?->position;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;

Expand All @@ -35,7 +35,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::NAMED_REFERENCE;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$value = rtrim($lexer->token?->value ?? '', '_');
$node = $this->createReference($blockContext, $value);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\Nodes\Inline\StrongInlineNode;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;
Expand All @@ -28,7 +28,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::STRONG_DELIMITER;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$text = '';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

namespace phpDocumentor\Guides\RestructuredText\Parser\Productions\InlineRules;

use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\RestructuredText\Parser\BlockContext;
use phpDocumentor\Guides\RestructuredText\Parser\InlineLexer;

Expand All @@ -29,7 +29,7 @@ public function applies(InlineLexer $lexer): bool
return $lexer->token?->type === InlineLexer::COLON;
}

public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNode|null
public function apply(BlockContext $blockContext, InlineLexer $lexer): InlineNodeInterface|null
{
$domain = null;
$role = null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
namespace phpDocumentor\Guides\RestructuredText\Parser\Productions;

use phpDocumentor\Guides\Nodes\CompoundNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNode;
use phpDocumentor\Guides\Nodes\Inline\InlineNodeInterface;
use phpDocumentor\Guides\Nodes\Inline\NewlineInlineNode;
use phpDocumentor\Guides\Nodes\Node;
use phpDocumentor\Guides\RestructuredText\Nodes\ContainerNode;
Expand Down Expand Up @@ -71,7 +71,7 @@ private function collectContentLines(BlockContext $blockContext): Buffer
return $buffer;
}

/** @return CompoundNode<InlineNode> */
/** @return CompoundNode<InlineNodeInterface> */
private function createLine(BlockContext $blockContext, Buffer $buffer): CompoundNode
{
$line = $this->inlineMarkupRule->apply(new BlockContext(
Expand Down
Loading

0 comments on commit e0068c2

Please sign in to comment.