-
-
Notifications
You must be signed in to change notification settings - Fork 2.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add template engine ADR #11900
Add template engine ADR #11900
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pleae add an example for each temlating engine. Just reading the pros and cons, one cannot really decide.
I think, the main decision driver is a "nice" syntax. - Please add this as first decision driver.
Co-authored-by: Oliver Kopp <[email protected]>
Co-authored-by: Oliver Kopp <[email protected]>
Co-authored-by: Oliver Kopp <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You modified Markdown (*.md
) files and did not meet JabRef's rules for consistently formatted Markdown files.
To ensure consistent styling, we have markdown-lint in place.
Markdown lint's rules help to keep our Markdown files consistent within this repository and consistent with the Markdown files outside here.
You can check the detailed error output by navigating to your pull request, selecting the tab "Checks", section "Tests" (on the left), subsection "Markdown".
I think you understand this is unfinished ADR, because I haven't used layout files and template engines much in Java. I wrote everything for AI, and every option seems to be fine |
…te-engine-adr # Conflicts: # docs/decisions/0039-template-engine.md
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You modified Markdown (*.md
) files and did not meet JabRef's rules for consistently formatted Markdown files.
To ensure consistent styling, we have markdown-lint in place.
Markdown lint's rules help to keep our Markdown files consistent within this repository and consistent with the Markdown files outside here.
You can check the detailed error output by navigating to your pull request, selecting the tab "Checks", section "Tests" (on the left), subsection "Markdown".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix linting issues
Add one example for each entry. Maye with an example of #11884.
#foreach( $entry in $entries )
${CanonicalBibEntry.getCanonicalRepresentation($entry)}
#end""",
The example is good, because it shows
- forEach loops
- how to call existing functions
We should also add one function call for JabRef's functions - https://docs.jabref.org/collaborative-work/export/customexports
\format[HTMLChars,AuthorFirstFirst]{\editor}
New probably
$AuthorFirstFirst$(HTMLChars($entry.editor))
I am not sure about $entry.editor
. Is it $entry.getField(editor).get()`? -- I don't want the template engine be verbose.
The current code is at org.jabref.logic.layout.LayoutEntry#handleOptionField. (Many class variables 🙈)
- Add new Decision Driver: Short and understandable syntax. Especially good handling of unset fields and empty Optionals.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You modified Markdown (*.md
) files and did not meet JabRef's rules for consistently formatted Markdown files.
To ensure consistent styling, we have markdown-lint in place.
Markdown lint's rules help to keep our Markdown files consistent within this repository and consistent with the Markdown files outside here.
You can check the detailed error output by navigating to your pull request, selecting the tab "Checks", section "Tests" (on the left), subsection "Markdown".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
please all examples consistent
please remove all gempl te placeholders in the options
- Main page: <https://www.thymeleaf.org/>. | ||
- Documentation: <https://www.thymeleaf.org/doc/tutorials/3.1/usingthymeleaf.html>. | ||
|
||
Example (not related to AI): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why? 😅
|
Reading the syntax, +1 for Velocity.
From: https://stackoverflow.com/a/1984458/873282 And this is what we mainly want! |
I chose Apache Velocity Sorry, on your all behalf :) I want to complete this ADR |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think, text is good enough.
Mandatory checks
- [ ] Change inCHANGELOG.md
described in a way that is understandable for the average user (if applicable)- [ ] Tests created for changes (if applicable)- [ ] Manually tested changed features in running JabRef (always required)- [ ] Screenshots added in PR description (for UI changes)- [ ] Checked developer's documentation: Is the information available and up to date? If not, I outlined it in this pull request.- [ ] Checked documentation: Is the information available and up to date? If not, I created an issue at https://github.com/JabRef/user-documentation/issues or, even better, I submitted a pull request to the documentation repository.Refs JabRef#392