-
Notifications
You must be signed in to change notification settings - Fork 13
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
don't ignore non-existent variables #61
Comments
This is unfortunately an unwinnable war. While it would be nice to make nonexistent variables errors, it would also require passing Also, a rather common approach in dynamic HTML templating is to have templates with lots of optional arguments, allowing the same template to be reused across many different concrete data types. This would then require the host environment to provide a giant list of I do understand the concern though, and have, in fact, been bitten by it myself a couple times. So I guess if you were to come up with a patch that offers warnings about undefined variables as an opt-in flag, I'd be game. Compile-time checks however are going to be a whole lot more complex than you'd initially think, because they would basically boil down to adding a type checker, and to make it completely reliable (and thus useful for hard errors), the type system would have to support dependent types, because we can do things like dynamically construct strings and use those to look up variables at runtime, and this in turn means that the type system needs to be able to express things like "a dictionary that has a key for every string that this function here can output given an input of type X". This is not a project for an afternoon. On this note: ginger sits in a bit of a niche - unlike most other Haskell HTML templating solutions, it parses and interprets templates at runtime. If you don't need this, I would recommend using something else instead - Blaze, for example, is fantastic, and leverages the full glory of Haskell's type system. |
How does the runtime resolvement of variable name to underlying value work? Where is the code in the ginger codebase for this? Could it not just be added that when the templated "requests a value" which is not present an exception is thrown?
I've only seen templates that do something like
Optional arguments without defined checks are poorly written templates IMO and this use case should not be supported.
Don't really understand this. Ginger should check if the variable is in the hashmap yes, but the template can do 1 check for more variables.
Did you look how jinja2 in python handles this case? I know for sure that PHP's twig throws exception when the template requests a value which is not present. I understand the argument for compile time being difficult, but why should PHP be in the dynamic case be "more powerful" than a haskell implementation? |
That's a strong opinion, and I beg to differ. But that's beside the point, because I already said that if you come up with a patch, I'm up for it.
OK, let me try to explain this from a different angle. First of all, there is no hashmap. Variable lookups ultimately bubble up to The bigger issue is writing But if
That last one is of course the tricky bit: it's easy for Actually, you know what, I might give it a shot, because why not. |
Right now when printing
{{doesnt_exist}}
it just doesn't print anything. Rather i would like to have throw an exception or even better check on compile time. Now bugs are there and they are not notified about.The text was updated successfully, but these errors were encountered: