The commented out dependency is a transitive dependency via contingent-claims, which I want to use. However, if I uncomment that line, and try to import form daml-ctl, I see
./main/daml/**/*.daml|16 col 8| not found:Error:Could not load module ‘Daml.Control.Monad.Trans.Class’ It is a member of the hidden package ‘daml-ctl-2.0.0’. You can run ‘:set -package daml-ctl’ to expose it. (Note: this unloads all the modules in the current scope.)
Hi @Luciano, this is to be expected. In general it is only allowed to import modules from direct dependencies. The error message is a bit misleading, but the important part is that the package ‘daml-ctl-2.0.0’ is “hidden” because it’s not a direct dependency (regardless of it being a transitive dependency). This is true for both regular and data- dependencies, and it’s inherited from GHC.
In this case, I’d suggest simply uncommenting that line, but I’d like to understand your motivation for removing it.
As for why we don’t expose transitive deps by default: Only exposing direct deps limits module collisions to a minimum and therefore the modules you might have to rename. E.g., an older stdlib is usually not in scope so you don’t have to worry about renaming modules from it to avoid a collision unless you truly need a direct reference to the old stdlib.
Hey @akrmn I thought you had posted here that sometimes clearing the build directory helped. It turned out in this case to be a combination of this, and the fact that I initialized the language server from the wrong directory (src/main instead of src). Restarting the IDE seems to have helped.
I usually recommend first trying to reproduce weird dependency issues with daml build. I’m not actually aware of any cases where you currently need to daml clean so if you are, I’d be interested in examples.