Compare commits
3 Commits
2fff247ac1
...
1de5e568ef
Author | SHA1 | Date | |
---|---|---|---|
1de5e568ef | |||
96f16a33a1 | |||
859b660400 |
2
run.php
2
run.php
@ -49,7 +49,7 @@ foreach ($titles as $title) {
|
||||
|
||||
$sanitized_title = $title;
|
||||
$sanitized_title = strtolower($sanitized_title);
|
||||
$sanitized_title = str_replace([' ', ','], ['-'], $sanitized_title);
|
||||
$sanitized_title = str_replace([' ', ',', '\''], ['-'], $sanitized_title);
|
||||
$sanitized_title .= '.gmi';
|
||||
|
||||
$output_path = $gemlog_output_path . '/' . $sanitized_title;
|
||||
|
@ -7,6 +7,7 @@ namespace LogseqGem;
|
||||
use League\CommonMark\Node\Inline\Text;
|
||||
use League\CommonMark\Extension\CommonMark\Node\Inline\Link;
|
||||
use League\CommonMark\Extension\CommonMark\Node\Block\ListBlock;
|
||||
use League\CommonMark\Extension\CommonMark\Node\Block\ListItem;
|
||||
|
||||
class ArticleParser extends Parser {
|
||||
private ?array $properties;
|
||||
@ -17,14 +18,22 @@ class ArticleParser extends Parser {
|
||||
|
||||
$in_frontmatter = true;
|
||||
|
||||
// we only update this for significant nodes
|
||||
$previous_node = null;
|
||||
$node = null; //current node
|
||||
$last_node = null; //updated every time
|
||||
$previous_node = null; // we only update this for significant nodes
|
||||
|
||||
$walker = $this->document->walker();
|
||||
while ($event = $walker->next()) {
|
||||
$entering = $event->isEntering();
|
||||
$last_node = $node;
|
||||
$node = $event->getNode();
|
||||
|
||||
// treat empty node as a newline
|
||||
if ($node instanceof ListItem && $last_node === $node && !$entering) {
|
||||
$gemtext[] = '';
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!$entering) {
|
||||
continue;
|
||||
}
|
||||
|
@ -2,7 +2,8 @@
|
||||
|
||||
%CONTENT%
|
||||
|
||||
- annika // %DATE_FORMATTED%
|
||||
✑ Annika
|
||||
📅 %DATE_FORMATTED%
|
||||
|
||||
=> /gemlog.gmi gemlog
|
||||
=> / home
|
||||
|
@ -89,4 +89,10 @@ class ArticleParserTest extends TestCase {
|
||||
$this->parser->convert();
|
||||
$this->assertTrue($this->parser->isPublished());
|
||||
}
|
||||
|
||||
public function testNewlineBetweenLinks() {
|
||||
$this->setArticleText("\n- [foo](bar)\n-\n- [bar](foo)");
|
||||
$this->parser->load(vfsStream::url('root/article.md'));
|
||||
$this->assertSame("=> bar foo\n\n=> foo bar", $this->parser->convert());
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user