#variant (2019-06)
Discuss variant (the “Universal CLI”) https://github.com/mumoshu/variant
Archive: https://archive.sweetops.com/variant/
2019-06-12
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
FYI:
https://github.com/mumoshu/variant/pull/91 -> @Erik Osterman (Cloud Posse) https://github.com/mumoshu/variant/pull/90
Solves #81 Now you can use the Viper-based hide_extra_cmds configuration entity to control if extra commands entries should be hidden from help, like: VARIANT_HIDE_EXTRA_CMDS=true variant
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2019-06-13
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
I built an another tool called variantmod
envisioning to integrate it into variant
someday, like vgo
integrated to go
:slightly_smiling_face:
https://github.com/variantdev/mod/blob/master/examples/basic/variant.mod
The source
in this example isn’t meaningful but guess what we can achieve with it…
Turn any set of files into a reusable module. Contribute to variantdev/mod development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
why the new org? variantdev
?
Turn any set of files into a reusable module. Contribute to variantdev/mod development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
no strong reason, but considered mumoshu/variantmod
vs mumoshu/mod
, vs variant/mod
vs variantdev/mod
and realized variant
was already taken and mumoshu/variantmod
seemed a bit verbose!
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
while i wasn’t happy with mumoshu/mod
because i was planning to integrate it to variant
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
You can add variant.mod
so that running mod
fetches templates from remote sources and renders config files from it. Imagine building reusable template of .circleci/config.yml
, drone.yml
, travis.yml
, “import”ing one of them with variant.mod
and render it with runtime arguments..
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@Erik Osterman (Cloud Posse) Perhaps you’ll be interested
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
The only type of dependencies is currently file
. But I’m considering to add module
. That is, any go-getter
accessible directory containing variant.mod
can be distributed and reused across your projects.
This avoids copy-pasting various YAML files for e.g. CI across projects. But I think there are more use-cases.
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
@mumoshu That’s a good idea (and I tried to find something like this only yesterday ).
In fact, I was thinking about it (retrieving and processing external files to produce the configuration & code) for the last couple of years and even implemented some version of this idea with “gomplate” and some other tools to retrieve the templates.
In my opinion, you could follow the Unix philosophy principle “Do One Thing and Do It Well” meaning that you can retrieve the templates by “mod” and use other tools, like “gomplate” to generate the result files from the templates (instead of processing the templates by “mod”).
BTW, how are you going to store the “result” files? Do you want to leave this action for the end-user to perform it manually (git commit?) or provide some functionality for it in the tool as well?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
@tolstikov Thanks! I believe I have similar sentiment.
What if variantmod just provide the unified api/config syntax for the job, and used gotemplate as a library under the hood? Would it still follow the unix philosophy?
data:image/s3,"s3://crabby-images/d4598/d4598b9a6de519e147b1e42eeb854ec8c53adce8" alt="mumoshu avatar"
Results are rendered to the local paths specified by keys of the files
entries. The user would commit the resulting files after manual testing.
For automation, you can later build a CI pipeline to re-render and test the updated files when variant.mod
file changes.
Does it sound good to you?
data:image/s3,"s3://crabby-images/c3045/c30457671c549c83747cff024180a42acd53f85a" alt="tolstikov avatar"
2019-06-14
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
sorry all - I haven’t had a chance yet to get my head into this. @mumoshu codes at the speed of hard to keep up