disable timing for now

This commit is contained in:
Sina Atalay 2024-02-04 21:50:44 +01:00
parent 53e2fe59b9
commit 382914eee9
1 changed files with 15 additions and 10 deletions

View File

@ -2,9 +2,10 @@
This module contains functions and classes for generating a $\\LaTeX$ file from the data This module contains functions and classes for generating a $\\LaTeX$ file from the data
model and rendering the $\\LaTeX$ file to produce a PDF. model and rendering the $\\LaTeX$ file to produce a PDF.
The $\\LaTeX$ files are generated with [Jinja2](https://jinja.palletsprojects.com/en/3.1.x/) The $\\LaTeX$ files are generated with
templates. Then, the $\\LaTeX$ file is rendered into a PDF with [Jinja2](https://jinja.palletsprojects.com/en/3.1.x/) templates. Then, the $\\LaTeX$
[TinyTeX](https://yihui.org/tinytex/), a $\\LaTeX$ distribution. file is rendered into a PDF with [TinyTeX](https://yihui.org/tinytex/), a $\\LaTeX$
distribution.
""" """
import subprocess import subprocess
@ -19,7 +20,7 @@ from typing import Optional, Literal
import jinja2 import jinja2
from . import data_models as dm from . import data_models as dm
from .terminal_reporter import time_the_event_below # from .user_communicator import time_the_event_below
class LaTeXFile: class LaTeXFile:
@ -114,7 +115,11 @@ class LaTeXFile:
if entry is not None and not isinstance(entry, str): if entry is not None and not isinstance(entry, str):
for key, value in entry.model_dump().items(): for key, value in entry.model_dump().items():
if value is None: if value is None:
try:
entry.__setattr__(key, "") entry.__setattr__(key, "")
except ValueError:
# Then it means it's a computed_field, so it can be ignored.
pass
# The arguments of the template can be used in the template file: # The arguments of the template can be used in the template file:
latex_code = template.render( latex_code = template.render(
@ -370,7 +375,7 @@ def setup_jinja2_environment() -> jinja2.Environment:
return environment return environment
@time_the_event_below("Generating the LaTeX file") # @time_the_event_below("Generating the LaTeX file")
def generate_latex_file( def generate_latex_file(
rendercv_data_model: dm.RenderCVDataModel, output_directory: pathlib.Path rendercv_data_model: dm.RenderCVDataModel, output_directory: pathlib.Path
) -> pathlib.Path: ) -> pathlib.Path:
@ -406,17 +411,17 @@ def generate_latex_file(
if not ("j2.tex" in theme_file.name or "py" in theme_file.name): if not ("j2.tex" in theme_file.name or "py" in theme_file.name):
if theme_file.is_dir(): if theme_file.is_dir():
shutil.copytree( shutil.copytree(
theme_file, str(theme_file),
output_directory / theme_file.name, output_directory / theme_file.name,
dirs_exist_ok=True, dirs_exist_ok=True,
) )
else: else:
shutil.copyfile(theme_file, output_directory / theme_file.name) shutil.copyfile(str(theme_file), output_directory / theme_file.name)
return latex_file_path return latex_file_path
@time_the_event_below("Generating the PDF file") # @time_the_event_below("Generating the PDF file")
def latex_to_pdf(latex_file_path: pathlib.Path) -> pathlib.Path: def latex_to_pdf(latex_file_path: pathlib.Path) -> pathlib.Path:
"""Run TinyTeX with the given $\\LaTeX$ file to generate the PDF. """Run TinyTeX with the given $\\LaTeX$ file to generate the PDF.
@ -446,7 +451,7 @@ def latex_to_pdf(latex_file_path: pathlib.Path) -> pathlib.Path:
with subprocess.Popen( with subprocess.Popen(
[ [
executables[sys.platform], executables[sys.platform],
str(latex_file_path), str(latex_file_path.name),
"-lualatex", "-lualatex",
], ],
cwd=latex_file_path.parent, cwd=latex_file_path.parent,