-Jinja Changelog
-===============
+Jinja2 Changelog
+================
-Version 1.1
+Version 2.4
-----------
(codename to be selected, release date unknown)
-- blocks now support ``{{ super() }}`` to render the parent output.
+- the environment template loading functions now transparently
+ pass through a template object if it was passed to it. This
+ makes it possible to import or extend from a template object
+ that was passed to the template.
+- added a :class:`ModuleLoader` that can load templates from
+ precompiled sources. The environment now features a method
+ to compile the templates from a configured loader into a zip
+ file or folder.
-- debugging system improved, smaller filesize for the cached files.
- Debugging works now well for any module using linecache.
+- the _speedups C extension now supports Python 3.
-- ``{{ debug() }}`` can now be used to get a list of filters and
- tags.
+Version 2.3.1
+-------------
+(bugfix release, released on February 19th 2010)
-- the template lexer keeps not track of brace, parenthesis and
- bracket balance in order to not break variable tags apart if they
- are configured to look like this: ``${expr}``. This also fixes
- the problem with nested dicts in variable expressions.
+- fixed an error reporting bug on all python versions
+- fixed an error reporting bug on Python 2.4
-- it's now possible to configure the variable blocks to look the
- same as the block delimiters. Thus you can set the syntax to something
- like ``{ / }`` for both blocks and variables.
-
-- added whitespace management system for the template designer.
-
-- some small bugfixes.
-
-- improved security system regarding function calls and variable
- assignment in for loops.
-
-- added `lipsum` function to generate random text.
-
-- strings without unicode characters are processed as binary strings now
- to workaround problems with `datetime.strftime` which only accepts
- binary strings.
-
-- it's now possible to use newlines in string literals
+Version 2.3
+-----------
+(3000 Pythons, released on February 10th 2010)
+
+- fixes issue with code generator that causes unbound variables
+ to be generated if set was used in if-blocks and other small
+ identifier problems.
+- include tags are now able to select between multiple templates
+ and take the first that exists, if a list of templates is
+ given.
+- fixed a problem with having call blocks in outer scopes that
+ have an argument that is also used as local variable in an
+ inner frame (#360).
+- greatly improved error message reporting (#339)
+- implicit tuple expressions can no longer be totally empty.
+ This change makes ``{% if %}...{% endif %}`` a syntax error
+ now. (#364)
+- added support for translator comments if extracted via babel.
+- added with-statement extension.
+- experimental Python 3 support.
+
+Version 2.2.1
+-------------
+(bugfix release, released on September 14th 2009)
+
+- fixes some smaller problems for Jinja2 on Jython.
+
+Version 2.2
+-----------
+(codename Kong, released on September 13th 2009)
+
+- Include statements can now be marked with ``ignore missing`` to skip
+ non existing templates.
+- Priority of `not` raised. It's now possible to write `not foo in bar`
+ as an alias to `foo not in bar` like in python. Previously the grammar
+ required parentheses (`not (foo in bar)`) which was odd.
+- Fixed a bug that caused syntax errors when defining macros or using the
+ `{% call %}` tag inside loops.
+- Fixed a bug in the parser that made ``{{ foo[1, 2] }}`` impossible.
+- Made it possible to refer to names from outer scopes in included templates
+ that were unused in the callers frame (#327)
+- Fixed a bug that caused internal errors if names where used as iteration
+ variable and regular variable *after* the loop if that variable was unused
+ *before* the loop. (#331)
+- Added support for optional `scoped` modifier to blocks.
+- Added support for line-comments.
+- Added the `meta` module.
+- Renamed (undocumented) attribute "overlay" to "overlayed" on the
+ environment because it was clashing with a method of the same name.
+- speedup extension is now disabled by default.
+
+Version 2.1.1
+-------------
+(Bugfix release)
+
+- Fixed a translation error caused by looping over empty recursive loops.
+
+Version 2.1
+-----------
+(codename Yasuzō, released on November 23rd 2008)
-- developer friendly traceback is now toggleable
+- fixed a bug with nested loops and the special loop variable. Before the
+ change an inner loop overwrote the loop variable from the outer one after
+ iteration.
-- the variable failure is now pluggable by replacing the undefined
- singleton for an environment instance
+- fixed a bug with the i18n extension that caused the explicit pluralization
+ block to look up the wrong variable.
-- fixed issue with old-style classes not implementing `__getitem__`
- (thanks to Axel Böhm for discovering that bug)
+- fixed a limitation in the lexer that made ``{{ foo.0.0 }}`` impossible.
-- added a bunch of new docstrings to the Jinja classes. Makes fun now to
- use pydoc :-)
+- index based subscribing of variables with a constant value returns an
+ undefined object now instead of raising an index error. This was a bug
+ caused by eager optimizing.
-- fixed severe memcaching bug. Formerly it wasn't possible to use memcaching
- without enabling disk cache.
+- the i18n extension looks up `foo.ugettext` now followed by `foo.gettext`
+ if an translations object is installed. This makes dealing with custom
+ translations classes easier.
-- fixed a bug that allowed users to override the special names `_`, `true` etc.
+- fixed a confusing behavior with conditional extending. loops were partially
+ executed under some conditions even though they were not part of a visible
+ area.
-- added `batch` and `slice` filters for batching or slicing sequences
+- added `sort` filter that works like `dictsort` but for arbitrary sequences.
-- added `sum`, `abs` and `round` filters. This fixes #238
+- fixed a bug with empty statements in macros.
-- added `striptags` and `xmlattr` filters for easier SGML/XML processing
+- implemented a bytecode cache system. (:ref:`bytecode-cache`)
-- the trans tag does not need explicit naming for variables with the same
- name any more. You can now use ``{% trans foo %}`` instead of the verbose
- version ``{% trans foo=foo %}``.
+- the template context is now weakref-able
-- reimplemented Buffet plugin so that it works at least for pylons
+- inclusions and imports "with context" forward all variables now, not only
+ the initial context.
-- added `Environment.get_translations_for_string`
+- added a cycle helper called `cycler`.
-- fixed a bug in the parser that didn't unescape keyword arguments. (thanks
- to Alexey Melchakov for reporting)
+- added a joining helper called `joiner`.
-- You can now use the environment to just tokenize a template. This can
- be useful for syntax highlighting or other purposes.
+- added a `compile_expression` method to the environment that allows compiling
+ of Jinja expressions into callable Python objects.
-- added optional C-implementation of the context baseclass.
+- fixed an escaping bug in urlize
-- you can now use optional parentheses around macro defintions. Thus it's
- possible to write ``{% macro foo(a, b, c) %}`` instead of ``{% macro
- foo a, b, c %}``.
+Version 2.0
+-----------
+(codename jinjavitus, released on July 17th 2008)
-- additional macro arguments now end up in `varargs`.
+- the subscribing of objects (looking up attributes and items) changed from
+ slightly. It's now possible to give attributes or items a higher priority
+ by either using dot-notation lookup or the bracket syntax. This also
+ changed the AST slightly. `Subscript` is gone and was replaced with
+ :class:`~jinja2.nodes.Getitem` and :class:`~jinja2.nodes.Getattr`.
-- implemented the `{% call %}` block. `call` and `endcall` can still be used
- as identifiers until Jinja 1.3
+ For more information see :ref:`the implementation details <notes-on-subscriptions>`.
-- it's not possible to stream templates.
+- added support for preprocessing and token stream filtering for extensions.
+ This would allow extensions to allow simplified gettext calls in template
+ data and something similar.
-- fixed a corner case when defining a block inside of a condition
+- added :meth:`jinja2.environment.TemplateStream.dump`.
-- the cached loader mixin is now able to cache multiple templates from
- different loaders in the same cache folder.
+- added missing support for implicit string literal concatenation.
+ ``{{ "foo" "bar" }}`` is equivalent to ``{{ "foobar" }}``
-- Translatable strings returned by ``_()`` will leave their string formatting
- signs untouched. Thanks to Stefan Ebner for reporting.
+- `else` is optional for conditional expressions. If not given it evaluates
+ to `false`.
-- ``{% block name "data" %}`` is now an alias for
- ``{% block name %}data{% endblock %}``. Note that the second argument can
- be an expression. As soon as you specify an expression as second argument
- the closing tag has to be omitted.
+- improved error reporting for undefined values by providing a position.
-- It's now possible to iterate over iterators additionally to sequences.
- If the iterator is inifite it will crash however, so makes sure you don't
- pass something like that to a template!
+- `filesizeformat` filter uses decimal prefixes now per default and can be
+ set to binary mode with the second parameter.
+- fixed bug in finalizer
-Version 1.0
------------
-(released Mar 23, 2007)
+Version 2.0rc1
+--------------
+(no codename, released on June 9th 2008)
-- Initial release
+- first release of Jinja2