Build the basis for tools working with dependencies, e.g. license checkers.
Abstract the repositories of various language ecosystems.
Support at least
Don't rely on the implementation of existing build tools. Implement the primitives of repositories in Clojure. Use existing Clojure libraries where feasable.
Out of scope:
Q: What are the primitive operations for the abstractions?
Q: Does a canonical format for artifact coordinates exist for all supported repositories?
Package URL (PURL) is a proposed format supporting many different repositories.
Q: What is the difference between an artifact and a dependency?
Q: How should versions be handled?
Q: Versioning strategies? Semantic versioning Build numbers Commit SHA
Q: Ordering of versions? Partial/total
Q: Search strategy? Collect by depth first search or breadth first search?
Q: Intermediate data structure in search?
Dependency tree, including conflicting versions of a dependency. Dependency tree is useful information in itself and can be rendered textually or as diagram to show the structure including conflicts.
Q: Final dependency data structure?
List of all dependencies of the project with conflicts resolved.
Q: How to collect transitive dependencies with excludes?
Set of excludes on the stack (will be unrolled returning from a level)
Can you improve this documentation?Edit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |