From 3d02590436fb09d48ecdaac29f630322ab64f0df Mon Sep 17 00:00:00 2001 From: Ren Xie Liu Date: Thu, 7 Sep 2023 11:09:38 +0800 Subject: [PATCH] Remove empty space after colon --- lib/Parser/MimeDir.php | 20 +++++++++++++------ tests/VObject/Parser/UnfoldingTest.php | 27 ++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 6 deletions(-) diff --git a/lib/Parser/MimeDir.php b/lib/Parser/MimeDir.php index db5ded667..bd5e5e372 100644 --- a/lib/Parser/MimeDir.php +++ b/lib/Parser/MimeDir.php @@ -227,12 +227,20 @@ protected function parseLine(string $line) && $e instanceof ParseException && str_contains($e->getMessage(), 'Invalid Mimedir file. Line starting at') && ($this->options & Reader::OPTION_FIX_UNFOLDING) ) { - // Fix unfolding - $component->remove($prevNode); - $value = $prevNode->getValue().' '.$line.PHP_EOL; - $prevNode->offsetSet('VALUE', $value); - $prevNode->setValue($value); - $component->add($prevNode); + if (preg_match('/[A-Z]\w+; /', $line)) { + $line = preg_replace('/([A-Z]\w+;) /', '$1', $line); + $result = $this->parseLine($line); + if ($result) { + $prevNode = $component->add($result); + } + } else { + // Fix unfolding + $component->remove($prevNode); + $value = $prevNode->getValue() . ' ' . $line . PHP_EOL; + $prevNode->offsetSet('VALUE', $value); + $prevNode->setValue($value); + $component->add($prevNode); + } continue; } throw $e; diff --git a/tests/VObject/Parser/UnfoldingTest.php b/tests/VObject/Parser/UnfoldingTest.php index 8d751ae7a..56c9e28e4 100644 --- a/tests/VObject/Parser/UnfoldingTest.php +++ b/tests/VObject/Parser/UnfoldingTest.php @@ -96,4 +96,31 @@ public function testNotFixUnknownProperty() $this->assertNotNull($vcard->children()[0]->CONFERENCE->getValue()); } + + public function testRemoveEmptySpaceAfterColon(): void + { + $vcard = <<parse($vcard, Reader::OPTION_FIX_UNFOLDING | Reader::OPTION_FORGIVING); + + + $this->assertSame( + 0, + $vcard->VEVENT->SEQUENCE->getValue() + ); + + $this->assertSame( + 'ORGANIZER;CN=Plannert:mailto:noreply@sho.nl' . "\r\n", + $vcard->VEVENT->ORGANIZER->serialize() + ); + } }