summaryrefslogtreecommitdiff
path: root/deps/v8/third_party/jinja2/tests.py
diff options
context:
space:
mode:
Diffstat (limited to 'deps/v8/third_party/jinja2/tests.py')
-rw-r--r--deps/v8/third_party/jinja2/tests.py114
1 files changed, 77 insertions, 37 deletions
diff --git a/deps/v8/third_party/jinja2/tests.py b/deps/v8/third_party/jinja2/tests.py
index fabd4ce51b..a467cf08b5 100644
--- a/deps/v8/third_party/jinja2/tests.py
+++ b/deps/v8/third_party/jinja2/tests.py
@@ -1,36 +1,32 @@
-# -*- coding: utf-8 -*-
"""Built-in template tests used with the ``is`` operator."""
-import decimal
import operator
-import re
+import typing as t
+from collections import abc
+from numbers import Number
-from ._compat import abc
-from ._compat import integer_types
-from ._compat import string_types
-from ._compat import text_type
from .runtime import Undefined
+from .utils import pass_environment
-number_re = re.compile(r"^-?\d+(\.\d+)?$")
-regex_type = type(number_re)
-test_callable = callable
+if t.TYPE_CHECKING:
+ from .environment import Environment
-def test_odd(value):
+def test_odd(value: int) -> bool:
"""Return true if the variable is odd."""
return value % 2 == 1
-def test_even(value):
+def test_even(value: int) -> bool:
"""Return true if the variable is even."""
return value % 2 == 0
-def test_divisibleby(value, num):
+def test_divisibleby(value: int, num: int) -> bool:
"""Check if a variable is divisible by a number."""
return value % num == 0
-def test_defined(value):
+def test_defined(value: t.Any) -> bool:
"""Return true if the variable is defined:
.. sourcecode:: jinja
@@ -47,17 +43,57 @@ def test_defined(value):
return not isinstance(value, Undefined)
-def test_undefined(value):
+def test_undefined(value: t.Any) -> bool:
"""Like :func:`defined` but the other way round."""
return isinstance(value, Undefined)
-def test_none(value):
+@pass_environment
+def test_filter(env: "Environment", value: str) -> bool:
+ """Check if a filter exists by name. Useful if a filter may be
+ optionally available.
+
+ .. code-block:: jinja
+
+ {% if 'markdown' is filter %}
+ {{ value | markdown }}
+ {% else %}
+ {{ value }}
+ {% endif %}
+
+ .. versionadded:: 3.0
+ """
+ return value in env.filters
+
+
+@pass_environment
+def test_test(env: "Environment", value: str) -> bool:
+ """Check if a test exists by name. Useful if a test may be
+ optionally available.
+
+ .. code-block:: jinja
+
+ {% if 'loud' is test %}
+ {% if value is loud %}
+ {{ value|upper }}
+ {% else %}
+ {{ value|lower }}
+ {% endif %}
+ {% else %}
+ {{ value }}
+ {% endif %}
+
+ .. versionadded:: 3.0
+ """
+ return value in env.tests
+
+
+def test_none(value: t.Any) -> bool:
"""Return true if the variable is none."""
return value is None
-def test_boolean(value):
+def test_boolean(value: t.Any) -> bool:
"""Return true if the object is a boolean value.
.. versionadded:: 2.11
@@ -65,7 +101,7 @@ def test_boolean(value):
return value is True or value is False
-def test_false(value):
+def test_false(value: t.Any) -> bool:
"""Return true if the object is False.
.. versionadded:: 2.11
@@ -73,7 +109,7 @@ def test_false(value):
return value is False
-def test_true(value):
+def test_true(value: t.Any) -> bool:
"""Return true if the object is True.
.. versionadded:: 2.11
@@ -82,16 +118,16 @@ def test_true(value):
# NOTE: The existing 'number' test matches booleans and floats
-def test_integer(value):
+def test_integer(value: t.Any) -> bool:
"""Return true if the object is an integer.
.. versionadded:: 2.11
"""
- return isinstance(value, integer_types) and value is not True and value is not False
+ return isinstance(value, int) and value is not True and value is not False
# NOTE: The existing 'number' test matches booleans and integers
-def test_float(value):
+def test_float(value: t.Any) -> bool:
"""Return true if the object is a float.
.. versionadded:: 2.11
@@ -99,22 +135,22 @@ def test_float(value):
return isinstance(value, float)
-def test_lower(value):
+def test_lower(value: str) -> bool:
"""Return true if the variable is lowercased."""
- return text_type(value).islower()
+ return str(value).islower()
-def test_upper(value):
+def test_upper(value: str) -> bool:
"""Return true if the variable is uppercased."""
- return text_type(value).isupper()
+ return str(value).isupper()
-def test_string(value):
+def test_string(value: t.Any) -> bool:
"""Return true if the object is a string."""
- return isinstance(value, string_types)
+ return isinstance(value, str)
-def test_mapping(value):
+def test_mapping(value: t.Any) -> bool:
"""Return true if the object is a mapping (dict etc.).
.. versionadded:: 2.6
@@ -122,12 +158,12 @@ def test_mapping(value):
return isinstance(value, abc.Mapping)
-def test_number(value):
+def test_number(value: t.Any) -> bool:
"""Return true if the variable is a number."""
- return isinstance(value, integer_types + (float, complex, decimal.Decimal))
+ return isinstance(value, Number)
-def test_sequence(value):
+def test_sequence(value: t.Any) -> bool:
"""Return true if the variable is a sequence. Sequences are variables
that are iterable.
"""
@@ -136,10 +172,11 @@ def test_sequence(value):
value.__getitem__
except Exception:
return False
+
return True
-def test_sameas(value, other):
+def test_sameas(value: t.Any, other: t.Any) -> bool:
"""Check if an object points to the same memory address than another
object:
@@ -152,21 +189,22 @@ def test_sameas(value, other):
return value is other
-def test_iterable(value):
+def test_iterable(value: t.Any) -> bool:
"""Check if it's possible to iterate over an object."""
try:
iter(value)
except TypeError:
return False
+
return True
-def test_escaped(value):
+def test_escaped(value: t.Any) -> bool:
"""Check if the value is escaped."""
return hasattr(value, "__html__")
-def test_in(value, seq):
+def test_in(value: t.Any, seq: t.Container) -> bool:
"""Check if value is in seq.
.. versionadded:: 2.10
@@ -180,6 +218,8 @@ TESTS = {
"divisibleby": test_divisibleby,
"defined": test_defined,
"undefined": test_undefined,
+ "filter": test_filter,
+ "test": test_test,
"none": test_none,
"boolean": test_boolean,
"false": test_false,
@@ -193,7 +233,7 @@ TESTS = {
"number": test_number,
"sequence": test_sequence,
"iterable": test_iterable,
- "callable": test_callable,
+ "callable": callable,
"sameas": test_sameas,
"escaped": test_escaped,
"in": test_in,