From 3dcd47d4bbd9fea4d1210e7a7a0a5ca02d99df14 Mon Sep 17 00:00:00 2001 From: MatTheCat Date: Fri, 22 Mar 2024 10:44:23 +0100 Subject: [PATCH] [Config] Fix `YamlReferenceDumper` handling of array examples --- Definition/Dumper/YamlReferenceDumper.php | 24 +++++++------------ .../Dumper/XmlReferenceDumperTest.php | 2 ++ .../Dumper/YamlReferenceDumperTest.php | 11 ++++++--- .../Configuration/ExampleConfiguration.php | 3 +++ 4 files changed, 22 insertions(+), 18 deletions(-) diff --git a/Definition/Dumper/YamlReferenceDumper.php b/Definition/Dumper/YamlReferenceDumper.php index 718a1ae53..c762e22a0 100644 --- a/Definition/Dumper/YamlReferenceDumper.php +++ b/Definition/Dumper/YamlReferenceDumper.php @@ -18,7 +18,6 @@ use Symfony\Component\Config\Definition\NodeInterface; use Symfony\Component\Config\Definition\PrototypedArrayNode; use Symfony\Component\Config\Definition\ScalarNode; -use Symfony\Component\Config\Definition\VariableNode; use Symfony\Component\Yaml\Inline; /** @@ -90,19 +89,12 @@ private function writeNode(NodeInterface $node, ?NodeInterface $parentNode = nul $children = $this->getPrototypeChildren($node); } - if (!$children) { - if ($node->hasDefaultValue() && \count($defaultArray = $node->getDefaultValue())) { - $default = ''; - } elseif (!\is_array($example)) { - $default = '[]'; - } + if (!$children && !($node->hasDefaultValue() && \count($defaultArray = $node->getDefaultValue()))) { + $default = '[]'; } } elseif ($node instanceof EnumNode) { $comments[] = 'One of '.implode('; ', array_map('json_encode', $node->getValues())); $default = $node->hasDefaultValue() ? Inline::dump($node->getDefaultValue()) : '~'; - } elseif (VariableNode::class === \get_class($node) && \is_array($example)) { - // If there is an array example, we are sure we dont need to print a default value - $default = ''; } else { $default = '~'; @@ -170,7 +162,7 @@ private function writeNode(NodeInterface $node, ?NodeInterface $parentNode = nul $this->writeLine('# '.$message.':', $depth * 4 + 4); - $this->writeArray(array_map([Inline::class, 'dump'], $example), $depth + 1); + $this->writeArray(array_map([Inline::class, 'dump'], $example), $depth + 1, true); } if ($children) { @@ -191,7 +183,7 @@ private function writeLine(string $text, int $indent = 0) $this->reference .= sprintf($format, $text)."\n"; } - private function writeArray(array $array, int $depth) + private function writeArray(array $array, int $depth, bool $asComment = false) { $isIndexed = array_values($array) === $array; @@ -202,14 +194,16 @@ private function writeArray(array $array, int $depth) $val = $value; } + $prefix = $asComment ? '# ' : ''; + if ($isIndexed) { - $this->writeLine('- '.$val, $depth * 4); + $this->writeLine($prefix.'- '.$val, $depth * 4); } else { - $this->writeLine(sprintf('%-20s %s', $key.':', $val), $depth * 4); + $this->writeLine(sprintf('%s%-20s %s', $prefix, $key.':', $val), $depth * 4); } if (\is_array($value)) { - $this->writeArray($value, $depth + 1); + $this->writeArray($value, $depth + 1, $asComment); } } } diff --git a/Tests/Definition/Dumper/XmlReferenceDumperTest.php b/Tests/Definition/Dumper/XmlReferenceDumperTest.php index 520d25666..67ecb3bf7 100644 --- a/Tests/Definition/Dumper/XmlReferenceDumperTest.php +++ b/Tests/Definition/Dumper/XmlReferenceDumperTest.php @@ -109,6 +109,8 @@ enum="" + + EOL diff --git a/Tests/Definition/Dumper/YamlReferenceDumperTest.php b/Tests/Definition/Dumper/YamlReferenceDumperTest.php index 3f198ca9d..b2a45ae9d 100644 --- a/Tests/Definition/Dumper/YamlReferenceDumperTest.php +++ b/Tests/Definition/Dumper/YamlReferenceDumperTest.php @@ -114,11 +114,11 @@ enum: ~ # One of "this"; "that" # which should be indented child3: ~ # Example: 'example setting' scalar_prototyped: [] - variable: + variable: ~ # Examples: - - foo - - bar + # - foo + # - bar parameters: # Prototype: Parameter name @@ -142,6 +142,11 @@ enum: ~ # One of "this"; "that" # Prototype name: [] + array_with_array_example_and_no_default_value: [] + + # Examples: + # - foo + # - bar custom_node: true EOL; diff --git a/Tests/Fixtures/Configuration/ExampleConfiguration.php b/Tests/Fixtures/Configuration/ExampleConfiguration.php index 126008831..512150afd 100644 --- a/Tests/Fixtures/Configuration/ExampleConfiguration.php +++ b/Tests/Fixtures/Configuration/ExampleConfiguration.php @@ -96,6 +96,9 @@ public function getConfigTreeBuilder(): TreeBuilder ->end() ->end() ->end() + ->arrayNode('array_with_array_example_and_no_default_value') + ->example(['foo', 'bar']) + ->end() ->append(new CustomNodeDefinition('acme')) ->end() ;