-
Notifications
You must be signed in to change notification settings - Fork 295
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
Allow if
on tasks
#225
Comments
That's an interesting suggestion -- I can certainly see how it could be useful to expand the Dotbot has a simple declarative-ish YAML config file, and if we add something like this, we'll be slowly moving towards a programming language embedded in YAML (this has happened with Ansible, for example), and I think this eventually becomes unmanageable. YAML is a pretty good config file format, but it's not a great programming language -- it's not really designed for that. If we're moving towards a more featureful DSL with general-purpose programming language constructs like structured control flow etc., another option might be to have a embedded DSL in a real programming language. Python is a decent DSL host; we could even imagine migrating to a language explicitly designed for designing languages, like Racket (though I don't think we'll do this in practice for practical purposes, because everyone has Python preinstalled but nobody will have Racket). There's a bit more discussion on this topic in #35 (comment), with some examples of what this syntax could look like. I could imagine a future version of Dotbot could support both, a simple YAML config file for simple situations, and the full power of the Python programming language for more complicated situations. I'd love to hear your thoughts on this. And thanks for opening this issue -- it's gotten me thinking again about adding these kinds of more powerful features to Dotbot. |
@anishathalye How about only limiting it to |
@anishathalye Thanks for considering my proposal and sharing your reaction. I understand your hesitation -- I can see how my example looks a bit more like a programming language -- but I see it differently. I don't think my proposal would make Dotbot's YAML format any less declarative, and I hope I can convince you of this. As I see it, Ultimately, it allows me to achieve the same thing that I could today, only with much less repetition. And, as a side effect, it also allows the I really see it as a tiny enhancement to the configuration format that really doesn't change the sorts of things you can describe at all. You certainly won't see me arguing for control flow constructs like loops. I agree that would be a bad idea, but it doesn't feel like a slippery slope to me -- I can't see how it would fit at all with how Dotbot works. Thanks for pointing to the Dotbot 2.0 issue. There are a lot of interesting ideas there. I'm with the folks who preferred to stick with the current YAML format. I'm a big fan: It's simple and it's very accessible to pretty much any developer, regardless of what language(s) they work in. I think that's very valuable. Personally, I'm not a Python programmer, so switching to a Python DSL would be a barrier for me. Even though I'm not a Python programmer, I thought it would be worthwhile to see what implementing my proposal might look like, so I took a stab at it. It was such a tiny change that even I was able to do it. I'm going to open a PR for you to have a look at. Hopefully having something concrete to consider will be helpful. Thanks again! |
After I finished my PR and comment last night, I took a look at issue #81 based on the mention above, and that expanded my thinking a bit more and maybe helped me to see some of the disconnects. I do think what folks are asking for there is closely related to what I'm asking for here. To put a finer point on what I was trying to say in my previous comment: In both cases, I think it's not control flow, but rather more powerful composition. It's the ability to group some related actions and identity and describe them as a unit. And as I see it, composition is very much a declarative concept. The main difference between what's been going there vs. what I'm proposing here is that I see the existing concept of a task as that unit of composition. It already can, itself, compose multiple actions. All it's missing to be super useful is a name and a way of declaring in which situations it applies (and my suggestion was to reuse the existing What they're talking about over there is a unit of composition that's bigger than tasks. But what's not clear to me is if they're thinking about it that way because they don't know that tasks can already compose multiple actions, or if they need something more than that. In fact, it's not even clear to me if tasks are intended to compose multiple actions. The only reason I know they can is from looking at the code ( So, I wonder if that might be the source of discomfort and disconnect with these sorts of suggestions -- the question of what tasks are actually meant to be and whether a mechanism for composition (rather than just a list of actions) is desirable.. As I see it, yes, a mechanism for composition would be highly beneficial in a lot of cases, and tasks are very well suited to be that mechanism. It wouldn't complicate the model at all for users who don't need them, and the changes to the code would be minor. With all this in mind, I've come up with minor revision to my idea that's a little more explicit and unambiguous:
I'm adding a Of course, all of this is optional. I could have declared the common task without a name just like before:
Users who just want a flat list of actions and no composition can continue using this format. What would you think of this approach? If you think it might be worth pursuing, I'd be happy to update my PR to implement it. |
I've updated #229 to implement my new proposal. I think it's still a really simple, clean change. |
Yeah, this is a good point. I think Python is among the more accessible languages (even though I love Racket, I don't think I'd release a Dotbot 2.0 implemented in it), but yeah, YAML is probably better understood.
This is the thing that "true programming languages" handle pretty well, but data serialization languages don't do quite as well. Have a generic
Heh, that's a good question. Yes, in practice, each task ends up having exactly one action. This is a bit of an artificial distinction that arose from the need to have actions be named (so we know whether to
That looks pretty clean, though perhaps a bit verbose for my tastes (I think I wouldn't personally need that kind of complexity, so I'd have a single task). Again, a challenge with the YAML format is that In the strictest sense, this is not backwards compatible, because technically "task" and "if" are legal plugin names. But nobody is using those silly plugin names in practice, so I don't think it's a problem. (more specific comments in #229) |
I have an enhancement to propose: Allowing an
if
property (which would work just like thelink
option) on the top-level tasks, alongside each directive. If the executed command is not successful, the whole task would be skipped.The idea is that you could define sets of
link
s, orshell
commands, or whatever task, for an environment/profile/whatever. My use case is that I'd like to have a task withlink
s that are always created, and then another set just for personal machines, and a third just for work machines. I have a different.gitconfig
file between the two, plus a.pairs
file for work, plus more...Since I can't put two different entries for the same file under a singlelink
task, I need to have different task for these cases, anyway. So, it would be wonderful if I didn't have to repeat the sameif
option again and again and again.For exmaple:
Plus, I could imagine this being useful with other directives -- definitely for
shell
andcreate
, and probably for many plugins, too.I think this small enhancement would make dotbot so much more flexible and powerful.
The text was updated successfully, but these errors were encountered: