-
Notifications
You must be signed in to change notification settings - Fork 993
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
[workspaces] Workspaces should be Super Builds #5762
Comments
🙌 Thanks a lot for your detailed overview and valuable feedback, also for gathering together all the issues related to workspaces. I agree with you on most of your comments. We know we need to [re]define workspaces again, there are many issues related to them and it is a very valuable feature. Many of the issues are related to layouts, and your intuition about layouts being defined inside the recipe are in the right direction, I would like @memsharded to summarize here the work related to them before entering into details. |
Being able to work on multiple components at once is one of the main requests I get from our developers. Having workspaces "just work" would be awesome. |
@jgsogo Thanks for being receptive to my comments. I'm interested to know what is in store for the redesign. As it is being redesigned, is there a stopgap that would allow it to work like pre-1.13.2 workspaces? I would like to get current with my conan version, but I need to be able to do workspaces without layout files. Perhaps we could revert back to that? Or enable the old or the current with a configuration option? |
@jgsogo I'd support the cmake generator to do a super build using Specifically, I don't think we should mind the fact that |
Another problem with the |
Very interesting. There seem to be many quite different ideas and use cases for workspaces. E.g.
The conan team should aim for a generic solution that enables all these use cases by just providing the required information and interfaces without actually creating any targets and without assuming any standard workspace layout:
|
What is the state of Conan workspace, Conan 2.0? |
I believe @jgsogo is best equipped to answer this question. I've tried to lobby for the workspaces feature reform in the Conan 2.0 Tribe discussions, especially as I think it is applicable to the proposals we've seen on local package development, secondary caches, With relation to this thread, where I am advocating for specific workspaces behavior that involves super build and co-development of heterogeneous packages, I don't see that gaining any traction with the group. It seems one major sticking point is the desire to have individual source file dependencies for incremental builds. Of course, the only way to accomplish this is if all packages share the same build system, which is a narrow and unfortunate constraint to put on workspaces. If we could loosen that restriction, we could have package-level dependencies which inform incremental builds at the super build level. That is, any changes to source would cause the individual package to rebuild and changes to the package folder would force other packages to do the same. |
Thanks for the update, too bad I really liked your proposal and thought 2.0 would follow something like that. |
We have been recently doing a lot of effort in improving the foundation of the workspaces, the "editables". We have developed the new We didn't want to resume work on the workspaces until this necessary piece was improved. Now it is looking much better, and the plan is to start allowing its usage in ConanCenter in next releases, so the feature will further mature and stabilize. We will keep investing in improving the editables via the Furthermore, Conan 2.0 will bring many other very related changes, like pivoting the way the environment is managed, the |
Sounds great! I've used layouts already but I was not able to run Are there public reports of the Conan 2.0 Tribes? What is the best way to stay up to date with the project? EDIT: Oh I did not realize you were talking about a new method, I will recheck the new doc |
Thanks @memsharded! I'm a bit concerned about the persistence of "layout" and "editables" for the reasons I outlined at the top of this thread. Unless the concept of an editable has changed, it is problematic to keep that pattern going. There was lots of talk in the tribe about secondary caches and other strategies for local development, so I'm not sure if "editables" as I understand them is what you're talking about. I see that the |
Yes, the best to stay up to date is the repo: https://github.com/conan-io/tribe, check the closed and open PRs
Yes, check also the new
The secondary caches are a different approach that can resolve some related issues, but there are still many users that would still request the direct editable experience, so we think we are not ready to completely give up on the editable experience. Actually, the plan is to make package recipes "editable" by default. You can check some preliminary POC of how recipes in ConanCenter would be modernized: conan-io/conan-center-index#6474. The layout() will be there by default.
Yes, the external layout mechanism will be completely removed in Conan 2.0.
Yes, they do, because the editables still rely on the generators like CMakeDeps, and the |
Although I agree with the motivation of layered/tiered cache and think something is sorely needed, I don't support representing this as a "cache." I propose a similar approach around the workspace. You can see lengthy discussion on this topic: conan-io/tribe#19 (comment)
I would like to probe this a bit. Of course users are asking for a way to edit packages and have those packages act as dependencies to other packages while in development. Are users asking specifically to globally override their cache to reference this "dirty" recipe? It is a pretty glaring liability to rewire your whole system to point to a particular reference that is in development. Many things can go wrong here. Indeed this is what the "secondary cache" (and its variants, including my workspace proposal) are trying to address. I don't see how editables can continue to exist as-is with the prospect of these solutions on the horizon: they are meant to fix (or replace) editables. Of course, to be successful, the new design will need to satisfy the features enjoyed by the current users of editables.
I think I'm missing something here. I understand that layouts are build system agnostic. However I need more information on what will be generated by the workspace and how it will form dependencies between packages in the workspace. The current workspace generator uses My understanding is that |
Sorry if this is not fully related, but when I started to read about conan editable and this post I was quite surprise to learn that once you have an editable package, any other packages start to use it. I was always trying to figure out how my own package would "link" to this editable package I added, and now I understand, but I think Conan is getting it wrong. Assuming the scenario "MyApp" is using "MyLib" and both are independent Conan packages, I would expect having to do something special when installing "MyLib" and also when building "MyApp". Today, we only have to do something special when installing "MyLib" -> use "conan editable add". What I was somehow expecting is something like this:
that would give me the following hierarchy:
This could be implemented by using some default rules: There would be no need for a "conan editable" command, it would ensure that CI script that uses "conan build" without --dev always does the proper thing, in case they get tested locally on the developer machine. It would also ensure that the editable package is clearly identified, by default at the same level, or otherwise, you have to specify. Maybe the "workspace" then is basically "currentdir", one could then set "workspace" to "parentdir" (relative or absolute path) and then all packages would appear at the same level:
By default, the workspace would be the current folder you execute "conan install" in... Anyway, total newbie here as far as Conan goes. Let me know if that makes no sense ;-) |
Thanks for your comment. There are some challenges that would make your proposal not work nicely:
So in the development of editables it is very important that editable packages are almost "transparent" to their consumers. It doesn't matter if the package is in "editable" mode or in the cache, for the consumer/consumers of that package, it should be exactly the same. Editables don't aim to be a workspace which is what it seems you are proposing. |
For most case, the need to have something in the recipe would not exists, since the default package name is likely to be the value used by all, only the "dir" or "workspace" could change and that could be set in the global conan config. Regarding the diamond approach, likely when a developer works on one app, it doesn't need to have all the requirements locally made available but only some. In a situation of a diamond approach, that is where you may want to set the requirement editable_folder to be something else. when you install a package with --dev its own dependency is not installed locally, you would have to install those explicitly. conan install -dev MyLib would install only MyLib, not MyDep locally, then if you want to have MyDep installed locally, you would install it under MyLib if you want MyLib to take it or at a different place, in which case then you would have to edit the editable_folder for the requirement that you want to use that folder. So you could decide between
or
or
Since the workspace is "parent", it works without any change. Using a git repo for another one is not that problematic, and you can control how you want the structure to be. I used git within git often and other than having to know where you are when you type a command, there is not many issues occurring. I cannot say for other VCS, but the idea here is you are in control of how those things will show up on your disk, so you pick the structure that fits you need. I agree that a solution that would not require you to edit your requirement inside your own conanfile.py would be great, but somehow this to me feel less of an issue since it only becomes applicable when you use --dev and you probably will want the structure to be the same once you start working on a workspace and then wants to reconstruct it. Seems more explicit and doesn't impact other packages that you do not use --dev or are outside of the workspace. There is the "name" clash that can happen but when you install the package if there is something with the same name, conan can just stop there and tell you, you then have to pass --output folder to override the installation name, and adjust the editable_folder on the recipe using it. |
Hello @memsharded :
I thought that is exactly what editables were meant for. When Conan removed the previous concept of workspaces, it pointed to this editable scheme as the alternative. If this is not the way to do a "workspace", is there going to be a way? I useful reference is the spack environment. Environments are similar to the old Conan workspaces. Is there anything like this in Conan?
The issue is the editables become global to your system and you can't have multiple versions of a package in development (without jumping through big hoops, like creating a new cache). Packages under development should not be transparent to the consumer - they should be very obvious and limited in scope, only affecting the "workspace" / group of packages you are co-developing. |
There may be 2 views on this.
|
Option 1 is bad because it points your whole system to a mutable package, which negates much of Conan's efforts to ensure reproducible builds. If the "official" version is bad and you never want to use it, then a new "official" version should be created and used. And, very importantly, that particular revision of that new official version should be immutable! |
Using a separate dedicated Conan Local Cache seems acceptable and cleaner to me. We are anyway using project-specific ones to keep the profiles and so on separated. |
The downside of that is you need to populate your new cache with all of your dependency tree, even if you're only developing a couple of them. For large packages, this can be a pretty heavy operation. The whole concept of "cache" is to prevent those long fetches by having a local mirror. Once you decide to make a cache serve as a workspace, it is no longer useful as a cache. IMO, Conan needs the cache and a workspace concept to make multi-package co-development reasonable. |
It is not an alternative. The 1.X workspaces were already using editables as building blocks, but the previous editable management based on external .ini files was simply not working. The concept has not changed, editables are still the necessary building block to be able to restore workspaces sometime in 2.X. I think you are still conflating both concepts. As I said, we are not building or inventing something out of the blue. The Python The fact that there is not yet in Conan 2.0 a "workspace" layer that manages the orchestration, local relative location, bootstraping, project-local definition of editables doesn't mean that that the current editables are incorrect or that they should implement those features. Those features still belong to the "workspace" layer, not to the editable layer, and when work on workspaces is resumed (it is part of 2.X roadmap), it will be focused on those things. I am not saying that this will not be considered, it is already in the 2.X roadmap. |
Hello @memsharded. Thanks for your reply!
I was talking about the original Conan workspaces. Editables were not introduced until around 1.12 or 1.13. Agreed that both the original workspaces and the post-1.13 workspaces had flaws that needed fixing.
Another well-established Python tool is the virtual environment to sandbox your dependencies. I do not have a problem with using a python editable within a virtual environment. That is effectively the behavior I think we need for Conan workspaces. It's the global-ness of the editables that I find offensive and I would like a workspace akin to a virtual environment so I can restrict which builds the mutable package is affecting. |
#15992 is centralizing feedback and effort for Conan 2 workspaces, lets close this one and track progress there. |
These comments were relevant as of version 1.18.
We were early adopters of Workspaces and we continue to rely it for our workflow. Unfortunately, the changes introduced in 1.13, have broken our workflow and we're stuck at a previous version of Conan. I have seen and commented on issues that are components of workspaces and deal with the issues I'm going to discuss (#4840, #4004, #4803, #4751, #5291, #4802, #4800) but I feel like we need an issue to discuss the design as a whole. My main focus is workspaces, but I'll share some opinions on editables as well, since they are closely related. Here is some feedback.
TLDR: Layouts, editables, and the current CMake workspace generator feel off the mark to me. I need more of a super build that retains the features we know and love from Conan.
Layouts
Layout files allow you to manually provide the paths Conan needs to generate conaninfo files. This is motivated by the fact that most packages in development have not had an install step and, therefore, the paths to libs, headers, and bins are somewhere in the build directory. Dependent packages need an alternate
package_info
to tell them where to find the goodies they need in the build directory.Unfortunately, layout files are problematic for several reasons:
Layout files can conflict with reality. Layout files allow you to specify externally what is happening internally, and the two can easily be in conflict. Layout files give the illusion that you can direct Conan to copy the output files to those locations, when actually you're simply telling Conan where you expect those files to end up in the build directory. In other words, layout files are presented as a remapping of output file locations, when actually they force Conan to look at particular location, whether the files are there or not.
It defeats the convenience of package_info. The ability of a package to fill out its own info is a tremendous power of Conan. It allows dependent packages to automatically pick up paths and other features. This is analogous to modern CMake's use of
target_link_libraries
, which passes along include directories, library paths, and usage requirements. Using layout files,package_info
is overridden with a manual file the consumer has to provide with some internal knowledge of the inner-workings of the package.Conan does provide a way to specify this layout within
package_info
. IMHO, this is much preferred, since it is the recipe that knows where the output files live. (See above - the user shouldn't have to assume these locations externally). The issue I have with this is the reliance on theself.in_local_cache
switch. The condition should not be whether the recipe is being consumed from the local cache (in fact a recipe shouldn't know about the cache at all). The condition should be if the consumer is consuming from the build directory or the package directory. There is a direct CMake analog for this as well: package layout config files. Look at the followingCMakeLists.txt
:You can see that the include directory is specified for both scenarios: if you're consuming from the build folder or if you're consuming from the install folder. CMake will generate a configuration file for each that contains all of the necessary include paths and usage requirements. (The actual config file generation is not shown in that snippet, but it involves CMake export and install functions).
CMake is right to rely on the package's
CMakeLists.txt
to define how to consume the package. Similarly, Conan should do the same within the recipe. The ability to do this inpackage_info
is sufficient, but we need a better condition thanin_local_cache
and a way for workspaces to trigger the in-build condition.New syntax for the same mechanism. Given that
package_info
and the full power of python is already available. Why introduce Jinja templating? Obviously this is necessary if you're going to do layout files in the ini format, but this only reinforces the notion that this logic should be in the recipe itself, not provided externally with new syntax.Out-of-source builds are broken. Layout files hardcode paths. There are some Jinja template expressions, but these are quite limited. Right now, the only way to do an out-of-source build is to blindly go up directories in relative path (ie.
../build
). Not only is this dangerous (could overwrite an existing directory), it doesn't allow the user control over where the build directory is. This is especially critical when the user wishes to build more than one configuration at the same time with multiple build folders. CMake does things relative toCMAKE_CURRENT_BINARY_DIR
orINSTALL_PREFIX
and Conan should follow suite.Editables
Editables allow you to short-circuit Conan to point to some local copy of a recipe instead of fetching it from the local cache. It does this globally for any other recipe that refers to it. As a developer who works on many things at once, this is problematic. It is too big of a hammer to globally override Conan to point to a alternate recipe for any and all dependent packages that reference it. I will happily continue to use workspaces, which explicitly states the intent for co-developed recipes and leaves the others alone. Please consider workspaces as the non-global editable and keep that functionality.
CMake Generator
The CMake Generator creates a cmake script that will
add_subdirectory
on the source folders (defined in the layout file). The actual generated script isn't very useful.When you're developing recipes, you rely on
conan build
to perform non-trivial build steps. It is very useful to be able to reuse the settings and options in the recipe during the build. Even for end consumers, we useconan build
as recommended in Mastering Conan. By using the generated cmake script, you lose this ability.User/Channel
Why has user and channel been added as a requirement to the workspace file? When you are specifying the local path to the package in the workspace file, user and channel (and even version number) are meaningless.
Some Suggestions
I can see workspaces being used in two modes:
Super Build
This is the primary use-case. I have unique packages that I own and want to develop, sometimes together, sometimes individually. I temporarily create a workspace file that indicates my intent to develop them together. When I issue a
conan workspace
command, instead of generating a script with a bunch ofadd_subdirectory
calls, it would generate a script with custom commands or similar that would invokeconan install
andconan build
. By doing this, you would gain:conan build
arguments, settings, options still workconan package
as part of the custom command and then all of the special build folder mapping goes awayconan build
already knows where and how to build the source,package_info
already knows how to communicate paths and artifact info.Self-Managed Build
In some cases, the source code of multiple packages are always developed together and their relative source locations are deterministic. This would be the case in a monorepo or git submodule situation. (This happens to be how I am using workspaces). In this case, I have my own
CMakeLists.txt
that knows where toadd_subdirectory
and a rootconanfile.py
that builds the monorepo viaconan build
. I also have otherconanfile.py
files scattered throughout the monorepo because packages within the monorepo should declare their own dependencies and remain independent, even if they are source controlled together. Finally, I have checked in a workspace file, because these packages are necessarily developed together. The workspace is critical to building the monorepo.In this scenario, what I need from Conan is to walk all the dependencies and install all of the third-party packages like it normally would in a
conan install
. This is something I could do prior to Conan 1.13, although there were a few warts.I think the Self-Managed Build is really just a special case of the Super Build where I don't bother to use the generated super build script and instead use my own
CMakeLists.txt
.To help us debug your issue please explain:
The text was updated successfully, but these errors were encountered: