mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-16 00:56:23 +00:00
eb91547e52
Some checks are pending
binaries / Build binary artifacts (push) Waiting to run
nix / flake check (push) Waiting to run
build / build (, macos-13) (push) Waiting to run
build / build (, macos-14) (push) Waiting to run
build / build (, ubuntu-latest) (push) Waiting to run
build / build (, windows-latest) (push) Waiting to run
build / build (--all-features, ubuntu-latest) (push) Waiting to run
build / Build jj-lib without Git support (push) Waiting to run
build / Check protos (push) Waiting to run
build / Check formatting (push) Waiting to run
build / Check that MkDocs can build the docs (push) Waiting to run
build / Check that MkDocs can build the docs with Poetry 1.8 (push) Waiting to run
build / cargo-deny (advisories) (push) Waiting to run
build / cargo-deny (bans licenses sources) (push) Waiting to run
build / Clippy check (push) Waiting to run
Codespell / Codespell (push) Waiting to run
website / prerelease-docs-build-deploy (ubuntu-latest) (push) Waiting to run
Scorecards supply-chain security / Scorecards analysis (push) Waiting to run
This also fixes the Xethub link, by pointing it to the web archive, which no longer is available.
91 lines
4.1 KiB
Markdown
91 lines
4.1 KiB
Markdown
# Roadmap
|
|
|
|
This documents some of the goals we have. Many of them are quite independent.
|
|
|
|
> **Note:** Most people contributing to Jujutsu do so in their spare time, which
|
|
> means that we cannot attach any target dates to any of the goals below.
|
|
|
|
## Support for copies and renames
|
|
|
|
We want to support copy tracing in a way that leaves it up to the commit backend
|
|
to either record or detect copies. That should let us work with existing Git
|
|
repos (Git does not record copies, it detects them on the fly) as well as with
|
|
very large repos where detection would be too slow. See
|
|
[design doc][copy-design-doc].
|
|
|
|
## Forge integrations
|
|
|
|
We would like to make it easier to work with various popular forges by providing
|
|
something like `jj github submit`, `jj gitlab submit`, and `jj gerrit send`. For
|
|
popular forges, we might include that support by default in the standard `jj`
|
|
binary.
|
|
|
|
## Submodule support
|
|
|
|
Git submodules are used frequently enough in large Git repos that we will
|
|
probably need to [support them][submodules]. There are still big open
|
|
questions around UX.
|
|
|
|
## Better Rust API for UIs
|
|
|
|
UIs like [gg] currently have to duplicate quite a bit of logic from `jj-cli`. We
|
|
need to make this code not specific to the CLI (e.g. return status objects
|
|
instead of printing messages) and move it into `jj-lib`.
|
|
|
|
## RPC API
|
|
|
|
One problem with writing tools using the Rust API is that they will only work
|
|
with the backends they were compiled with. For example, a regular [gg] build
|
|
will not work on Google repos because it doesn't have the backends necessary to
|
|
load them. We want to provide an RPC API for tools that want to work with an
|
|
unknown build of `jj` by having the tool run something like `jj api` to give it
|
|
an address to talk to.
|
|
|
|
In addition to helping with the problem of unknown backends, having an RPC API
|
|
should make it easier for tools like VS Code that are not written in Rust. The
|
|
RPC API will probably be at a higher abstraction level than the Rust API.
|
|
|
|
See [design doc][api-design-doc].
|
|
|
|
## Open-source cloud-based repos (server and daemon process)
|
|
|
|
Google has an internal Jujutsu server backed by a database. This server allows
|
|
commits and repos (operation logs) to be stored in the cloud (i.e. the database).
|
|
Working copies can still be stored locally.
|
|
|
|
In order to reduce latency, there is a local daemon process that caches reads
|
|
and writes. It also prefetches of objects it thinks the client might ask for
|
|
next. In also helps with write latency by optimistically answering write
|
|
requests (it therefore needs to know the server's hashing scheme so it can
|
|
return the right IDs).
|
|
|
|
We (the project, not necessarily Google) want to provide a similar experience
|
|
for all users. We would therefore like to create a similar server and daemon.
|
|
The daemon might be the same process as for the RPC API mentioned above.
|
|
|
|
## Virtual file system (VFS)
|
|
|
|
For very large projects and/or large files, it can be expensive to update the
|
|
working copy. We want to provide a VFS to help with that. Updating the working
|
|
copy to another commit can then be done simply by telling the VFS to use the
|
|
other commit as base, without needing to download any large files in the target
|
|
commit until the user asks for them via the file system. A VFS can also make it
|
|
cheap to snapshot the working copy by keeping track of all changes compared to
|
|
the base commit.
|
|
|
|
Having a VFS can also be very benefial for [`jj run`][jj-run], since we can then
|
|
cheaply create temporary working copies for the commands to run in.
|
|
|
|
## Better support for large files
|
|
|
|
We have talked about somehow using content-defined chunking (CDC) to reduce
|
|
storage and transfer costs for large files. Maybe we will store files in our
|
|
future cloud-based server using the same model as [XetHub][xet-storage].
|
|
|
|
|
|
[api-design-doc]: https://docs.google.com/document/d/1rOKvutee5TVYpFhh_UDNZDxfUKyrJ8rjCNpFaNHOHwU/edit?usp=sharing&resourcekey=0-922ApyoAjuXN_uTKqmCqjg
|
|
[copy-design-doc]: design/copy-tracking.md
|
|
[gg]: https://github.com/gulbanana/gg
|
|
[jj-run]: https://github.com/martinvonz/jj/issues/1869
|
|
[submodules]: https://github.com/martinvonz/jj/issues/494
|
|
[xet-storage]: https://web.archive.org/web/20240914200921/https://xethub.com/assets/docs/concepts/xet-storage
|