Skip to content
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

Macros within comments are executed #23

Closed
frankier opened this issue Dec 10, 2023 · 4 comments
Closed

Macros within comments are executed #23

frankier opened this issue Dec 10, 2023 · 4 comments

Comments

@frankier
Copy link
Contributor

Thanks for the update! I think it is very close to working for my purposes, but I still have one more round of nits.

If I write something like the following:

#= {{ my_macro(...) }} =#

Then currently the macros will be expanded first, which will mean my_macro is executed. This could cause problems, e.g. if my_macro isn't defined or my_macro contains an infinite loop or some bad side-effect.

I guess possibly applying comments before macros would help.

P.S. You will probably not be able to implement nested comments without actually parsing into a tree, but these are a bit unusual. I thought I would just note this since Julia itself does support nested comments and I think that might be a point at which the "lex and rewrite" approach might break down.

@MommaWatasu
Copy link
Owner

Thanks for your report.
I’ll fix this bug by removing comments before processing macros. Please wait for a while.

But, as you mentioned, parser which doesn't use syntax tree is not appropriate to make complex template engine. So, I will try implementing own parser which uses syntax tree(and then, I think I should release it as v1.0.0). This change must take a lot of time, but I believe it’s necessary to make OteraEngine.jl practical.

@frankier
Copy link
Contributor Author

Okay sounds great! I guess the argument against is simplicity. As long as there is a good correspondence between the template language and Julia then lex+rewrite works just fine. On the other hand it could well be useful for some cases beyond nested comments like certain custom tags or something. Good luck either way.

@MommaWatasu
Copy link
Owner

Now, v0.4.1 is available. But please note that this patch slows down the speed.

@frankier
Copy link
Contributor Author

Great!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants