aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMelody Horn <melody@boringcactus.com>2020-10-29 11:24:46 -0600
committerMelody Horn <melody@boringcactus.com>2020-10-29 11:24:46 -0600
commit7b451ea5d662df6512e4934bc92c85b428a9121f (patch)
treede8ef2cc72a43b2884bc0fb8592ae620d0413a68
parent8c2a36072f2b1c89539c615d47d5639f9268ce3f (diff)
downloadspec-7b451ea5d662df6512e4934bc92c85b428a9121f.tar.gz
spec-7b451ea5d662df6512e4934bc92c85b428a9121f.zip
fix gemtext building
-rw-r--r--_ext/gemtext_builder.py22
1 files changed, 16 insertions, 6 deletions
diff --git a/_ext/gemtext_builder.py b/_ext/gemtext_builder.py
index 9c31788..1e21d29 100644
--- a/_ext/gemtext_builder.py
+++ b/_ext/gemtext_builder.py
@@ -27,7 +27,8 @@ class GemtextTranslator(SphinxTranslator):
self.current_line = ''
self.body = []
self.literal = False
-
+ self.pending_links = []
+
def _finish_line(self):
if self.current_line != '':
self.body.append(self.current_line)
@@ -38,6 +39,7 @@ class GemtextTranslator(SphinxTranslator):
self.current_line = ''
self.body = []
self.literal = False
+ self.pending_links = []
def depart_document(self, node: nodes.document):
self._finish_line()
@@ -72,6 +74,9 @@ class GemtextTranslator(SphinxTranslator):
def depart_paragraph(self, node: nodes.paragraph):
self._finish_line()
+ self.body += self.pending_links
+ self.pending_links = []
+ self.body.append('')
def visit_reference(self, node: nodes.reference):
pass
@@ -81,7 +86,7 @@ class GemtextTranslator(SphinxTranslator):
self._finish_line()
self.body.append('=> {} {}'.format(node.attributes['refuri'], node.astext()))
else:
- self.current_line = '=> {} {}'.format(node.attributes['refuri'], self.current_line)
+ self.pending_links.append('=> {} {}'.format(node.attributes['refuri'], node.astext()))
def visit_image(self, node: nodes.image):
if self.current_line == '':
@@ -112,13 +117,17 @@ class GemtextTranslator(SphinxTranslator):
pass
def depart_bullet_list(self, node: nodes.bullet_list):
- pass
+ if self.body[-1] != '':
+ self.body.append('')
def visit_list_item(self, node: nodes.list_item):
self.current_line += '* '
def depart_list_item(self, node: nodes.list_item):
- pass
+ if self.body[-1] == '':
+ self.body = self.body[:-1]
+ if self.body[-1].startswith('=>') and self.body[-1].endswith(self.body[-2].replace('* ', '')):
+ self.body = self.body[:-2] + [self.body[-1]]
def visit_compound(self, node: nodes.compound):
pass
@@ -144,7 +153,8 @@ class GemtextTranslator(SphinxTranslator):
depart_literal = visit_literal
def visit_literal_block(self, nodes: nodes.literal_block):
- self.body.append('')
+ if self.body[-1] != '':
+ self.body.append('')
self.body.append('```')
self.literal = True
@@ -165,7 +175,7 @@ class GemtextBuilder(Builder):
return self.env.found_docs # can't be fucked to implement this right
def get_target_uri(self, docname: str, typ: str = None):
- return docname
+ return docname + '.gmi'
def prepare_writing(self, docnames: Set[str]):
self.writer = GemtextWriter(self)