`delete.namespace` reportedly flags dependents in `lib` (why?)
Closed this issue · 4 comments
Describe and demonstrate the bug
I don't have a reproduction; here's an example that doesn't repro:
project.create
fork lib.base up.base
delete.namespace up.base
First step is to reproduce and explain the issue better
Screenshots
Environment (please complete the following information):
Additional context
Transcript that reproduces the issue:
```ucm
fresh/main> builtins.merge
```
```unison
foo : Text
foo = "I am going to be deleted"
lib.mylibrary.bar : Text
lib.mylibrary.bar = foo ++ foo
```
```ucm
fresh/main> add
fresh/main> delete.term foo
```
The way that this comes up in practice is that a library has a reference to an unnamed definition (probably due to footguns in ucm, a lot of which have been resolved) and you have a name for that definition. The name might be in your project directly, or it might be in an old version of base that you still depend on (perhaps transitively).
Ok, so then it sounds like the logic is working as intended after all, but we need a workaround for the possibly-outdated bug of creating unnamed definitions?
Then is the thinking that namespace.dependents
doesn't include lib, so that gives the clean report after delete.namespace.force
? We should probably have a namespace.dependents.all
or something then to help figure out what's going on.
possibly-outdated bug of creating unnamed definitions?
There are definitely still ways to end up in this situation, and fairly easily. #5044 and #5381 are two that quickly come to mind.
FWIW I don't think that it ever really makes sense to force people to deal with this. If the library has an unnamed dependency then that's an issue for the library, not for the person using it.