-
-
Notifications
You must be signed in to change notification settings - Fork 163
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
[feature] CUE support #1599
Comments
See also: Pulumi supports CUE, and essentially anything that compiles to yaml, via a |
I haven't used cue really but the main reasons I'm looking forward to Pkl is:
I don't really plan to support more than 1 config format, so if Pkl is a success, YAML will be removed entirely in v2. |
What are your reasons for not wanting to do the pulumi approach, and having yaml (or json, etc) as your config file format, and being unopinionated on how your users compile them? That way the templating logic is still outsourced to the compilation system (pkl/cue/jsonnet/etc), but users retain more flexibility on what they need to use. |
@iyefrat I have no idea what pulumi is or what it does, but after a brief glance, I don't see how this would work for moon? moon isn't infrastructure, and a lot of pulumi's APIs are infra centric. It also seems like a maintenance burden on me (when something breaks) if users are configuring things in whatever format they want. Most support requests are based around config issues. |
Oh sorry i think i was vague with my wording - I meant the approach linked here #1599 (comment), where you support yaml but let users specify how they want to compile to yaml (via pkl for example), and delegate features like inheritance to the compilation step. on the moon level you only support the yaml, anything inheritance based is out of scope and delegated to pkl/cue/whatever support. The main reason I'm concerned about this change is that we use cue to in our monorepo to solve the same class of problems you want to solve here: to define variables, allow shared logic across workspace, not have to reinvent inheritance logic, etc. The issue is that if moon moves to only supporting pkl, we're essentially forced to migrate away from moon, or migrate the monorepo from cue to pkl, and we don't want to be forced in to either of those moves for that reason. |
Pkl wouldn't be used to compile to YAML, it would just be Pkl itself. I'm looking for a new configuration format that is stand-alone, and doesn't have a compilation step or intermediary format, but has far more functionality than static formats (JSON, YAML). Something like Starlark is too much, so Pkl feels like a good choice at the moment. I'm not 100% sold on it though, it's still experimental.
It looks like CUE doesn't even support Rust, so that means it's immediately off the table. |
@milesj I am trying to find a feature or discussion on the topic of pkl/configuration language, where you can share your thoughts on this topic and get feedback on the experimental pkl feature. I can see a lot of potential in using Pkl, but for our users, it is "yet another language" to learn. The starlark language looks more attractive to use, because of the familiar syntax to Python developers (and we have a number of things already that are python based). So, it would be interesting to have a place where we can see your reasoning behind statements like "starlark is too much". |
I had a look at pkl and CUE and read Miles's blog post on the subject, and here's my POV: pkl is an interesting and powerful tool, but I would hate for it to be the only way to define moon configs. One of the things I really like about Yes, there are cases where a for loop inside my config file would be a powerful way to reduce boilerplate, but that benefit does not outweigh the trade offs of requiring my developers spend hours reading the pkl docs to understand nuances like the difference between a Let's compare a few options, starting with the example from your blog post:
tasks {
for (_os in List("linux", "macos", "windows")) {
["build-\(_os)"] {
command = "cargo"
args = List(
"--target",
if (_os == "linux") "x86_64-unknown-linux-gnu"
else if (_os == "macos") "x86_64-apple-darwin"
else "i686-pc-windows-msvc",
"--verbose"
)
options {
os = _os
}
}
}
} Moon already supports templating with tera, so adding support for reading templated config files directly could be a fine compromise:
tasks:
{%- for os in ["linux", "macos", "windows"] %}
build-{{ os }}:
command: "cargo"
args:
- "--target"
{%- if os == "linux" %}
- "x86_64-unknown-linux-gnu"
{%- elif os == "macos" %}
- "x86_64-apple-darwin"
{%- else %}
- "i686-pc-windows-msvc"
{%- endif %}
- "--verbose"
options:
os: {{ os }}
{%- endfor %} But honestly, in many cases I would just go with the explicit approach to keep it simple:
tasks:
build-linux:
command: "cargo"
args: ["--target=x86_64-unknown-linux-gnu", "--verbose"]
options:
os: linux
build-macos:
command: "cargo"
args: ["--target=x86_64-apple-darwin", "--verbose"]
options:
os: macos
build-windows:
command: "cargo"
args: ["--target=i686-pc-windows-msvc", "--verbose"]
options:
os: windows tl;dr I'm fine with pkl as an officially supported config format, but please don't take away YAML. I think this would be a deal-breaker for me and my team. If one of the benefits of pkl is schema-definition and validation, can't you use pkl libraries to load yaml and easily support both formats? |
I've thought about Tera before, but the primary reason I won't support it is that it will break syntax highlighting in editors, and make it nigh impossible for consumers to parse these files manually (I know people are doing this). Honestly, I think in 2.0, I may just support any config format that is serde compatible, so YAML, JSON, TOML, Pkl, etc. |
Is your feature request related to a problem? Please describe.
From #1598 and #1569 (comment) I see that you're planning on migrating the config files from yaml to pkl. We've been using CUE as our source-of-truth configuration format in our monorepo, for
moon.yml
,package.json
, etc. Have you considered CUE before settling on pkl? Is supporting both an option?Describe the solution you'd like
Using CUE directly to configure moon. I think that it has a strong set of core abstractions behind it, in particular https://cuelang.org/docs/concept/the-logic-of-cue/
Describe alternatives you've considered
I haven't yet looked into pkl deeply, and currently we have a manual build step, but the fact that we generate the moon files themselves does cause some paper cuts with things like caching and package installation
The text was updated successfully, but these errors were encountered: