-
-
Notifications
You must be signed in to change notification settings - Fork 366
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
Add overloads to try and simplify resolveDeps workflows #3330
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The issue with these overloads is, that they hide the fact dependencies need to bind to a context. API users now are encouraged to collect dependencies from various contexts (e.g. different modules). This led to various issues in the past, where modules with different contexts (Scala version, platform, ...) were resolved with the wrong (local) context.
By introducing the BoundDep
, we made the context explicit and all targets returning dependencies originating in non-local modules return collections of BoundDep
s instead of Dep
s.
Maybe, these overloads should have the word "local" in their names? Although the type alone already has that semantic, its name Dep
is way to generic to make that obvious.
Sure, I think |
TBH looking at all the callsites, resolving to "this module" by default definitely seems like the right thing to do. I do think that for the bulk of users, resolving "this module's" dependencies is what they want. And it's true that occasionally people will need to aggregate across multiple modules and feed it through the same context, but that seems like a pretty advanced use case that doesn't happen that often |
I have some ideas of how to make this API even better, will update the PR |
customizer = customizer, | ||
coursierCacheCustomizer = coursierCacheCustomizer, | ||
ctx = ctx | ||
).asSuccess.get.value |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This needs to be adjusted to throw a proper exception
@lefou took another pass at it. I think the code looks a lot nicer now; no more confusing nested One downside is the normal method call now needs to throw an exception if it fails, but that's what normal method calls do, and it shouldn't be too hard to wire up try/throw/catch to report a proper error |
coursier.cache.FileCache[coursier.util.Task] => coursier.cache.FileCache[coursier.util.Task] | ||
] = None) { | ||
|
||
def resolveDeps[T: CoursierModule.Resolvable](deps: IterableOnce[T], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Using a typeclass here is a bit annoying, but it's necessary to work around the "multiple overloads cant have default params" problem that would otherwise make the user-facing API a lot worse
Couldn't we provide a version returning a |
|
I had some idea in mind for quite a while, that we split the coursier resolution into two steps, resolution and fetching. Lots of meta-operations like finding updates, inspecting licenses, ... only require the resolution without the fetched artifacts. The resolution could also be locked and persisted for later reuse in a more reproducible setup. Since this affects |
Making This is pretty fundamental to Mill's multi-stage evaluation model here. Given all the callsites within the Mill codebase work just fine with the more restricted callsites, I think it's probably the right move to mostly use the newer restricted API, and the older more flexible API is still available for whoever wants it. I'd like to get it in sooner rather than waiting for a complete re-think of the API, since it's a backwards compatible addition that fixes a pretty warty part of the Mill experience, and it doesn't block us from making more drastic cleanups later |
Updated a bunch of the examples to take advantage of this, which makes them a lot simpler |
Still a bit awkward, but less than before.
Semantics should be exactly the same, just moved a bunch of boilerplate into helper overloads.
Pull request: #3330