-
-
Notifications
You must be signed in to change notification settings - Fork 223
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
I could not give relative path to template on linux but can give on windows #932
Comments
It is intended to be platform-agnostic, so this might just be a bug? (Could be a bug on the Windows side, though...) I don't know exactly what's going on here, but maybe have a look at the |
What happens in windows side is ideal behavior imo. Giving a relative path is way more easy. So i think you should apply this behavior for linux on future versions. Strictly defining folder and place of that folder of the templates is not good for development experience. |
Duplicate of #383 I explained why it occurs in that issue https://github.com/djc/askama/issues/383#issuecomment-727597503. In short, it has to do with how paths are resolved. Your path is actually The workaround is that instead of starting your paths with [general]
dirs = ["path/to/pages"] The |
@vallentin do you think it makes sense for us to document this behavior in the Askama book? |
@djc Yes, I'll look into it. Since I'm already documenting other stuff |
So I was thinking more about this. We could also specialize this case, where the template path starts with So when resolving the template path, say the
Testing like this, would ensure that even if someone actually symlinked I just want to point out again, that the/my original issue #383. This issue only exists on Unix and macOS. The behavior works as expected on Windows, given that there's no symlinks to resolve in the first place. Which funnily enough meant that I first triggered the issue myself, when I attempted to build on a separate system. To be very clear, I'm only suggesting special casing a path starting with Of course we should still recommend in the book, that people actually use The main question is, should it resolve in the previous order, or this order:
What do you think @djc? |
If the goal is to more closely match the behavior on Windows, we should probably also try to match the order that Windows ends up with? |
Hello, my project structure from beginning of the root directory like this:
the file which template struct exist:
routemodels -> src -> lib.rs
the folder that actual templates exist:
pages
and i create a template struct and give path of a template like that:
Now, the problem is it's totally fine for windows, it compiles and works but it doesn't work on linux. That usage is so practical and easy, but i cant compile it on ubuntu, i take this error:
error: template "../../pages/contact.html" not found in directories ["/home/neco/calculate-measures/routemodels/templates"]
--> routemodels/src/lib.rs:79:10
|
79 | #[derive(Template)]
| ^^^^^^^^
|
= note: this error originates in the derive macro
Template
(in Nightly builds, run with -Z macro-backtrace for more info)So, how can i get rid of this error? I don't want to change my project structure. Why it doesn't force you to put your files on "templates" folder on windows and forces you to put that on linux?
Can you make that path platform agnostic(in my case at least for windows and linux) and make support relative paths on linux? It will make your crate way more maintainable.
The text was updated successfully, but these errors were encountered: