Improved changelog rendering
[jinja2.git] / CHANGES
1 Jinja2 Changelog
2 ================
3
4 Version 2.2
5 -----------
6 (codename unknown, release date yet unknown)
7
8 - Include statements can now be marked with ``ignore missing`` to skip
9   non existing templates.
10 - Priority of `not` raised.  It's now possible to write `not foo in bar`
11   as an alias to `foo not in bar` like in python.  Previously the grammar
12   required parentheses (`not (foo in bar)`) which was odd.
13 - Fixed a bug that caused syntax errors when defining macros or using the
14   `{% call %}` tag inside loops.
15 - Fixed a bug in the parser that made ``{{ foo[1, 2] }}`` impossible.
16 - Made it possible to refer to names from outer scopes in included templates
17   that were unused in the callers frame (#327)
18 - Fixed a bug that caused internal errors if names where used as iteration
19   variable and regular variable *after* the loop if that variable was unused
20   *before* the loop.  (#331)
21 - Added support for optional `scoped` modifier to blocks.
22 - Added support for line-comments.
23
24 Version 2.1.1
25 -------------
26 (Bugfix release)
27
28 - Fixed a translation error caused by looping over empty recursive loops.
29
30 Version 2.1
31 -----------
32 (codename Yasuzō, released on November 23rd 2008)
33
34 - fixed a bug with nested loops and the special loop variable.  Before the
35   change an inner loop overwrote the loop variable from the outer one after
36   iteration.
37
38 - fixed a bug with the i18n extension that caused the explicit pluralization
39   block to look up the wrong variable.
40
41 - fixed a limitation in the lexer that made ``{{ foo.0.0 }}`` impossible.
42
43 - index based subscribing of variables with a constant value returns an
44   undefined object now instead of raising an index error.  This was a bug
45   caused by eager optimizing.
46
47 - the i18n extension looks up `foo.ugettext` now followed by `foo.gettext`
48   if an translations object is installed.  This makes dealing with custom
49   translations classes easier.
50
51 - fixed a confusing behavior with conditional extending.  loops were partially
52   executed under some conditions even though they were not part of a visible
53   area.
54
55 - added `sort` filter that works like `dictsort` but for arbitrary sequences.
56
57 - fixed a bug with empty statements in macros.
58
59 - implemented a bytecode cache system.  (:ref:`bytecode-cache`)
60
61 - the template context is now weakref-able
62
63 - inclusions and imports "with context" forward all variables now, not only
64   the initial context.
65
66 - added a cycle helper called `cycler`.
67
68 - added a joining helper called `joiner`.
69
70 - added a `compile_expression` method to the environment that allows compiling
71   of Jinja expressions into callable Python objects.
72
73 - fixed an escaping bug in urlize
74
75 Version 2.0
76 -----------
77 (codename jinjavitus, released on July 17th 2008)
78
79 - the subscribing of objects (looking up attributes and items) changed from
80   slightly.  It's now possible to give attributes or items a higher priority
81   by either using dot-notation lookup or the bracket syntax.  This also
82   changed the AST slightly.  `Subscript` is gone and was replaced with
83   :class:`~jinja2.nodes.Getitem` and :class:`~jinja2.nodes.Getattr`.
84
85   For more information see :ref:`the implementation details <notes-on-subscriptions>`.
86
87 - added support for preprocessing and token stream filtering for extensions.
88   This would allow extensions to allow simplified gettext calls in template
89   data and something similar.
90
91 - added :meth:`jinja2.environment.TemplateStream.dump`.
92
93 - added missing support for implicit string literal concatenation.
94   ``{{ "foo" "bar" }}`` is equivalent to ``{{ "foobar" }}``
95
96 - `else` is optional for conditional expressions.  If not given it evaluates
97   to `false`.
98
99 - improved error reporting for undefined values by providing a position.
100
101 - `filesizeformat` filter uses decimal prefixes now per default and can be
102   set to binary mode with the second parameter.
103
104 - fixed bug in finalizer
105
106 Version 2.0rc1
107 --------------
108 (no codename, released on June 9th 2008)
109
110 - first release of Jinja2