mirror of
https://github.com/ae-utbm/sith.git
synced 2024-11-14 02:03:22 +00:00
179 lines
5.2 KiB
Python
179 lines
5.2 KiB
Python
# -*- coding:utf-8 -*
|
|
#
|
|
# Copyright 2023 © AE UTBM
|
|
# ae@utbm.fr / ae.info@utbm.fr
|
|
#
|
|
# This file is part of the website of the UTBM Student Association (AE UTBM),
|
|
# https://ae.utbm.fr.
|
|
#
|
|
# You can find the source code of the website at https://github.com/ae-utbm/sith3
|
|
#
|
|
# LICENSED UNDER THE GNU GENERAL PUBLIC LICENSE VERSION 3 (GPLv3)
|
|
# SEE : https://raw.githubusercontent.com/ae-utbm/sith3/master/LICENSE
|
|
# OR WITHIN THE LOCAL FILE "LICENSE"
|
|
#
|
|
#
|
|
|
|
import os
|
|
import re
|
|
|
|
from django.urls import reverse
|
|
from mistune import InlineGrammar, InlineLexer, Markdown, Renderer, escape, escape_link
|
|
|
|
|
|
class SithRenderer(Renderer):
|
|
def file_link(self, id, suffix):
|
|
return reverse("core:file_detail", kwargs={"file_id": id}) + suffix
|
|
|
|
def exposant(self, text):
|
|
return """<sup>%s</sup>""" % text
|
|
|
|
def indice(self, text):
|
|
return """<sub>%s</sub>""" % text
|
|
|
|
def underline(self, text):
|
|
return """<u>%s</u>""" % text
|
|
|
|
def image(self, original_src, title, text):
|
|
"""Rendering a image with title and text.
|
|
:param src: source link of the image.
|
|
:param title: title text of the image.
|
|
:param text: alt text of the image.
|
|
"""
|
|
style = None
|
|
if "?" in original_src:
|
|
src, params = original_src.rsplit("?", maxsplit=1)
|
|
m = re.search(r"(\d+%?)(x(\d+%?))?", params)
|
|
if not m:
|
|
src = original_src
|
|
else:
|
|
width = m.group(1)
|
|
if not width.endswith("%"):
|
|
width += "px"
|
|
style = "width: %s; " % width
|
|
try:
|
|
height = m.group(3)
|
|
if not height.endswith("%"):
|
|
height += "px"
|
|
style += "height: %s; " % height
|
|
except:
|
|
pass
|
|
else:
|
|
params = None
|
|
src = original_src
|
|
src = escape_link(src)
|
|
text = escape(text, quote=True)
|
|
if title:
|
|
title = escape(title, quote=True)
|
|
html = '<img src="%s" alt="%s" title="%s"' % (src, text, title)
|
|
else:
|
|
html = '<img src="%s" alt="%s"' % (src, text)
|
|
if style:
|
|
html = '%s style="%s"' % (html, style)
|
|
if self.options.get("use_xhtml"):
|
|
return "%s />" % html
|
|
return "%s>" % html
|
|
|
|
|
|
class SithInlineGrammar(InlineGrammar):
|
|
double_emphasis = re.compile(r"^\*{2}([\s\S]+?)\*{2}(?!\*)") # **word**
|
|
emphasis = re.compile(r"^\*((?:\*\*|[^\*])+?)\*(?!\*)") # *word*
|
|
underline = re.compile(r"^_{2}([\s\S]+?)_{2}(?!_)") # __word__
|
|
exposant = re.compile(r"^<sup>([\s\S]+?)</sup>") # <sup>text</sup>
|
|
indice = re.compile(r"^<sub>([\s\S]+?)</sub>") # <sub>text</sub>
|
|
|
|
|
|
class SithInlineLexer(InlineLexer):
|
|
grammar_class = SithInlineGrammar
|
|
|
|
default_rules = [
|
|
"escape",
|
|
# 'inline_html',
|
|
"autolink",
|
|
"url",
|
|
"footnote",
|
|
"link",
|
|
"reflink",
|
|
"nolink",
|
|
"exposant",
|
|
"double_emphasis",
|
|
"emphasis",
|
|
"underline",
|
|
"indice",
|
|
"code",
|
|
"linebreak",
|
|
"strikethrough",
|
|
"text",
|
|
]
|
|
inline_html_rules = [
|
|
"escape",
|
|
"autolink",
|
|
"url",
|
|
"link",
|
|
"reflink",
|
|
"nolink",
|
|
"exposant",
|
|
"double_emphasis",
|
|
"emphasis",
|
|
"underline",
|
|
"indice",
|
|
"code",
|
|
"linebreak",
|
|
"strikethrough",
|
|
"text",
|
|
]
|
|
|
|
def output_underline(self, m):
|
|
text = m.group(1)
|
|
return self.renderer.underline(text)
|
|
|
|
def output_exposant(self, m):
|
|
text = m.group(1)
|
|
return self.renderer.exposant(text)
|
|
|
|
def output_indice(self, m):
|
|
text = m.group(1)
|
|
return self.renderer.indice(text)
|
|
|
|
# Double emphasis rule changed
|
|
def output_double_emphasis(self, m):
|
|
text = m.group(1)
|
|
text = self.output(text)
|
|
return self.renderer.double_emphasis(text)
|
|
|
|
# Emphasis rule changed
|
|
def output_emphasis(self, m):
|
|
text = m.group(1)
|
|
text = self.output(text)
|
|
return self.renderer.emphasis(text)
|
|
|
|
def _process_link(self, m, link, title=None):
|
|
try: # Add page:// support for links
|
|
page = re.compile(r"^page://(\S*)") # page://nom_de_ma_page
|
|
match = page.search(link)
|
|
page = match.group(1) or ""
|
|
link = reverse("core:page", kwargs={"page_name": page})
|
|
except:
|
|
pass
|
|
try: # Add file:// support for links
|
|
file_link = re.compile(r"^file://(\d*)/?(\S*)?") # file://4000/download
|
|
match = file_link.search(link)
|
|
id = match.group(1)
|
|
suffix = match.group(2) or ""
|
|
link = reverse("core:file_detail", kwargs={"file_id": id}) + suffix
|
|
except:
|
|
pass
|
|
return super(SithInlineLexer, self)._process_link(m, link, title)
|
|
|
|
|
|
renderer = SithRenderer(escape=True)
|
|
inline = SithInlineLexer(renderer)
|
|
|
|
markdown = Markdown(renderer, inline=inline)
|
|
|
|
if __name__ == "__main__":
|
|
root_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
|
with open(os.path.join(root_path) + "/doc/SYNTAX.md", "r") as md:
|
|
result = markdown(md.read())
|
|
print(result, end="")
|