diff --git a/content/docs/concept/faq/new-modules-vs-old-modules/en.md b/content/docs/concept/faq/new-modules-vs-old-modules/en.md index f8d0a51234..89dd5ce03e 100644 --- a/content/docs/concept/faq/new-modules-vs-old-modules/en.md +++ b/content/docs/concept/faq/new-modules-vs-old-modules/en.md @@ -1,13 +1,57 @@ --- -title: Modules in CUE v0.9 +title: New modules vs old modules toc_hide: true tags: [modules] --- -This guide provides an extended FAQ for the release notes at -https://github.com/cue-lang/cue/releases/tag/v0.9.0 and subsequent bugfix -releases. In particular, this FAQ focuses on questions about the transition to -the "new" modules implementation that is enabled by default, as of v0.9.0. +The [v0.9.0](https://github.com/cue-lang/cue/releases/tag/v0.9.0) release of CUE +made "new" modules the default ... but what are "new" modules and what were +"old" modules? What's the difference between them, and can I still use "old" +ones? + +This guide provides an extended FAQ that focuses on these questions -- and more +-- including information about the transition from "old" to "new" modules. + +## What do you mean by "old" and "new" modules? + +The concept of a module has existed since the early days of CUE, but its +initial support for modules was very primitive. + +Dependencies needed to be downloaded manually and then copied, by hand, into +the `cue.mod/{gen,pkg,usr}` directories. There was no native tooling for +fetching modules from a remote store, or for publishing them in the first +place. Native module support within the CUE toolchain and APIs was missing, and +everything was very minimal and extremely manual. We refer to this original +behaviour as the "old" modules implementation. + +To address the shortcomings of the old modules implementation, we went through +a number of design and proposal iterations. These culminated in the +{{}}modules proposal v3{{}}, which was accompanied by an +experimental implementation in pre-releases of the v0.8.x series from version +[`v0.8.0-alpha.1`](/releases/v0.8.0-alpha.1) in February 2024. +Old modules remained the default behaviour at this time, but the experimental +implementation could be enabled by setting the +[environment variable `CUE_EXPERIMENT=modules`]({{< relref "/docs/reference/command/cue-help-environment" >}}). + +In May 2024, after extensive testing and feedback from users, the modules +proposal v3 was +[accepted](https://github.com/cue-lang/cue/discussions/2939#discussioncomment-9468945). +At this time we started referring to the experimental implementation that +supported the v3 proposal as "new" modules, to reflect the change away from it +being an experiment. The default behaviour was still that of old modules, with +"new" modules being enabled using the same +[environment variable]({{< relref "/docs/reference/command/cue-help-environment" >}}) +as before. + +At the start of June 2024 CUE [v0.9.0](/releases/v0.9.0) was released. It +changed CUE's default behaviour - new modules were now enabled out of the box. +This removed the need to enable them manually, but folks needing old +modules in v0.9.0 or later could set +[`CUE_EXPERIMENT=modules=0`]({{< relref "/docs/reference/command/cue-help-environment" >}}) +to revert to old modules behaviour. + +At some point in the future, support for old modules will be removed entirely, +so we encourage you to explore and adopt them before then! ## Modules? Where do I get started? @@ -26,16 +70,6 @@ well-known services and projects. We will share more details about the Central Registry in the future. For now, we are looking to get early feedback - please come and discuss it in the `#modules` [Slack channel](/slack). -## What do you mean "new" and "old" modules implementations? - -{{}}Issue #2939{{}} presented a proposal for how CUE can -fully support package and dependency management. Over the course of v0.8.x -releases and pre-releases leading up to v0.9.0, we have been experimenting with -an implementation of this proposal: we refer to this as the "new" modules -implementation. In v0.9.0, this "new" implementation is the default. In -previous CUE versions (v0.8.x and earlier), the "old" implementation is the -default. - ## Why do I need to run `cue mod fix`? v0.9.0 requires that `language.version` is declared in the `cue.mod/module.cue` file. @@ -91,7 +125,7 @@ be removed in time. `cue mod publish` needs to determine what files to include in a published module. Rather than rely on implicit heuristics such as whether a VCS exists or is installed,to determine whether the file list should be determined from the -files on disk, or from the contents of a Git commit, we require the module +files on disk, or from the contents of a Git commit, we require the module author to be explicit. ## How do I configure which OCI registry is used for publishing/fetching modules? @@ -119,7 +153,37 @@ notable exception of `@if` attributes. Specifically: module. In any external module, all tags are considered to be `false`. This is a change from earlier versions, when there was no distinction between the main module and external modules. - - + + +## Can I use "`cue.mod/usr`" with new modules? + +Technically, yes, you can - but with one very important caveat: if a module +dependency is declared in your `cue.mod/module.cue` file (in the `deps` field), +then **it must not also exist** in *any* of the `cue.mod/{pkg,gen,usr}` +directories. +If you try to declare and define an dependency in both "old" and "new" +locations, an error will ocurr: + +``` +mod.example@v0: import failed: cannot find package "github.com/cue-labs/examples/frostyconfig@v0": ambiguous import: found package github.com/cue-labs/examples/frostyconfig@v0 in multiple modules: + github.com/cue-labs/examples/frostyconfig@v0 v0.0.1 (.) + local (cue.mod/usr/github.com/cue-labs/examples/frostyconfig): +``` + +Essentially, the CUE loader is unable to determine which dependency "wins" and, +because of this, old and new modules are mutually exclusive *at the level of +individual module dependencies*. + +We continue to support `cue.mod/{pkg,gen,usr}` for now, as we continue our +efforts to improve the CUE module ecosystem. +In particular, we are looking to better understand how to support: + +- generated CUE modules (old modules: `cue.mod/gen`); and +- user augmentations for dependencies/generated CUE modules (old modules: + `cue.mod/usr`). + +Work on the +[Central Registry](https://registry.cue.works/) +is a key part of these goals. +We welcome and encourage you to share your experiences and use cases for either +of these features in {{}}. diff --git a/hugo/content/en/docs/concept/faq/new-modules-vs-old-modules/index.md b/hugo/content/en/docs/concept/faq/new-modules-vs-old-modules/index.md index 7068442948..d0fd00828a 100644 --- a/hugo/content/en/docs/concept/faq/new-modules-vs-old-modules/index.md +++ b/hugo/content/en/docs/concept/faq/new-modules-vs-old-modules/index.md @@ -1,13 +1,57 @@ --- -title: Modules in CUE v0.9 +title: New modules vs old modules toc_hide: true tags: [modules] --- -This guide provides an extended FAQ for the release notes at -https://github.com/cue-lang/cue/releases/tag/v0.9.0 and subsequent bugfix -releases. In particular, this FAQ focuses on questions about the transition to -the "new" modules implementation that is enabled by default, as of v0.9.0. +The [v0.9.0](https://github.com/cue-lang/cue/releases/tag/v0.9.0) release of CUE +made "new" modules the default ... but what are "new" modules and what were +"old" modules? What's the difference between them, and can I still use "old" +ones? + +This guide provides an extended FAQ that focuses on these questions -- and more +-- including information about the transition from "old" to "new" modules. + +## What do you mean by "old" and "new" modules? + +The concept of a module has existed since the early days of CUE, but its +initial support for modules was very primitive. + +Dependencies needed to be downloaded manually and then copied, by hand, into +the `cue.mod/{gen,pkg,usr}` directories. There was no native tooling for +fetching modules from a remote store, or for publishing them in the first +place. Native module support within the CUE toolchain and APIs was missing, and +everything was very minimal and extremely manual. We refer to this original +behaviour as the "old" modules implementation. + +To address the shortcomings of the old modules implementation, we went through +a number of design and proposal iterations. These culminated in the +{{}}modules proposal v3{{}}, which was accompanied by an +experimental implementation in pre-releases of the v0.8.x series from version +[`v0.8.0-alpha.1`](/releases/v0.8.0-alpha.1) in February 2024. +Old modules remained the default behaviour at this time, but the experimental +implementation could be enabled by setting the +[environment variable `CUE_EXPERIMENT=modules`]({{< relref "/docs/reference/command/cue-help-environment" >}}). + +In May 2024, after extensive testing and feedback from users, the modules +proposal v3 was +[accepted](https://github.com/cue-lang/cue/discussions/2939#discussioncomment-9468945). +At this time we started referring to the experimental implementation that +supported the v3 proposal as "new" modules, to reflect the change away from it +being an experiment. The default behaviour was still that of old modules, with +"new" modules being enabled using the same +[environment variable]({{< relref "/docs/reference/command/cue-help-environment" >}}) +as before. + +At the start of June 2024 CUE [v0.9.0](/releases/v0.9.0) was released. It +changed CUE's default behaviour - new modules were now enabled out of the box. +This removed the need to enable them manually, but folks needing old +modules in v0.9.0 or later could set +[`CUE_EXPERIMENT=modules=0`]({{< relref "/docs/reference/command/cue-help-environment" >}}) +to revert to old modules behaviour. + +At some point in the future, support for old modules will be removed entirely, +so we encourage you to explore and adopt them before then! ## Modules? Where do I get started? @@ -26,16 +70,6 @@ well-known services and projects. We will share more details about the Central Registry in the future. For now, we are looking to get early feedback - please come and discuss it in the `#modules` [Slack channel](/slack). -## What do you mean "new" and "old" modules implementations? - -{{}}Issue #2939{{}} presented a proposal for how CUE can -fully support package and dependency management. Over the course of v0.8.x -releases and pre-releases leading up to v0.9.0, we have been experimenting with -an implementation of this proposal: we refer to this as the "new" modules -implementation. In v0.9.0, this "new" implementation is the default. In -previous CUE versions (v0.8.x and earlier), the "old" implementation is the -default. - ## Why do I need to run `cue mod fix`? v0.9.0 requires that `language.version` is declared in the `cue.mod/module.cue` file. @@ -91,7 +125,7 @@ be removed in time. `cue mod publish` needs to determine what files to include in a published module. Rather than rely on implicit heuristics such as whether a VCS exists or is installed,to determine whether the file list should be determined from the -files on disk, or from the contents of a Git commit, we require the module +files on disk, or from the contents of a Git commit, we require the module author to be explicit. ## How do I configure which OCI registry is used for publishing/fetching modules? @@ -119,7 +153,37 @@ notable exception of `@if` attributes. Specifically: module. In any external module, all tags are considered to be `false`. This is a change from earlier versions, when there was no distinction between the main module and external modules. - - + + +## Can I use "`cue.mod/usr`" with new modules? + +Technically, yes, you can - but with one very important caveat: if a module +dependency is declared in your `cue.mod/module.cue` file (in the `deps` field), +then **it must not also exist** in *any* of the `cue.mod/{pkg,gen,usr}` +directories. +If you try to declare and define an dependency in both "old" and "new" +locations, an error will ocurr: + +``` +mod.example@v0: import failed: cannot find package "github.com/cue-labs/examples/frostyconfig@v0": ambiguous import: found package github.com/cue-labs/examples/frostyconfig@v0 in multiple modules: + github.com/cue-labs/examples/frostyconfig@v0 v0.0.1 (.) + local (cue.mod/usr/github.com/cue-labs/examples/frostyconfig): +``` + +Essentially, the CUE loader is unable to determine which dependency "wins" and, +because of this, old and new modules are mutually exclusive *at the level of +individual module dependencies*. + +We continue to support `cue.mod/{pkg,gen,usr}` for now, as we continue our +efforts to improve the CUE module ecosystem. +In particular, we are looking to better understand how to support: + +- generated CUE modules (old modules: `cue.mod/gen`); and +- user augmentations for dependencies/generated CUE modules (old modules: + `cue.mod/usr`). + +Work on the +[Central Registry](https://registry.cue.works/) +is a key part of these goals. +We welcome and encourage you to share your experiences and use cases for either +of these features in {{}}.