LATEX¶
LATEX-specific utilities exposed by Texsmith.
LaTeXFormatter ¶
LaTeXFormatter(template_dir: Path = TEMPLATE_DIR)
Render LATEX templates using Jinja2 with custom delimiters.
Source code in src/texsmith/adapters/latex/formatter.py
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 | |
template_names
property
¶
template_names: set[str]
Return the set of available template identifiers.
__getattr__ ¶
__getattr__(method: str) -> Callable[..., str]
Proxy calls to templates or custom handlers.
Source code in src/texsmith/adapters/latex/formatter.py
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 | |
get_cover ¶
get_cover(name: str, **kwargs: Any) -> str
Render a named cover template populated with book metadata.
Source code in src/texsmith/adapters/latex/formatter.py
268 269 270 271 272 273 274 275 276 277 278 279 | |
handle_codeblock ¶
handle_codeblock(
code: str,
language: str = "text",
filename: str | None = None,
lineno: bool = False,
highlight: Iterable[int] | None = None,
baselinestretch: float | None = None,
engine: str | None = None,
state: DocumentState | None = None,
**_: Any,
) -> str
Render code blocks with optional line numbers and highlights.
Source code in src/texsmith/adapters/latex/formatter.py
144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 | |
handle_codeinline ¶
handle_codeinline(
*,
language: str = "text",
text: str,
engine: str | None = None,
state: DocumentState | None = None,
delimiter: str | None = None,
) -> str
Render inline code with engine-specific highlighting.
Source code in src/texsmith/adapters/latex/formatter.py
226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 | |
handle_codeinlinett ¶
handle_codeinlinett(text: str) -> str
Render plain inline code inside \texttt.
Source code in src/texsmith/adapters/latex/formatter.py
138 139 140 141 142 | |
handle_href ¶
handle_href(text: str, url: str) -> str
Render \href links with escaped URLs.
Source code in src/texsmith/adapters/latex/formatter.py
218 219 220 | |
handle_regex ¶
handle_regex(text: str, url: str) -> str
Render regex helper links with escaped URLs.
Source code in src/texsmith/adapters/latex/formatter.py
222 223 224 | |
normalise_key
classmethod
¶
normalise_key(name: str) -> str
Public wrapper for normalising template identifiers.
Source code in src/texsmith/adapters/latex/formatter.py
80 81 82 83 | |
override_template ¶
override_template(name: str, source: str | Path) -> None
Override a built-in template snippet using an external payload.
Source code in src/texsmith/adapters/latex/formatter.py
281 282 283 284 285 286 287 288 289 290 291 292 293 294 | |
svg ¶
svg(svg: str | Path) -> str
Render an SVG image by converting it to PDF first.
Source code in src/texsmith/adapters/latex/formatter.py
261 262 263 264 265 266 | |
url ¶
url(text: str, url: str) -> str
Render a URL, escaping special LATEX characters.
Source code in src/texsmith/adapters/latex/formatter.py
213 214 215 216 | |
LaTeXRenderer ¶
LaTeXRenderer(
config: BookConfig | None = None,
formatter: LaTeXFormatter | None = None,
output_root: Path | str = Path("build"),
parser: str = "lxml",
copy_assets: bool = True,
convert_assets: bool = False,
hash_assets: bool = False,
)
Source code in src/texsmith/adapters/latex/renderer.py
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | |
describe_registered_rules ¶
describe_registered_rules() -> list[dict[str, object]]
Return detailed metadata about registered rules.
Source code in src/texsmith/adapters/latex/renderer.py
215 216 217 | |
iter_registered_rules ¶
iter_registered_rules() -> Iterable[
tuple[RenderPhase, str]
]
Expose currently registered rules for debugging/reporting.
Source code in src/texsmith/adapters/latex/renderer.py
209 210 211 212 213 | |
register ¶
register(handler: Any) -> None
Register additional handlers on demand.
Arguments can be callables decorated with :func:renders or modules/classes
exposing decorated attributes.
Source code in src/texsmith/adapters/latex/renderer.py
88 89 90 91 92 93 94 95 96 97 98 99 | |
render ¶
render(
html: str,
*,
runtime: Mapping[str, Any] | None = None,
state: DocumentState | None = None,
emitter: DiagnosticEmitter | None = None,
) -> str
Render an HTML fragment into LATEX.
Source code in src/texsmith/adapters/latex/renderer.py
154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 | |
escape_latex_chars ¶
escape_latex_chars(
text: str, *, legacy_accents: bool = False
) -> str
Escape LATEX special characters leveraging pylatexenc.
Source code in src/texsmith/adapters/latex/utils.py
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 | |
optimize_list ¶
optimize_list(numbers: Iterable[int]) -> list[str]
Merge consecutive integers into human-readable ranges.
Source code in src/texsmith/adapters/latex/formatter.py
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | |
Utilities for rendering LATEX partials (snippets).
LaTeXFormatter ¶
LaTeXFormatter(template_dir: Path = TEMPLATE_DIR)
Render LATEX templates using Jinja2 with custom delimiters.
Source code in src/texsmith/adapters/latex/formatter.py
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 | |
template_names
property
¶
template_names: set[str]
Return the set of available template identifiers.
__getattr__ ¶
__getattr__(method: str) -> Callable[..., str]
Proxy calls to templates or custom handlers.
Source code in src/texsmith/adapters/latex/formatter.py
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 | |
get_cover ¶
get_cover(name: str, **kwargs: Any) -> str
Render a named cover template populated with book metadata.
Source code in src/texsmith/adapters/latex/formatter.py
268 269 270 271 272 273 274 275 276 277 278 279 | |
handle_codeblock ¶
handle_codeblock(
code: str,
language: str = "text",
filename: str | None = None,
lineno: bool = False,
highlight: Iterable[int] | None = None,
baselinestretch: float | None = None,
engine: str | None = None,
state: DocumentState | None = None,
**_: Any,
) -> str
Render code blocks with optional line numbers and highlights.
Source code in src/texsmith/adapters/latex/formatter.py
144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 | |
handle_codeinline ¶
handle_codeinline(
*,
language: str = "text",
text: str,
engine: str | None = None,
state: DocumentState | None = None,
delimiter: str | None = None,
) -> str
Render inline code with engine-specific highlighting.
Source code in src/texsmith/adapters/latex/formatter.py
226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 | |
handle_codeinlinett ¶
handle_codeinlinett(text: str) -> str
Render plain inline code inside \texttt.
Source code in src/texsmith/adapters/latex/formatter.py
138 139 140 141 142 | |
handle_href ¶
handle_href(text: str, url: str) -> str
Render \href links with escaped URLs.
Source code in src/texsmith/adapters/latex/formatter.py
218 219 220 | |
handle_regex ¶
handle_regex(text: str, url: str) -> str
Render regex helper links with escaped URLs.
Source code in src/texsmith/adapters/latex/formatter.py
222 223 224 | |
normalise_key
classmethod
¶
normalise_key(name: str) -> str
Public wrapper for normalising template identifiers.
Source code in src/texsmith/adapters/latex/formatter.py
80 81 82 83 | |
override_template ¶
override_template(name: str, source: str | Path) -> None
Override a built-in template snippet using an external payload.
Source code in src/texsmith/adapters/latex/formatter.py
281 282 283 284 285 286 287 288 289 290 291 292 293 294 | |
svg ¶
svg(svg: str | Path) -> str
Render an SVG image by converting it to PDF first.
Source code in src/texsmith/adapters/latex/formatter.py
261 262 263 264 265 266 | |
url ¶
url(text: str, url: str) -> str
Render a URL, escaping special LATEX characters.
Source code in src/texsmith/adapters/latex/formatter.py
213 214 215 216 | |
optimize_list ¶
optimize_list(numbers: Iterable[int]) -> list[str]
Merge consecutive integers into human-readable ranges.
Source code in src/texsmith/adapters/latex/formatter.py
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | |
High-level HTML to LATEX renderer based on the modular pipeline.
LaTeXRenderer ¶
LaTeXRenderer(
config: BookConfig | None = None,
formatter: LaTeXFormatter | None = None,
output_root: Path | str = Path("build"),
parser: str = "lxml",
copy_assets: bool = True,
convert_assets: bool = False,
hash_assets: bool = False,
)
Source code in src/texsmith/adapters/latex/renderer.py
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | |
describe_registered_rules ¶
describe_registered_rules() -> list[dict[str, object]]
Return detailed metadata about registered rules.
Source code in src/texsmith/adapters/latex/renderer.py
215 216 217 | |
iter_registered_rules ¶
iter_registered_rules() -> Iterable[
tuple[RenderPhase, str]
]
Expose currently registered rules for debugging/reporting.
Source code in src/texsmith/adapters/latex/renderer.py
209 210 211 212 213 | |
register ¶
register(handler: Any) -> None
Register additional handlers on demand.
Arguments can be callables decorated with :func:renders or modules/classes
exposing decorated attributes.
Source code in src/texsmith/adapters/latex/renderer.py
88 89 90 91 92 93 94 95 96 97 98 99 | |
render ¶
render(
html: str,
*,
runtime: Mapping[str, Any] | None = None,
state: DocumentState | None = None,
emitter: DiagnosticEmitter | None = None,
) -> str
Render an HTML fragment into LATEX.
Source code in src/texsmith/adapters/latex/renderer.py
154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 | |
Utilities for parsing and presenting output from LATEX engine builds.
LatexLogParser ¶
LatexLogParser()
Incrementally parse LATEX output into structured messages.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
107 108 109 110 | |
finalize ¶
finalize() -> list[LatexMessage]
Flush any pending message.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
166 167 168 | |
process_line ¶
process_line(line: str) -> list[LatexMessage]
Process a log line and return messages that have just completed.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 | |
LatexLogRenderer ¶
LatexLogRenderer(console: Console)
Render structured LATEX messages to a Rich console.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
417 418 419 420 421 422 423 424 425 | |
consume ¶
consume(message: LatexMessage) -> None
Display a single message, queueing it for tree-aware formatting.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 | |
summarize ¶
summarize() -> None
Print a summary of processed messages grouped by severity.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 | |
LatexMessage
dataclass
¶
LatexMessage(
severity: LatexMessageSeverity,
summary: str,
details: list[str] = list(),
indent: int = 0,
)
Structured LATEX message extracted from the build log.
LatexMessageSeverity ¶
Bases: Enum
Classification severity extracted from LATEX output.
LatexStreamResult
dataclass
¶
LatexStreamResult(
returncode: int, messages: list[LatexMessage]
)
Result of streaming LATEX engine output.
parse_latex_log ¶
parse_latex_log(log_path: Path) -> list[LatexMessage]
Parse a LATEX log file into structured messages.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
711 712 713 714 715 716 717 718 719 720 | |
stream_latexmk_output ¶
stream_latexmk_output(
command: Sequence[str],
*,
cwd: str,
env: Mapping[str, str],
console: Console,
verbosity: int = 0,
) -> LatexStreamResult
Execute a LATEX engine command and render output incrementally.
Source code in src/texsmith/adapters/latex/engines/latex/log.py
657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 | |
Utility helpers specific to LATEX rendering.
escape_latex_chars ¶
escape_latex_chars(
text: str, *, legacy_accents: bool = False
) -> str
Escape LATEX special characters leveraging pylatexenc.
Source code in src/texsmith/adapters/latex/utils.py
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 | |
Public template helpers shared across the conversion pipeline.
BaseTemplate ¶
BaseTemplate(root: Path)
Base class shared by template implementations.
Source code in src/texsmith/core/templates/base.py
66 67 68 69 70 71 72 73 74 | |
default_context ¶
default_context() -> dict[str, Any]
Return a shallow copy of the manifest default attributes.
Source code in src/texsmith/core/templates/base.py
76 77 78 79 80 | |
render_template ¶
render_template(template_name: str, **context: Any) -> str
Render a template using the configured Jinja environment.
Source code in src/texsmith/core/templates/base.py
82 83 84 85 86 87 88 89 90 | |
ResolvedAsset
dataclass
¶
ResolvedAsset(
source: Path,
destination: Path,
template: bool = False,
encoding: str | None = None,
template_name: str | None = None,
)
Resolved template asset ready to be materialised.
TemplateAsset ¶
Bases: BaseModel
Description of individual template assets.
TemplateAttributeSpec ¶
Bases: BaseModel
Typed attribute definition used to build template defaults.
default_value ¶
default_value() -> Any
Return a deep copy of the attribute default.
Source code in src/texsmith/core/templates/manifest.py
511 512 513 | |
TemplateBinding
dataclass
¶
TemplateBinding(
runtime: TemplateRuntime | None,
instance: WrappableTemplate | None,
name: str | None,
engine: str | None,
requires_shell_escape: bool,
formatter_overrides: dict[str, Path],
slots: dict[str, TemplateSlot],
default_slot: str,
base_level: int | None,
required_partials: set[str] = set(),
)
Binding between slot requests and a LATEX template.
apply_formatter_overrides ¶
apply_formatter_overrides(
formatter: "LaTeXFormatter",
) -> None
Apply template-provided overrides to a formatter.
Source code in src/texsmith/core/templates/runtime.py
61 62 63 64 | |
slot_levels ¶
slot_levels(*, offset: int = 0) -> dict[str, int]
Return the resolved base level for each slot.
Source code in src/texsmith/core/templates/runtime.py
56 57 58 59 | |
TemplateError ¶
Bases: LatexRenderingError
Raised when a LATEX template cannot be loaded or rendered.
TemplateInfo ¶
Bases: BaseModel
Metadata describing the LATEX template payload.
attribute_defaults ¶
attribute_defaults() -> dict[str, Any]
Return a deep copy of template attribute defaults.
Source code in src/texsmith/core/templates/manifest.py
785 786 787 | |
attribute_owners ¶
attribute_owners() -> dict[str, str]
Return attribute ownership map (name -> owner).
Source code in src/texsmith/core/templates/manifest.py
800 801 802 | |
emit_defaults ¶
emit_defaults() -> dict[str, Any]
Return default attributes emitted by the template.
Source code in src/texsmith/core/templates/manifest.py
789 790 791 | |
resolve_attributes ¶
resolve_attributes(
overrides: Mapping[str, Any] | None = None,
) -> dict[str, Any]
Return defaults merged with overrides using the attribute specification.
Source code in src/texsmith/core/templates/manifest.py
796 797 798 | |
resolve_slots ¶
resolve_slots() -> tuple[dict[str, TemplateSlot], str]
Return declared slots ensuring a single default sink exists.
Source code in src/texsmith/core/templates/manifest.py
765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 | |
TemplateManifest ¶
Bases: BaseModel
Structured manifest describing a LATEX template.
load
classmethod
¶
load(manifest_path: Path) -> TemplateManifest
Load and validate a manifest from disk.
Source code in src/texsmith/core/templates/manifest.py
817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 | |
TemplateRuntime
dataclass
¶
TemplateRuntime(
instance: WrappableTemplate,
name: str,
engine: str | None,
requires_shell_escape: bool,
slots: dict[str, TemplateSlot],
default_slot: str,
formatter_overrides: dict[str, Path],
base_level: int | None,
required_partials: set[str] = set(),
extras: dict[str, Any] = dict(),
)
Resolved template metadata reused across conversions.
TemplateSlot ¶
Bases: BaseModel
Configuration describing how content is injected into a template slot.
resolve_level ¶
resolve_level(fallback: int) -> int
Return the base level applied to rendered headings for this slot.
Source code in src/texsmith/core/templates/manifest.py
123 124 125 126 127 128 129 130 | |
TemplateWrapResult
dataclass
¶
TemplateWrapResult(
latex_output: str,
template_context: dict[str, Any],
output_path: Path | None,
asset_paths: list[Path] = list(),
asset_pairs: list[tuple[Path, Path]] = list(),
rendered_fragments: list[str] = list(),
)
Result artefacts produced after wrapping LATEX with a template.
WrappableTemplate ¶
WrappableTemplate(root: Path)
Bases: BaseTemplate
Template capable of wrapping a generated LATEX fragment.
Source code in src/texsmith/core/templates/base.py
66 67 68 69 70 71 72 73 74 | |
iter_assets ¶
iter_assets() -> Iterable['ResolvedAsset']
Yield declared template assets.
Source code in src/texsmith/core/templates/base.py
168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 | |
iter_formatter_overrides ¶
iter_formatter_overrides() -> Iterable[tuple[str, Path]]
Yield formatter override templates declared by the manifest.
Source code in src/texsmith/core/templates/base.py
212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 | |
prepare_context ¶
prepare_context(
latex_body: str,
*,
overrides: Mapping[str, Any] | None = None,
) -> dict[str, Any]
Build the rendering context shared by the template and its assets.
Source code in src/texsmith/core/templates/base.py
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | |
wrap_document ¶
wrap_document(
latex_body: str,
*,
overrides: Mapping[str, Any] | None = None,
context: Mapping[str, Any] | None = None,
) -> str
Render the template entry point using the provided LATEX payload.
Source code in src/texsmith/core/templates/base.py
137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 | |
build_template_overrides ¶
build_template_overrides(
front_matter: Mapping[str, Any] | None,
) -> dict[str, Any]
Build template overrides from front matter while preserving metadata.
Source code in src/texsmith/core/templates/runtime.py
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 | |
coerce_base_level ¶
coerce_base_level(
value: Any, *, allow_none: bool = True
) -> int | None
Normalise base-level metadata to an integer or None.
Source code in src/texsmith/core/templates/runtime.py
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | |
copy_template_assets ¶
copy_template_assets(
template: WrappableTemplate,
output_dir: Path,
*,
context: Mapping[str, Any] | None = None,
overrides: Mapping[str, Any] | None = None,
assets: Iterable["ResolvedAsset"] | None = None,
) -> list[Path]
Copy the template declared assets into the selected output directory.
Source code in src/texsmith/core/templates/loader.py
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 | |
discover_templates ¶
discover_templates() -> list[dict[str, str]]
Return available templates in discovery order.
Source code in src/texsmith/core/templates/loader.py
220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 | |
extract_base_level_override ¶
extract_base_level_override(
overrides: Mapping[str, Any] | None,
) -> Any
Extract a base level override from template metadata overrides.
Source code in src/texsmith/core/templates/runtime.py
107 108 109 110 111 112 113 114 115 116 117 118 | |
extract_language_from_front_matter ¶
extract_language_from_front_matter(
front_matter: Mapping[str, Any] | None,
) -> str | None
Inspect front matter for language hints.
Source code in src/texsmith/core/templates/runtime.py
161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 | |
load_template ¶
load_template(identifier: str) -> WrappableTemplate
Load a template selected by name or filesystem path.
Source code in src/texsmith/core/templates/loader.py
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | |
load_template_runtime ¶
load_template_runtime(template: str) -> TemplateRuntime
Resolve template metadata for repeated conversions.
Source code in src/texsmith/core/templates/runtime.py
228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 | |
normalise_template_language ¶
normalise_template_language(
value: str | None,
) -> str | None
Normalise language codes and map them through babel aliases when available.
Source code in src/texsmith/core/templates/runtime.py
186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 | |
resolve_template_binding ¶
resolve_template_binding(
*,
template: str | None,
template_runtime: TemplateRuntime | None,
template_overrides: Mapping[str, Any],
slot_requests: Mapping[str, str],
warn: Callable[[str], None] | None = None,
) -> tuple[TemplateBinding, dict[str, str]]
Resolve template runtime metadata and apply slot overrides.
Source code in src/texsmith/core/templates/runtime.py
262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 | |
resolve_template_language ¶
resolve_template_language(
explicit: str | None,
front_matter: Mapping[str, Any] | None,
) -> str
Resolve the effective template language from CLI and front matter inputs.
Source code in src/texsmith/core/templates/runtime.py
211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 | |
wrap_template_document ¶
wrap_template_document(
*,
template: WrappableTemplate,
default_slot: str,
slot_outputs: Mapping[str, str],
slot_output_overrides: Mapping[str, str] | None = None,
document_state: DocumentState,
template_overrides: Mapping[str, Any] | None,
output_dir: Path,
copy_assets: bool = True,
output_name: str | None = None,
bibliography_path: Path | None = None,
emitter: DiagnosticEmitter | None = None,
fragments: list[str] | None = None,
template_runtime: TemplateRuntime | None = None,
) -> TemplateWrapResult
Wrap LATEX content using a template and optional asset copying.
Source code in src/texsmith/core/templates/wrapper.py
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 | |
Core classes used to load and wrap LATEX templates.
BaseTemplate ¶
BaseTemplate(root: Path)
Base class shared by template implementations.
Source code in src/texsmith/core/templates/base.py
66 67 68 69 70 71 72 73 74 | |
default_context ¶
default_context() -> dict[str, Any]
Return a shallow copy of the manifest default attributes.
Source code in src/texsmith/core/templates/base.py
76 77 78 79 80 | |
render_template ¶
render_template(template_name: str, **context: Any) -> str
Render a template using the configured Jinja environment.
Source code in src/texsmith/core/templates/base.py
82 83 84 85 86 87 88 89 90 | |
ResolvedAsset
dataclass
¶
ResolvedAsset(
source: Path,
destination: Path,
template: bool = False,
encoding: str | None = None,
template_name: str | None = None,
)
Resolved template asset ready to be materialised.
TemplateError ¶
Bases: LatexRenderingError
Raised when a LATEX template cannot be loaded or rendered.
WrappableTemplate ¶
WrappableTemplate(root: Path)
Bases: BaseTemplate
Template capable of wrapping a generated LATEX fragment.
Source code in src/texsmith/core/templates/base.py
66 67 68 69 70 71 72 73 74 | |
iter_assets ¶
iter_assets() -> Iterable['ResolvedAsset']
Yield declared template assets.
Source code in src/texsmith/core/templates/base.py
168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 | |
iter_formatter_overrides ¶
iter_formatter_overrides() -> Iterable[tuple[str, Path]]
Yield formatter override templates declared by the manifest.
Source code in src/texsmith/core/templates/base.py
212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 | |
prepare_context ¶
prepare_context(
latex_body: str,
*,
overrides: Mapping[str, Any] | None = None,
) -> dict[str, Any]
Build the rendering context shared by the template and its assets.
Source code in src/texsmith/core/templates/base.py
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | |
wrap_document ¶
wrap_document(
latex_body: str,
*,
overrides: Mapping[str, Any] | None = None,
context: Mapping[str, Any] | None = None,
) -> str
Render the template entry point using the provided LATEX payload.
Source code in src/texsmith/core/templates/base.py
137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 | |
load_specialised_template ¶
load_specialised_template(
path: Path,
) -> WrappableTemplate | None
Import a template-specific module to retrieve a specialised implementation.
Source code in src/texsmith/core/templates/base.py
300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 | |
Helpers for loading template instances from disk or entry points.
copy_template_assets ¶
copy_template_assets(
template: WrappableTemplate,
output_dir: Path,
*,
context: Mapping[str, Any] | None = None,
overrides: Mapping[str, Any] | None = None,
assets: Iterable["ResolvedAsset"] | None = None,
) -> list[Path]
Copy the template declared assets into the selected output directory.
Source code in src/texsmith/core/templates/loader.py
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 | |
discover_templates ¶
discover_templates() -> list[dict[str, str]]
Return available templates in discovery order.
Source code in src/texsmith/core/templates/loader.py
220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 | |
load_template ¶
load_template(identifier: str) -> WrappableTemplate
Load a template selected by name or filesystem path.
Source code in src/texsmith/core/templates/loader.py
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | |
Pydantic models describing LATEX template manifests.
CompatInfo ¶
Bases: BaseModel
Compatibility constraints declared by the template.
LatexSection ¶
Bases: BaseModel
Section grouping LATEX-specific manifest settings.
TemplateAsset ¶
Bases: BaseModel
Description of individual template assets.
TemplateAttributeResolver ¶
TemplateAttributeResolver(
specs: Mapping[str, TemplateAttributeSpec],
)
Resolve attribute values from overrides using a typed specification.
Source code in src/texsmith/core/templates/manifest.py
657 658 | |
TemplateAttributeSpec ¶
Bases: BaseModel
Typed attribute definition used to build template defaults.
default_value ¶
default_value() -> Any
Return a deep copy of the attribute default.
Source code in src/texsmith/core/templates/manifest.py
511 512 513 | |
TemplateError ¶
Bases: LatexRenderingError
Raised when a LATEX template cannot be loaded or rendered.
TemplateInfo ¶
Bases: BaseModel
Metadata describing the LATEX template payload.
attribute_defaults ¶
attribute_defaults() -> dict[str, Any]
Return a deep copy of template attribute defaults.
Source code in src/texsmith/core/templates/manifest.py
785 786 787 | |
attribute_owners ¶
attribute_owners() -> dict[str, str]
Return attribute ownership map (name -> owner).
Source code in src/texsmith/core/templates/manifest.py
800 801 802 | |
emit_defaults ¶
emit_defaults() -> dict[str, Any]
Return default attributes emitted by the template.
Source code in src/texsmith/core/templates/manifest.py
789 790 791 | |
resolve_attributes ¶
resolve_attributes(
overrides: Mapping[str, Any] | None = None,
) -> dict[str, Any]
Return defaults merged with overrides using the attribute specification.
Source code in src/texsmith/core/templates/manifest.py
796 797 798 | |
resolve_slots ¶
resolve_slots() -> tuple[dict[str, TemplateSlot], str]
Return declared slots ensuring a single default sink exists.
Source code in src/texsmith/core/templates/manifest.py
765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 | |
TemplateManifest ¶
Bases: BaseModel
Structured manifest describing a LATEX template.
load
classmethod
¶
load(manifest_path: Path) -> TemplateManifest
Load and validate a manifest from disk.
Source code in src/texsmith/core/templates/manifest.py
817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 | |
TemplateSlot ¶
Bases: BaseModel
Configuration describing how content is injected into a template slot.
resolve_level ¶
resolve_level(fallback: int) -> int
Return the base level applied to rendered headings for this slot.
Source code in src/texsmith/core/templates/manifest.py
123 124 125 126 127 128 129 130 | |
Runtime helpers for binding LATEX templates to rendered documents.
TemplateBinding
dataclass
¶
TemplateBinding(
runtime: TemplateRuntime | None,
instance: WrappableTemplate | None,
name: str | None,
engine: str | None,
requires_shell_escape: bool,
formatter_overrides: dict[str, Path],
slots: dict[str, TemplateSlot],
default_slot: str,
base_level: int | None,
required_partials: set[str] = set(),
)
Binding between slot requests and a LATEX template.
apply_formatter_overrides ¶
apply_formatter_overrides(
formatter: "LaTeXFormatter",
) -> None
Apply template-provided overrides to a formatter.
Source code in src/texsmith/core/templates/runtime.py
61 62 63 64 | |
slot_levels ¶
slot_levels(*, offset: int = 0) -> dict[str, int]
Return the resolved base level for each slot.
Source code in src/texsmith/core/templates/runtime.py
56 57 58 59 | |
TemplateRuntime
dataclass
¶
TemplateRuntime(
instance: WrappableTemplate,
name: str,
engine: str | None,
requires_shell_escape: bool,
slots: dict[str, TemplateSlot],
default_slot: str,
formatter_overrides: dict[str, Path],
base_level: int | None,
required_partials: set[str] = set(),
extras: dict[str, Any] = dict(),
)
Resolved template metadata reused across conversions.
build_template_overrides ¶
build_template_overrides(
front_matter: Mapping[str, Any] | None,
) -> dict[str, Any]
Build template overrides from front matter while preserving metadata.
Source code in src/texsmith/core/templates/runtime.py
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 | |
coerce_base_level ¶
coerce_base_level(
value: Any, *, allow_none: bool = True
) -> int | None
Normalise base-level metadata to an integer or None.
Source code in src/texsmith/core/templates/runtime.py
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | |
extract_base_level_override ¶
extract_base_level_override(
overrides: Mapping[str, Any] | None,
) -> Any
Extract a base level override from template metadata overrides.
Source code in src/texsmith/core/templates/runtime.py
107 108 109 110 111 112 113 114 115 116 117 118 | |
extract_language_from_front_matter ¶
extract_language_from_front_matter(
front_matter: Mapping[str, Any] | None,
) -> str | None
Inspect front matter for language hints.
Source code in src/texsmith/core/templates/runtime.py
161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 | |
load_template_runtime ¶
load_template_runtime(template: str) -> TemplateRuntime
Resolve template metadata for repeated conversions.
Source code in src/texsmith/core/templates/runtime.py
228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 | |
normalise_template_language ¶
normalise_template_language(
value: str | None,
) -> str | None
Normalise language codes and map them through babel aliases when available.
Source code in src/texsmith/core/templates/runtime.py
186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 | |
resolve_template_binding ¶
resolve_template_binding(
*,
template: str | None,
template_runtime: TemplateRuntime | None,
template_overrides: Mapping[str, Any],
slot_requests: Mapping[str, str],
warn: Callable[[str], None] | None = None,
) -> tuple[TemplateBinding, dict[str, str]]
Resolve template runtime metadata and apply slot overrides.
Source code in src/texsmith/core/templates/runtime.py
262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 | |
resolve_template_language ¶
resolve_template_language(
explicit: str | None,
front_matter: Mapping[str, Any] | None,
) -> str
Resolve the effective template language from CLI and front matter inputs.
Source code in src/texsmith/core/templates/runtime.py
211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 | |