Vylepšený error handling, žádná chyba už není Exception, warningy používají pythoní warnings #3

This commit is contained in:
Jan Černohorský 2023-07-19 19:30:17 +02:00
parent 6dd2cbc995
commit 9092102fce
4 changed files with 25 additions and 9 deletions

View file

@ -1,7 +1,7 @@
from panflute import Doc, Div
import os
import warnings
# This class is used to keep state while transforming the document using
# transform.py. For the context to be available to the html and TeX generators,
@ -68,7 +68,7 @@ class Context:
def set_metadata(self, key: str, value):
if key == "language":
print("WARN: Setting language this way doesn't propagate to TeX. Either use the Front Matter or specify it additionally using the \\languagexx macro.")
warnings.warn("Setting language this way doesn't propagate to TeX. Either use the Front Matter or specify it additionally using the \\languagexx macro.", UserWarning)
meta = self.doc.metadata
keys = key.split(".")
for k in keys[:-1]:

View file

@ -7,6 +7,7 @@ from typing import Union, Dict
import re
import os
import io
import warnings
from pygments import highlight
from pygments.lexers import get_lexer_by_name
@ -107,6 +108,7 @@ class HTMLGenerator(OutputGenerator):
self.generate_simple_block_tag(e, "main", self.common_attributes(e))
def generate_CodeBlock(self, e: CodeBlock):
lexer = None
if e.classes and len(e.classes) > 0 and (e.attributes["highlight"] == True or e.attributes["highlight"] == 'True'):
# Syntax highlighting using pygments
for cl in e.classes:
@ -116,8 +118,9 @@ class HTMLGenerator(OutputGenerator):
continue
break
else:
lexer = None
print(f"WARN: Syntax highligher does not have lexer for element with these classes: {e.classes}")
warnings.warn(f"Syntax highligher does not have lexer for element with these classes: {e.classes}", UserWarning)
if lexer:
formatter = HtmlFormatter(style=e.attributes["style"])
result = highlight(e.text, lexer, formatter)
self.writeraw(result)

View file

@ -7,6 +7,12 @@ from PIL import Image
class FileInWrongDirError(Exception):
pass
class InkscapeError(Exception):
pass
class ImageMagickError(Exception):
pass
class ImageProcessor:
def __init__(self, public_dir: str, web_path: str, cache_dir: str, *lookup_dirs: List[str]):
self.public_dir = public_dir
@ -67,7 +73,7 @@ class ImageProcessor:
height_arg = ['--export-height', str(height)] if height is not None else []
dpi_arg = ['--export-dpi', str(dpi)] if dpi is not None else []
if subprocess.run(['inkscape', full_path, '-o', target_path, *width_arg, *height_arg, *dpi_arg]).returncode != 0:
raise Exception(f"Could not convert '{full_path}' to '{format}'")
raise InkscapeError(f"Could not convert '{full_path}' to '{format}'")
# Convert everything else using ImageMagick.
else:
@ -75,7 +81,7 @@ class ImageProcessor:
density_arg = ['-density', str(dpi)] if dpi is not None else []
quality_arg = ['-quality', str(quality)] if quality is not None else []
if subprocess.run(['convert', *density_arg, full_path, *resize_arg, *quality_arg, target_path]).returncode != 0:
raise Exception(f"Could not convert '{full_path}' to '{format}'")
raise ImageMagickError(f"Could not convert '{full_path}' to '{format}'")
return target_name

View file

@ -9,6 +9,13 @@ from typing import Dict
class KatexError(Exception):
pass
class NPMNotFoundError(Exception):
pass
class KatexServerError(Exception):
pass
class KatexClient:
def __init__(self):
# Create temporary directory for socket
@ -24,7 +31,7 @@ class KatexClient:
subprocess.run(["npm", "install"], cwd=srcdir+"/katex-server", check=True)
except subprocess.CalledProcessError as e:
if e.returncode == 127:
raise Exception("npm not found. Node.js is required to use KaTeX.")
raise NPMNotFoundError("npm not found. Node.js is required to use KaTeX.")
else:
raise e
@ -34,7 +41,7 @@ class KatexClient:
ok = self._server_process.stdout.readline()
if ok != b"OK\n":
raise Exception("Failed to connect to katex-server")
raise KatexServerError("Failed to connect to katex-server")
self._client.connect(self._socket_file)
@ -49,7 +56,7 @@ class KatexClient:
response = json.loads(data)
if "error" in response:
raise Exception(response["error"])
raise KatexServerError(response["error"])
if "error" in response["results"][0]:
raise KatexError(response["results"][0]["error"])
else: