You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Try having to paste an element like: P[idea]() over and over again.
It's no fun. First, it's not fun to have to do copy/paste, and second, it's extremely aesthetically disgusting to have a huge block (or even a semi large link) littering up the document. It would be better to allow variables in the syntax. This would have to be a feature of the parser directly, not a "component" itself, because how could the parser know to substitute things afterwards? Basically some kind of preprocessor.
There would have to be some way of describing variables, and separating them from the rest of the document.
The text was updated successfully, but these errors were encountered:
One nice syntax might be ${variable} but as soon as variables enter the picture we get some problems:
variables defined in terms of other variables - which anyone (especially me as a programmer) would want. That's the whole point of variables, anyway - being able to define higher orders of abstraction on top of the ones that we already have. That means that we have to do something like macroexpand to completely spit out the final component.
this isn't so bad, so long as it's just text replacement. We can compute the expanded version of each "variable" (which is now acting like a macro) once, and then do all the replacements in the document as necessary. Easy to implement with memoization.
Taking parameters - effectively now switching from writing variables to fully writing macros in glue language - not sure at all how this would look. Pretty soon, I would be writing my own coding language! Also, like with Lisp, the question "where should I make this change - in a macro, or in the python component descriptions?" will always continue to exist. I feel like it's easiest to write the python components rather than create this whole mess with macros, although text replace variables would still be a good feature.
So in short, don't turn this into a P/L assignment: just force everyone to write scripts where they don't want text replacement. And it's okay for the text replacement to use other variables, but it should be seen as a stopgap for a component that someone should consider writing on the python side.
Try having to paste an element like:
P[idea]()
over and over again.It's no fun. First, it's not fun to have to do copy/paste, and second, it's extremely aesthetically disgusting to have a huge block (or even a semi large link) littering up the document. It would be better to allow variables in the syntax. This would have to be a feature of the parser directly, not a "component" itself, because how could the parser know to substitute things afterwards? Basically some kind of preprocessor.
There would have to be some way of describing variables, and separating them from the rest of the document.
The text was updated successfully, but these errors were encountered: