Commit message (Collapse) | Author | Files | Lines | ||
---|---|---|---|---|---|
2022-01-06 | Add `#![deny(unreachable_pub)]` to all crates | René Kijewski | 1 | -0/+1 | |
2022-01-06 | Omit implicit lifetimes | René Kijewski | 4 | -7/+7 | |
2022-01-06 | Same number of repeats in macro pattern and body | René Kijewski | 1 | -1/+1 | |
2022-01-06 | No need to build a String when it gets referenced as &str implicitly | René Kijewski | 1 | -6/+0 | |
2022-01-06 | Combine imports from the same module | René Kijewski | 1 | -2/+1 | |
2022-01-05 | Update for actix-web beta | René Kijewski | 1 | -7/+3 | |
2022-01-04 | askama_rocket: revert to rocket 0.4 for release | Dirkjan Ochtman | 1 | -2/+4 | |
2022-01-04 | askama_actix: revert to actix-web v3 for release | Dirkjan Ochtman | 1 | -3/+4 | |
2021-12-15 | Use a separate trait for object safety (#579) | Dirkjan Ochtman | 1 | -17/+5 | |
This is relatively major change to the main trait's API. For context, I always started from the concept of monomorphized traits, but later several contributors asked about object safety. At that point I made `Template` object-safe, and then even later added a `SizedTemplate` to make some things easier for people who don't need object safety. However, having object-safety in the primary trait is bad for performance (a substantial number of calls into the virtual `Write` trait is relatively slow), and I don't think those who don't need object safety should pay for the cost of having it. Additionally, I feel using associated consts for the extension and size hint is more idiomatic than having accessor methods. I don't know why I didn't use these from the start -- maybe associated consts didn't exist yet, or I didn't yet know how/when to use them. Askama is pretty old at this point... | |||||
2021-12-14 | updated for actix-web 4.0.0-beta.14 | CrunkLord420 | 1 | -1/+2 | |
2021-12-08 | Use char for patterns where possible | Dirkjan Ochtman | 2 | -3/+3 | |
2021-12-05 | Update axum to 0.4 (by switching to axum-core) | Michael Alyn Miller | 1 | -5/+3 | |
2021-12-01 | Move askama_mendes integration into Askama repo (#561) | Dirkjan Ochtman | 1 | -2/+2 | |
2021-11-29 | Allow whitespace trimming in {{raw}} blocks | René Kijewski | 2 | -18/+21 | |
2021-11-27 | Add Axum integration | Michael Alyn Miller | 2 | -0/+19 | |
2021-11-24 | Simplify take_content() implementation | René Kijewski | 1 | -43/+37 | |
2021-11-24 | Parse `&str` instead of `&[u8]` | René Kijewski | 1 | -132/+120 | |
Askama's takes valid UTF-8 files as input. So why operate on byte slices instead of strings? This makes writing some functions a lot simpler. | |||||
2021-11-24 | Simplify identifier() implementation | René Kijewski | 1 | -17/+15 | |
2021-11-24 | Simplify ws() and split_ws_parts() | René Kijewski | 1 | -43/+19 | |
2021-11-24 | use nom::error::ErrorKind | René Kijewski | 1 | -16/+7 | |
2021-11-19 | Added support for optional escaper for escape filter (resolves #556) | vallentin | 2 | -11/+36 | |
2021-11-11 | Implement `for … in … if …` | René Kijewski | 2 | -30/+33 | |
2021-11-11 | Implement for-else | René Kijewski | 3 | -29/+72 | |
This PR implements for-else statements like in Jinja. They make it easy to print an alternative message if the loop iterator was empty. E.g. ```rs {% for result in result %} <li>{{ result }}</li> {% else %} <li><em>no results</em></li> {% endfor %} ``` | |||||
2021-11-11 | Prepare for actix-web v4 (#553) | Sergey Pashinin | 1 | -4/+2 | |
2021-11-11 | Implement {{loop.cycle(…)}} similar to Jinja | René Kijewski | 1 | -7/+30 | |
2021-11-10 | Don't parse non-template attributes | Dirkjan Ochtman | 1 | -9/+5 | |
2021-10-13 | Fix support for raw method identifiers | Kelly Thomas Kline | 1 | -1/+1 | |
2021-10-12 | Use char() instead of tag() when possible | René Kijewski | 1 | -73/+76 | |
2021-10-12 | Remove custom ParserError type | René Kijewski | 1 | -5/+3 | |
2021-10-05 | Fix suggestions from nightly clippy | Dirkjan Ochtman | 1 | -13/+9 | |
2021-08-30 | Ensure that {%break%} is only used inside of a loop | René Kijewski | 1 | -46/+76 | |
2021-08-30 | Add {% break %} and {% continue %} | René Kijewski | 2 | -0/+26 | |
This PR adds `{% break %}` and `{% continue %}` statements to break out of a loop, or continue with the next element of the iterator. | |||||
2021-08-25 | Parse boolean literals in assignment targets | René Kijewski | 2 | -3/+27 | |
268d825 introduced a regression that made matching against boolean literals impossible. E.g. "true" was interpreted as the variable "r#true". This PR fixes the problem. The bug was reported by @Restioson in issue #531. | |||||
2021-08-21 | Upgrade to nom 7 | Dirkjan Ochtman | 1 | -5/+9 | |
2021-07-30 | Better error messages using cuts | René Kijewski | 1 | -131/+186 | |
2021-07-30 | Use "target()" to parse "when" block | René Kijewski | 3 | -253/+83 | |
`target()` as used in parsing "let" and "if let" implements parsing nested tuples and structs. But it does not implement parsing literals. The functions `match_variant()` and `with_parameters()` as used in parsing "when" blocks do not implement parsing nested structs, but it implements parsing literals. This PR combines `match_variant()` and `with_parameters()` into `target()`, so that all `{%when%}` support nested structs, too. | |||||
2021-07-30 | Allow omitting "with" keyword in match blocks | René Kijewski | 1 | -1/+1 | |
Askama uses the syntax `{% when Variant with (parameters) %}` in `{% match %}` blocks. This is done because Askama does not implement the whole pattern matching of Rust's `match` statements. This PR wants to bring Askama a step closer Rust's matching, so the "with" keyword should not be needed anymore. | |||||
2021-07-30 | Allow using "with" keyword in "let" statements | René Kijewski | 1 | -0/+1 | |
Askama uses the syntax `{% when Variant with (parameters) %}` in `{% match %}` blocks. This change allows the optional use of the keyword "with" in "let" and "if let" statements, too. | |||||
2021-07-30 | Silence clippy warning from Rust 1.54 | Dirkjan Ochtman | 1 | -0/+1 | |
2021-07-05 | Implement destructoring of structs | René Kijewski | 2 | -8/+59 | |
This PR implements the destructoring of structs on the lhs of "let" and "for" statements. | |||||
2021-07-05 | Parse nested tuples in "let" statement lhs | René Kijewski | 2 | -17/+35 | |
2021-07-05 | Reduce code duplication for writing targets | René Kijewski | 1 | -22/+9 | |
This change also fixes a bug in the loop generator, which failed for shadowed variables. | |||||
2021-07-05 | Move logic where target shadows or declares a variable into method | René Kijewski | 1 | -23/+33 | |
2021-07-05 | Remove needless deref, only to ref it a few lines down | René Kijewski | 1 | -4/+4 | |
2021-07-05 | Remove duplicated code in generator | René Kijewski | 1 | -17/+1 | |
2021-07-05 | Prepare generator::visit_target() for nested targets | René Kijewski | 1 | -4/+2 | |
By now only non-nested tuples are accepted by the parser, but this will change. This change makes visit_target() call itself for items in a tuple. So enable the function to call itself, I needed to fix the lifetime annotation, because the references inside a Target instance may outlife a reference to instance itself. | |||||
2021-07-01 | Stop eliding lifetimes in paths | Dirkjan Ochtman | 5 | -102/+122 | |
2021-07-01 | Implement "if let" statement | René Kijewski | 2 | -17/+54 | |
2021-07-01 | Use "if let Some(_)" instead of match | René Kijewski | 1 | -21/+18 | |
2021-07-01 | Move visit_match_params into its own method | René Kijewski | 1 | -38/+42 | |