-
Notifications
You must be signed in to change notification settings - Fork 9
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 setting to allow duplicate tasks #47
Comments
Greetings! I can't tell you how happy it makes me that you've already tested the new Include feature so soon after merging it and before even getting it into a release or even announcing it ! I can definitely see the value in supporting the ability to override commands in some use cases. I'll want to grind on this a bit and decide if there are case that don't make sense. For example, I still think it's an error if you try to define a command multiple times within the same Runfile. I'll see if I can get a PR started to allow duplicate commands as long as they are defined in different files. Last-command-wins is likely the easiest way to go, so I'll assume that for now. I'll cc you on the PR and we go from there - Thanks again ! -TW |
It sounds like you have already added an ability to include other files into run. If so, then that means I can scrap my support_run branch in my justprep preprocessor and I had so much fun playing with it. During my testing I got this error: run: 5.8: expecting TokenNewline ('\n') which does not make sense to me. What does it mean? Dewayne |
LOL I actually thought you were referring to my newly-added include functionality ( #44 ), which landed in the main branch the day before you starred the repo and created this ticket :) Do feel free to build from the main branch and test the include functionality. I'd love to get some more feedback on it. I am going to hold off on generating the next release until I deal with this duplicate command issue, as I consider it a missed bug that should have been addressed at the time include support was added. I also found a couple of other missed places where I need to now include the Runfile as part of error messaging. |
I'd have to see the Runfile content in and around line 5, but a quick guess is you have an error in a doc-string on line 5. On the off chance that line 5 col 8 is the eof (ie. maybe the end of a command script), try adding a trailing newline. |
That specific test I was doing was with by justprep support_run branch. Its likely that the Runfile did not have a task defined only badly formed include statements to test my error codes. BTW justprep also supports what I call a Fake Module Convention that also works with run as is... if you already know this pattern forgive me for talking too much. Consider this Runfile # justprep/test/Runfile
module_aaa := "modules/aaa.run"
module_bbb := "modules/bbb.run"
EXPORT module_aaa, module_bbb
##
# Say hi
hello:
echo "Hello World"
##
# List all tasks including the modules
list_all:
run list
run aaa
run bbb
##
# Module aaa
aaa:
run -r ${module_aaa} ${@}
##
# Module bbb
bbb:
run -r ${module_bbb} ${@} and two others aaa.run and bbb.run both in a modules directory.
... and ... # .../modules/bbb.run
##
# Module bbb magic
magic:
echo 'Do you believe in Magic?'
##
# Do something magical in bbb
xyzzy:
echo "Magic from bbb ..."
echo "... watch me pull a ${1} out of my hat." Here is a console session using those three files:
What I do in justprep is to turn a line that looks like this ... module aaa := "modules/aaa.run into lines that look like this ... module_aaa := "modules/aaa.run
EXPORT module_aaa
##
# Module aaa
aaa:
run -r ${module_aaa} ${@} |
I've abandoned the support_run branch in my justprep CLI utility since you are so close to releasing your own... but please consider that Fake Module Convention as a possible feature for the next release. |
I created #50 as a place to continue the Module conversation.... |
Why would duplicate tasks be an interesting thing? Well, I'll tell you. I work on many projects at the same time. Each project has both common and specific needs with regard to tasks so I created the CLI utility "justprep" as a pre-processor to add the ability to include common content and add modularization to my taskfiles. When you do that, you then have the ability to include a common Runfile with its tasks into a project specific Runfile which may over-ride one or more of those common tasks.
So by definition, you could warn about duplicates but not fail. That last task defined in the Runfile should be the one that gets executed.
The text was updated successfully, but these errors were encountered: