CHANGELOG 24KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492
  1. * 1.7.0 (2012-04-24)
  2. * fixed template line number in some exceptions
  3. * added an iterable test
  4. * added an error when defining two blocks with the same name in a template
  5. * added the preserves_safety option for filters
  6. * fixed a PHP notice when trying to access a key on a non-object/array variable
  7. * enhanced error reporting when the template file is an instance of SplFileInfo
  8. * added Twig_Environment::mergeGlobals()
  9. * added compilation checks to avoid misuses of the sandbox tag
  10. * fixed filesystem loader freshness logic for high traffic websites
  11. * fixed random function when charset is null
  12. * 1.6.5 (2012-04-11)
  13. * fixed a regression when a template only extends another one without defining any blocks
  14. * 1.6.4 (2012-04-02)
  15. * fixed PHP notice in Twig_Error::guessTemplateLine() introduced in 1.6.3
  16. * fixed performance when compiling large files
  17. * optimized parent template creation when the template does not use dynamic inheritance
  18. * 1.6.3 (2012-03-22)
  19. * fixed usage of Z_ADDREF_P for PHP 5.2 in the C extension
  20. * fixed compilation of numeric values used in templates when using a locale where the decimal separator is not a dot
  21. * made the strategy used to guess the real template file name and line number in exception messages much faster and more accurate
  22. * 1.6.2 (2012-03-18)
  23. * fixed sandbox mode when used with inheritance
  24. * added preserveKeys support for the slice filter
  25. * fixed the date filter when a DateTime instance is passed with a specific timezone
  26. * added a trim filter
  27. * 1.6.1 (2012-02-29)
  28. * fixed Twig C extension
  29. * removed the creation of Twig_Markup instances when not needed
  30. * added a way to set the default global timezone for dates
  31. * fixed the slice filter on strings when the length is not specified
  32. * fixed the creation of the cache directory in case of a race condition
  33. * 1.6.0 (2012-02-04)
  34. * fixed raw blocks when used with the whitespace trim option
  35. * made a speed optimization to macro calls when imported via the "from" tag
  36. * fixed globals, parsers, visitors, filters, tests, and functions management in Twig_Environment when a new one or new extension is added
  37. * fixed the attribute function when passing arguments
  38. * added slice notation support for the [] operator (syntactic sugar for the slice operator)
  39. * added a slice filter
  40. * added string support for the reverse filter
  41. * fixed the empty test and the length filter for Twig_Markup instances
  42. * added a date function to ease date comparison
  43. * fixed unary operators precedence
  44. * added recursive parsing support in the parser
  45. * added string and integer handling for the random function
  46. * 1.5.1 (2012-01-05)
  47. * fixed a regression when parsing strings
  48. * 1.5.0 (2012-01-04)
  49. * added Traversable objects support for the join filter
  50. * 1.5.0-RC2 (2011-12-30)
  51. * added a way to set the default global date interval format
  52. * fixed the date filter for DateInterval instances (setTimezone() does not exist for them)
  53. * refactored Twig_Template::display() to ease its extension
  54. * added a number_format filter
  55. * 1.5.0-RC1 (2011-12-26)
  56. * removed the need to quote hash keys
  57. * allowed hash keys to be any expression
  58. * added a do tag
  59. * added a flush tag
  60. * added support for dynamically named filters and functions
  61. * added a dump function to help debugging templates
  62. * added a nl2br filter
  63. * added a random function
  64. * added a way to change the default format for the date filter
  65. * fixed the lexer when an operator ending with a letter ends a line
  66. * added string interpolation support
  67. * enhanced exceptions for unknown filters, functions, tests, and tags
  68. * 1.4.0 (2011-12-07)
  69. * fixed lexer when using big numbers (> PHP_INT_MAX)
  70. * added missing preserveKeys argument to the reverse filter
  71. * fixed macros containing filter tag calls
  72. * 1.4.0-RC2 (2011-11-27)
  73. * removed usage of Reflection in Twig_Template::getAttribute()
  74. * added a C extension that can optionally replace Twig_Template::getAttribute()
  75. * added negative timestamp support to the date filter
  76. * 1.4.0-RC1 (2011-11-20)
  77. * optimized variable access when using PHP 5.4
  78. * changed the precedence of the .. operator to be more consistent with languages that implements such a feature like Ruby
  79. * added an Exception to Twig_Loader_Array::isFresh() method when the template does not exist to be consistent with other loaders
  80. * added Twig_Function_Node to allow more complex functions to have their own Node class
  81. * added Twig_Filter_Node to allow more complex filters to have their own Node class
  82. * added Twig_Test_Node to allow more complex tests to have their own Node class
  83. * added a better error message when a template is empty but contain a BOM
  84. * fixed "in" operator for empty strings
  85. * fixed the "defined" test and the "default" filter (now works with more than one call (foo.bar.foo) and for both values of the strict_variables option)
  86. * changed the way extensions are loaded (addFilter/addFunction/addGlobal/addTest/addNodeVisitor/addTokenParser/addExtension can now be called in any order)
  87. * added Twig_Environment::display()
  88. * made the escape filter smarter when the encoding is not supported by PHP
  89. * added a convert_encoding filter
  90. * moved all node manipulations outside the compile() Node method
  91. * made several speed optimizations
  92. * 1.3.0 (2011-10-08)
  93. no changes
  94. * 1.3.0-RC1 (2011-10-04)
  95. * added an optimization for the parent() function
  96. * added cache reloading when auto_reload is true and an extension has been modified
  97. * added the possibility to force the escaping of a string already marked as safe (instance of Twig_Markup)
  98. * allowed empty templates to be used as traits
  99. * added traits support for the "parent" function
  100. * 1.2.0 (2011-09-13)
  101. no changes
  102. * 1.2.0-RC1 (2011-09-10)
  103. * enhanced the exception when a tag remains unclosed
  104. * added support for empty Countable objects for the "empty" test
  105. * fixed algorithm that determines if a template using inheritance is valid (no output between block definitions)
  106. * added better support for encoding problems when escaping a string (available as of PHP 5.4)
  107. * added a way to ignore a missing template when using the "include" tag ({% include "foo" ignore missing %})
  108. * added support for an array of templates to the "include" and "extends" tags ({% include ['foo', 'bar'] %})
  109. * added support for bitwise operators in expressions
  110. * added the "attribute" function to allow getting dynamic attributes on variables
  111. * added Twig_Loader_Chain
  112. * added Twig_Loader_Array::setTemplate()
  113. * added an optimization for the set tag when used to capture a large chunk of static text
  114. * changed name regex to match PHP one "[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*" (works for blocks, tags, functions, filters, and macros)
  115. * removed the possibility to use the "extends" tag from a block
  116. * added "if" modifier support to "for" loops
  117. * 1.1.2 (2011-07-30)
  118. * fixed json_encode filter on PHP 5.2
  119. * fixed regression introduced in 1.1.1 ({{ block(foo|lower) }})
  120. * fixed inheritance when using conditional parents
  121. * fixed compilation of templates when the body of a child template is not empty
  122. * fixed output when a macro throws an exception
  123. * fixed a parsing problem when a large chunk of text is enclosed in a comment tag
  124. * added PHPDoc for all Token parsers and Core extension functions
  125. * 1.1.1 (2011-07-17)
  126. * added a performance optimization in the Optimizer (also helps to lower the number of nested level calls)
  127. * made some performance improvement for some edge cases
  128. * 1.1.0 (2011-06-28)
  129. * fixed json_encode filter
  130. * 1.1.0-RC3 (2011-06-24)
  131. * fixed method case-sensitivity when using the sandbox mode
  132. * added timezone support for the date filter
  133. * fixed possible security problems with NUL bytes
  134. * 1.1.0-RC2 (2011-06-16)
  135. * added an exception when the template passed to "use" is not a string
  136. * made 'a.b is defined' not throw an exception if a is not defined (in strict mode)
  137. * added {% line \d+ %} directive
  138. * 1.1.0-RC1 (2011-05-28)
  139. Flush your cache after upgrading.
  140. * fixed date filter when using a timestamp
  141. * fixed the defined test for some cases
  142. * fixed a parsing problem when a large chunk of text is enclosed in a raw tag
  143. * added support for horizontal reuse of template blocks (see docs for more information)
  144. * added whitespace control modifier to all tags (see docs for more information)
  145. * added null as an alias for none (the null test is also an alias for the none test now)
  146. * made TRUE, FALSE, NONE equivalent to their lowercase counterparts
  147. * wrapped all compilation and runtime exceptions with Twig_Error_Runtime and added logic to guess the template name and line
  148. * moved display() method to Twig_Template (generated templates should now use doDisplay() instead)
  149. * 1.0.0 (2011-03-27)
  150. * fixed output when using mbstring
  151. * fixed duplicate call of methods when using the sandbox
  152. * made the charset configurable for the escape filter
  153. * 1.0.0-RC2 (2011-02-21)
  154. * changed the way {% set %} works when capturing (the content is now marked as safe)
  155. * added support for macro name in the endmacro tag
  156. * make Twig_Error compatible with PHP 5.3.0 >
  157. * fixed an infinite loop on some Windows configurations
  158. * fixed the "length" filter for numbers
  159. * fixed Template::getAttribute() as properties in PHP are case sensitive
  160. * removed coupling between Twig_Node and Twig_Template
  161. * fixed the ternary operator precedence rule
  162. * 1.0.0-RC1 (2011-01-09)
  163. Backward incompatibilities:
  164. * the "items" filter, which has been deprecated for quite a long time now, has been removed
  165. * the "range" filter has been converted to a function: 0|range(10) -> range(0, 10)
  166. * the "constant" filter has been converted to a function: {{ some_date|date('DATE_W3C'|constant) }} -> {{ some_date|date(constant('DATE_W3C')) }}
  167. * the "cycle" filter has been converted to a function: {{ ['odd', 'even']|cycle(i) }} -> {{ cycle(['odd', 'even'], i) }}
  168. * the "for" tag does not support "joined by" anymore
  169. * the "autoescape" first argument is now "true"/"false" (instead of "on"/"off")
  170. * the "parent" tag has been replaced by a "parent" function ({{ parent() }} instead of {% parent %})
  171. * the "display" tag has been replaced by a "block" function ({{ block('title') }} instead of {% display title %})
  172. * removed the grammar and simple token parser (moved to the Twig Extensions repository)
  173. Changes:
  174. * added "needs_context" option for filters and functions (the context is then passed as a first argument)
  175. * added global variables support
  176. * made macros return their value instead of echoing directly (fixes calling a macro in sandbox mode)
  177. * added the "from" tag to import macros as functions
  178. * added support for functions (a function is just syntactic sugar for a getAttribute() call)
  179. * made macros callable when sandbox mode is enabled
  180. * added an exception when a macro uses a reserved name
  181. * the "default" filter now uses the "empty" test instead of just checking for null
  182. * added the "empty" test
  183. * 0.9.10 (2010-12-16)
  184. Backward incompatibilities:
  185. * The Escaper extension is enabled by default, which means that all displayed
  186. variables are now automatically escaped. You can revert to the previous
  187. behavior by removing the extension via $env->removeExtension('escaper')
  188. or just set the 'autoescape' option to 'false'.
  189. * removed the "without loop" attribute for the "for" tag (not needed anymore
  190. as the Optimizer take care of that for most cases)
  191. * arrays and hashes have now a different syntax
  192. * arrays keep the same syntax with square brackets: [1, 2]
  193. * hashes now use curly braces (["a": "b"] should now be written as {"a": "b"})
  194. * support for "arrays with keys" and "hashes without keys" is not supported anymore ([1, "foo": "bar"] or {"foo": "bar", 1})
  195. * the i18n extension is now part of the Twig Extensions repository
  196. Changes:
  197. * added the merge filter
  198. * removed 'is_escaper' option for filters (a left over from the previous version) -- you must use 'is_safe' now instead
  199. * fixed usage of operators as method names (like is, in, and not)
  200. * changed the order of execution for node visitors
  201. * fixed default() filter behavior when used with strict_variables set to on
  202. * fixed filesystem loader compatibility with PHAR files
  203. * enhanced error messages when an unexpected token is parsed in an expression
  204. * fixed filename not being added to syntax error messages
  205. * added the autoescape option to enable/disable autoescaping
  206. * removed the newline after a comment (mimicks PHP behavior)
  207. * added a syntax error exception when parent block is used on a template that does not extend another one
  208. * made the Escaper extension enabled by default
  209. * fixed sandbox extension when used with auto output escaping
  210. * fixed escaper when wrapping a Twig_Node_Print (the original class must be preserved)
  211. * added an Optimizer extension (enabled by default; optimizes "for" loops and "raw" filters)
  212. * added priority to node visitors
  213. * 0.9.9 (2010-11-28)
  214. Backward incompatibilities:
  215. * the self special variable has been renamed to _self
  216. * the odd and even filters are now tests:
  217. {{ foo|odd }} must now be written {{ foo is odd }}
  218. * the "safe" filter has been renamed to "raw"
  219. * in Node classes,
  220. sub-nodes are now accessed via getNode() (instead of property access)
  221. attributes via getAttribute() (instead of array access)
  222. * the urlencode filter had been renamed to url_encode
  223. * the include tag now merges the passed variables with the current context by default
  224. (the old behavior is still possible by adding the "only" keyword)
  225. * moved Exceptions to Twig_Error_* (Twig_SyntaxError/Twig_RuntimeError are now Twig_Error_Syntax/Twig_Error_Runtime)
  226. * removed support for {{ 1 < i < 3 }} (use {{ i > 1 and i < 3 }} instead)
  227. * the "in" filter has been removed ({{ a|in(b) }} should now be written {{ a in b }})
  228. Changes:
  229. * added file and line to Twig_Error_Runtime exceptions thrown from Twig_Template
  230. * changed trans tag to accept any variable for the plural count
  231. * fixed sandbox mode (__toString() method check was not enforced if called implicitly from complex statements)
  232. * added the ** (power) operator
  233. * changed the algorithm used for parsing expressions
  234. * added the spaceless tag
  235. * removed trim_blocks option
  236. * added support for is*() methods for attributes (foo.bar now looks for foo->getBar() or foo->isBar())
  237. * changed all exceptions to extend Twig_Error
  238. * fixed unary expressions ({{ not(1 or 0) }})
  239. * fixed child templates (with an extend tag) that uses one or more imports
  240. * added support for {{ 1 not in [2, 3] }} (more readable than the current {{ not (1 in [2, 3]) }})
  241. * escaping has been rewritten
  242. * the implementation of template inheritance has been rewritten
  243. (blocks can now be called individually and still work with inheritance)
  244. * fixed error handling for if tag when a syntax error occurs within a subparse process
  245. * added a way to implement custom logic for resolving token parsers given a tag name
  246. * fixed js escaper to be stricter (now uses a whilelist-based js escaper)
  247. * added the following filers: "constant", "trans", "replace", "json_encode"
  248. * added a "constant" test
  249. * fixed objects with __toString() not being autoescaped
  250. * fixed subscript expressions when calling __call() (methods now keep the case)
  251. * added "test" feature (accessible via the "is" operator)
  252. * removed the debug tag (should be done in an extension)
  253. * fixed trans tag when no vars are used in plural form
  254. * fixed race condition when writing template cache
  255. * added the special _charset variable to reference the current charset
  256. * added the special _context variable to reference the current context
  257. * renamed self to _self (to avoid conflict)
  258. * fixed Twig_Template::getAttribute() for protected properties
  259. * 0.9.8 (2010-06-28)
  260. Backward incompatibilities:
  261. * the trans tag plural count is now attached to the plural tag:
  262. old: `{% trans count %}...{% plural %}...{% endtrans %}`
  263. new: `{% trans %}...{% plural count %}...{% endtrans %}`
  264. * added a way to translate strings coming from a variable ({% trans var %})
  265. * fixed trans tag when used with the Escaper extension
  266. * fixed default cache umask
  267. * removed Twig_Template instances from the debug tag output
  268. * fixed objects with __isset() defined
  269. * fixed set tag when used with a capture
  270. * fixed type hinting for Twig_Environment::addFilter() method
  271. * 0.9.7 (2010-06-12)
  272. Backward incompatibilities:
  273. * changed 'as' to '=' for the set tag ({% set title as "Title" %} must now be {% set title = "Title" %})
  274. * removed the sandboxed attribute of the include tag (use the new sandbox tag instead)
  275. * refactored the Node system (if you have custom nodes, you will have to update them to use the new API)
  276. * added self as a special variable that refers to the current template (useful for importing macros from the current template)
  277. * added Twig_Template instance support to the include tag
  278. * added support for dynamic and conditional inheritance ({% extends some_var %} and {% extends standalone ? "minimum" : "base" %})
  279. * added a grammar sub-framework to ease the creation of custom tags
  280. * fixed the for tag for large arrays (some loop variables are now only available for arrays and objects that implement the Countable interface)
  281. * removed the Twig_Resource::resolveMissingFilter() method
  282. * fixed the filter tag which did not apply filtering to included files
  283. * added a bunch of unit tests
  284. * added a bunch of phpdoc
  285. * added a sandbox tag in the sandbox extension
  286. * changed the date filter to support any date format supported by DateTime
  287. * added strict_variable setting to throw an exception when an invalid variable is used in a template (disabled by default)
  288. * added the lexer, parser, and compiler as arguments to the Twig_Environment constructor
  289. * changed the cache option to only accepts an explicit path to a cache directory or false
  290. * added a way to add token parsers, filters, and visitors without creating an extension
  291. * added three interfaces: Twig_NodeInterface, Twig_TokenParserInterface, and Twig_FilterInterface
  292. * changed the generated code to match the new coding standards
  293. * fixed sandbox mode (__toString() method check was not enforced if called implicitly from a simple statement like {{ article }})
  294. * added an exception when a child template has a non-empty body (as it is always ignored when rendering)
  295. * 0.9.6 (2010-05-12)
  296. * fixed variables defined outside a loop and for which the value changes in a for loop
  297. * fixed the test suite for PHP 5.2 and older versions of PHPUnit
  298. * added support for __call() in expression resolution
  299. * fixed node visiting for macros (macros are now visited by visitors as any other node)
  300. * fixed nested block definitions with a parent call (rarely useful but nonetheless supported now)
  301. * added the cycle filter
  302. * fixed the Lexer when mbstring.func_overload is used with an mbstring.internal_encoding different from ASCII
  303. * added a long-syntax for the set tag ({% set foo %}...{% endset %})
  304. * unit tests are now powered by PHPUnit
  305. * added support for gettext via the `i18n` extension
  306. * fixed twig_capitalize_string_filter() and fixed twig_length_filter() when used with UTF-8 values
  307. * added a more useful exception if an if tag is not closed properly
  308. * added support for escaping strategy in the autoescape tag
  309. * fixed lexer when a template has a big chunk of text between/in a block
  310. * 0.9.5 (2010-01-20)
  311. As for any new release, don't forget to remove all cached templates after
  312. upgrading.
  313. If you have defined custom filters, you MUST upgrade them for this release. To
  314. upgrade, replace "array" with "new Twig_Filter_Function", and replace the
  315. environment constant by the "needs_environment" option:
  316. // before
  317. 'even' => array('twig_is_even_filter', false),
  318. 'escape' => array('twig_escape_filter', true),
  319. // after
  320. 'even' => new Twig_Filter_Function('twig_is_even_filter'),
  321. 'escape' => new Twig_Filter_Function('twig_escape_filter', array('needs_environment' => true)),
  322. If you have created NodeTransformer classes, you will need to upgrade them to
  323. the new interface (please note that the interface is not yet considered
  324. stable).
  325. * fixed list nodes that did not extend the Twig_NodeListInterface
  326. * added the "without loop" option to the for tag (it disables the generation of the loop variable)
  327. * refactored node transformers to node visitors
  328. * fixed automatic-escaping for blocks
  329. * added a way to specify variables to pass to an included template
  330. * changed the automatic-escaping rules to be more sensible and more configurable in custom filters (the documentation lists all the rules)
  331. * improved the filter system to allow object methods to be used as filters
  332. * changed the Array and String loaders to actually make use of the cache mechanism
  333. * included the default filter function definitions in the extension class files directly (Core, Escaper)
  334. * added the // operator (like the floor() PHP function)
  335. * added the .. operator (as a syntactic sugar for the range filter when the step is 1)
  336. * added the in operator (as a syntactic sugar for the in filter)
  337. * added the following filters in the Core extension: in, range
  338. * added support for arrays (same behavior as in PHP, a mix between lists and dictionaries, arrays and hashes)
  339. * enhanced some error messages to provide better feedback in case of parsing errors
  340. * 0.9.4 (2009-12-02)
  341. If you have custom loaders, you MUST upgrade them for this release: The
  342. Twig_Loader base class has been removed, and the Twig_LoaderInterface has also
  343. been changed (see the source code for more information or the documentation).
  344. * added support for DateTime instances for the date filter
  345. * fixed loop.last when the array only has one item
  346. * made it possible to insert newlines in tag and variable blocks
  347. * fixed a bug when a literal '\n' were present in a template text
  348. * fixed bug when the filename of a template contains */
  349. * refactored loaders
  350. * 0.9.3 (2009-11-11)
  351. This release is NOT backward compatible with the previous releases.
  352. The loaders do not take the cache and autoReload arguments anymore. Instead,
  353. the Twig_Environment class has two new options: cache and auto_reload.
  354. Upgrading your code means changing this kind of code:
  355. $loader = new Twig_Loader_Filesystem('/path/to/templates', '/path/to/compilation_cache', true);
  356. $twig = new Twig_Environment($loader);
  357. to something like this:
  358. $loader = new Twig_Loader_Filesystem('/path/to/templates');
  359. $twig = new Twig_Environment($loader, array(
  360. 'cache' => '/path/to/compilation_cache',
  361. 'auto_reload' => true,
  362. ));
  363. * deprecated the "items" filter as it is not needed anymore
  364. * made cache and auto_reload options of Twig_Environment instead of arguments of Twig_Loader
  365. * optimized template loading speed
  366. * removed output when an error occurs in a template and render() is used
  367. * made major speed improvements for loops (up to 300% on even the smallest loops)
  368. * added properties as part of the sandbox mode
  369. * added public properties support (obj.item can now be the item property on the obj object)
  370. * extended set tag to support expression as value ({% set foo as 'foo' ~ 'bar' %} )
  371. * fixed bug when \ was used in HTML
  372. * 0.9.2 (2009-10-29)
  373. * made some speed optimizations
  374. * changed the cache extension to .php
  375. * added a js escaping strategy
  376. * added support for short block tag
  377. * changed the filter tag to allow chained filters
  378. * made lexer more flexible as you can now change the default delimiters
  379. * added set tag
  380. * changed default directory permission when cache dir does not exist (more secure)
  381. * added macro support
  382. * changed filters first optional argument to be a Twig_Environment instance instead of a Twig_Template instance
  383. * made Twig_Autoloader::autoload() a static method
  384. * avoid writing template file if an error occurs
  385. * added $ escaping when outputting raw strings
  386. * enhanced some error messages to ease debugging
  387. * fixed empty cache files when the template contains an error
  388. * 0.9.1 (2009-10-14)
  389. * fixed a bug in PHP 5.2.6
  390. * fixed numbers with one than one decimal
  391. * added support for method calls with arguments ({{ foo.bar('a', 43) }})
  392. * made small speed optimizations
  393. * made minor tweaks to allow better extensibility and flexibility
  394. * 0.9.0 (2009-10-12)
  395. * Initial release