forked from typeddjango/django-stubs
-
Notifications
You must be signed in to change notification settings - Fork 63
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Improve types around template rendering (#258)
Big improvements here are: - `template.Template.render` now returns `SafeText` instead of `Any`. - [`DjangoDivFormRenderer`](https://docs.djangoproject.com/en/4.2/ref/forms/renderers/#django.forms.renderers.DjangoDivFormRenderer) and [`Jinja2DivFormRenderer`](https://docs.djangoproject.com/en/4.2/ref/forms/renderers/#django.forms.renderers.Jinja2DivFormRenderer) in `forms.renderers`. - A `template.backends.base._BaseTemplate` [protocol class](https://docs.python.org/3/library/typing.html#typing.Protocol) that imitates the abstract [`BaseTemplate` class from DEP 182](https://github.com/django/deps/blob/main/final/0182-multiple-template-engines.rst#backends-api). This is needed because there is no real parent class from which each template backend inherits from, they implement their own `Template` classes from scratch. So, `BaseEngine` needed a return type for its abstract methods, which is what `_BaseTemplate` provides. Other changes include reducing repetition, adding more specific Template types for the different backends, using more generic `Mapping` type instead of `dict` for template contexts.
- Loading branch information
1 parent
d826549
commit b36b99f
Showing
8 changed files
with
94 additions
and
40 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,27 +1,40 @@ | ||
from collections.abc import Mapping | ||
from typing import Any | ||
from typing_extensions import override | ||
|
||
from django.template import Template | ||
from django.template.backends.base import BaseEngine | ||
from django.http.request import HttpRequest | ||
from django.template.backends.base import BaseEngine, _BaseTemplate | ||
from django.template.backends.django import Template as DjangoTemplate | ||
from django.template.backends.jinja2 import Template as Jinja2Template | ||
from django.utils.safestring import SafeText | ||
|
||
ROOT: Any | ||
|
||
def get_default_renderer() -> DjangoTemplates: ... | ||
def get_default_renderer() -> BaseRenderer: ... | ||
|
||
class BaseRenderer: | ||
def get_template(self, template_name: str) -> Any: ... | ||
form_template_name: str | ||
formset_template_name: str | ||
def get_template(self, template_name: str) -> _BaseTemplate: ... | ||
def render( | ||
self, template_name: str, context: dict[str, Any], request: None = ... | ||
) -> str: ... | ||
self, | ||
template_name: str, | ||
context: Mapping[str, Any], | ||
request: HttpRequest | None = ..., | ||
) -> SafeText: ... | ||
|
||
class EngineMixin: | ||
def get_template(self, template_name: str) -> Any: ... | ||
backend: BaseEngine | ||
def get_template(self, template_name: str) -> _BaseTemplate: ... | ||
@property | ||
def engine(self) -> BaseEngine: ... | ||
|
||
class DjangoTemplates(EngineMixin, BaseRenderer): | ||
backend: Any = ... | ||
@override | ||
def get_template(self, template_name: str) -> DjangoTemplate: ... | ||
|
||
class Jinja2(EngineMixin, BaseRenderer): | ||
backend: Any = ... | ||
@override | ||
def get_template(self, template_name: str) -> Jinja2Template: ... | ||
|
||
class TemplatesSetting(BaseRenderer): | ||
def get_template(self, template_name: str) -> Template: ... | ||
class DjangoDivFormRenderer(DjangoTemplates): ... | ||
class Jinja2DivFormRenderer(Jinja2): ... | ||
class TemplatesSetting(BaseRenderer): ... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,17 +1,26 @@ | ||
from collections.abc import Iterator, Mapping | ||
from typing import Any | ||
from typing import Any, Protocol | ||
|
||
from django.template.base import Template | ||
from django.http.request import HttpRequest | ||
from django.utils.safestring import SafeText | ||
|
||
# Source: https://github.com/django/deps/blob/main/final/0182-multiple-template-engines.rst#backends-api | ||
class _BaseTemplate(Protocol): | ||
def render( | ||
self, | ||
context: Mapping[str, Any] | None = ..., | ||
request: HttpRequest | None = ..., | ||
) -> SafeText | str: ... | ||
|
||
class BaseEngine: | ||
name: str = ... | ||
dirs: list[str] = ... | ||
app_dirs: bool = ... | ||
def __init__(self, params: Mapping[str, Any]) -> None: ... | ||
@property | ||
def app_dirname(self) -> str | None: ... | ||
def from_string(self, template_code: str) -> Template: ... | ||
def get_template(self, template_name: str) -> Template | None: ... | ||
def app_dirname(self) -> str: ... | ||
def from_string(self, template_code: str) -> _BaseTemplate: ... | ||
def get_template(self, template_name: str) -> _BaseTemplate: ... | ||
@property | ||
def template_dirs(self) -> tuple[str]: ... | ||
def iter_template_filenames(self, template_name: str) -> Iterator[str]: ... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,20 +1,21 @@ | ||
import string | ||
from collections.abc import Mapping | ||
from typing import Any | ||
from typing_extensions import override | ||
|
||
from django.http.request import HttpRequest | ||
|
||
from .base import BaseEngine | ||
|
||
class TemplateStrings(BaseEngine): | ||
template_dirs: tuple[str] | ||
def __init__( | ||
self, params: dict[str, dict[Any, Any] | list[Any] | bool | str] | ||
) -> None: ... | ||
@override | ||
def from_string(self, template_code: str) -> Template: ... | ||
@override | ||
def get_template(self, template_name: str) -> Template: ... | ||
|
||
class Template(string.Template): | ||
template: str | ||
def render( | ||
self, | ||
context: dict[str, str] | None = ..., | ||
context: Mapping[str, Any] | None = ..., | ||
request: HttpRequest | None = ..., | ||
) -> str: ... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,9 @@ | ||
from typing import Any | ||
from collections.abc import Callable | ||
|
||
from django.http.request import HttpRequest | ||
from django.utils.safestring import SafeText | ||
|
||
def csrf_input(request: HttpRequest) -> SafeText: ... | ||
|
||
csrf_input_lazy: Any | ||
csrf_token_lazy: Any | ||
csrf_input_lazy: Callable[[HttpRequest], SafeText] | ||
csrf_token_lazy: Callable[[HttpRequest], SafeText] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,20 +1,21 @@ | ||
from typing import Any | ||
|
||
from django.http.request import HttpRequest | ||
from django.template.backends.django import Template | ||
from django.template.backends.base import _BaseTemplate | ||
from django.template.exceptions import ( # noqa: F401 | ||
TemplateDoesNotExist as TemplateDoesNotExist, | ||
) | ||
from django.utils.safestring import SafeText | ||
|
||
from . import engines as engines # noqa: F401 | ||
|
||
def get_template(template_name: str, using: str | None = ...) -> Template: ... | ||
def get_template(template_name: str, using: str | None = ...) -> _BaseTemplate: ... | ||
def select_template( | ||
template_name_list: list[str] | str, using: str | None = ... | ||
) -> Template: ... | ||
) -> _BaseTemplate: ... | ||
def render_to_string( | ||
template_name: list[str] | str, | ||
context: dict[str, Any] | None = ..., | ||
request: HttpRequest | None = ..., | ||
using: str | None = ..., | ||
) -> str: ... | ||
) -> SafeText: ... |