Go workspaces
Go workspaces help you to work with several modules in your project. When you create a go.work file, Go runs through the list of modules listed in the workspace, and creates a single list of dependencies. If go.mod files have replace
directives, Go will also take them into account. A generated single dependency list is applied to all the modules listed in the workspace.
When you create a go.work file, GoLand automatically adds all the modules in the project.
data:image/s3,"s3://crabby-images/937fa/937fa1fad3b64b025340ac8b204a9f287c14793b" alt="Go workspaces Go workspaces"
Right-click the parent directory of your project and navigate to New | Go Workspace File.
Also, you can now generate go.work from go.mod
if you have replace
directives there.
Place the caret at a
replace
directive, press AltEnter and select the Generate 'go.work' using 'replace' directives quick-fix.The underlying inspection that detects
replace
directives has the Warning severity and highlighting, meaning the relevant code is shown in a yellow box and the yellow warning triangle is shown in the top-right corner in the editor window.There may be no warning, however. If a generated workspace includes Go modules that are not replaced in the original go.mod, the warning is not shown due to possible side effects caused by migration.
Click a
use
directive, press AltEnter, and select Merge multiple 'use' directives into one.
Thanks for your feedback!