Yuya Nishihara
ce3d28e234
git: do not import refs from remote named "git"
...
I made it simply fail on explicit fetch/import, and ignored on implicit import.
Since the error mode is predictable and less likely to occur. I don't think it
makes sense to implement warning propagation just for this.
Closes #1690 .
2023-08-29 22:50:46 +09:00
Yuya Nishihara
04e2f5ed20
git: fix typo in GitFetchError message
2023-08-29 22:50:46 +09:00
Yuya Nishihara
35a596ff66
git: prohibit creation of remote named "git"
...
#1690
2023-08-29 22:50:46 +09:00
Yuya Nishihara
0e26ef7733
git: add constant for pseudo remote name "git"
2023-08-29 22:50:46 +09:00
Martin von Zweigbergk
f47da04a43
tree: delete recursive diff iterator, which is no longer used
2023-08-28 16:21:44 -07:00
Martin von Zweigbergk
1b24b522f6
tree: move diff_summary()
to MergedTree
2023-08-28 16:21:44 -07:00
Martin von Zweigbergk
a7a2150328
tree: delete unused DiffSummary::is_empty()
2023-08-28 16:21:44 -07:00
Martin von Zweigbergk
dc06bbc7d1
commit: migrate remaining uses of Commit::tree_id()
and delete it
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
7bfd439bd1
rewrite: return MergedTree
from merge_commit_trees_without_repo()
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
90e78a1424
rewrite: return MergedTree
from merge_commit_trees()
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
494026a9bf
cli: merge trees via MergedTree
in rebase_to_dest_parent()
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
bd6098e09e
cli: merge trees via MergedTree
in jj move
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
873a6f0674
merged_tree: add a function for merging 3 MergedTree
s
...
With the already existing `MergedTree::resolve()` and all the recent
refactorings into `Merge<T>`, it's now very easy to add support for
3-way merging of `MergedTree` instances.
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
1674a421ec
commit_builder: take MergedTreeId
for root id argument
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
e5ec99d159
backout: propagate error from merging of trees
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
b19afb6d45
cli: migrate jj untrack
to MergedTree
API
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
6d89f0c0a0
cli: migrate jj restore
to MergedTree
API
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
a0291e99d7
cli: migrate cat
, files
& git submodule print
to MergedTree
API
2023-08-28 15:58:34 -07:00
Martin von Zweigbergk
d753c85e01
cli: migrate most diff-editing functions to MergedTree
API
2023-08-28 15:58:34 -07:00
Ilya Grigoriev
d3428d63a2
nix: Add poetry
to devDependencies for nix develop
...
This should allow Nix users to build the documentation in
`nix develop` following the instructions in `contributing.md`.
It feels a little weird to add a package manager and ask
people to use it inside nix, but I think it's simpler
than having two sets of instructions and dependencies
to maintain.
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
b67c115c29
docs: goodbye Github, hello GitHub
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
c8bb8fbeb2
Github actions to build docs
...
One action publishes the 'prerelease' version on every push
to `main`.
The other publishes a 'latest' version on every releasse.
I tested both of them, but not with branch protection rules.
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
8f29afaafd
docs: markdown fixups, mostly to remove links pointing outside docs
...
This makes mkdocs compile cleanly
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
fc49258d2f
docs: Set up mkdocs
and poetry
...
I initially was thinking of using `mdbook`, which looks a little better, but I
think versioning the docs is important, and the features I want are pretty much
only supported by the Mkdocs' "Material" theme.
Mkdocs is written in Python. The prerequesites for building docs on your
machine should be to install Python and Poetry, everything else should be
installed automatically by Poetry. See the edits to `contributing.md` for more details.
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
623c5e28c2
docs: change "shell script" codeblock to "shell"
...
```shell script
```
breaks mkdocs rendering
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
64140c34b7
docs: Move installation instructions from README to docs/
...
This allows the tutorial to reference them and will make it
easier to have different instructions for different versions.
We can later restore some instructions to the README, but I
think this is important since the installation instructions
do change in important (even if slight) ways from time to
time.
2023-08-28 10:43:48 -07:00
Ilya Grigoriev
d3bd1af37b
docs: minor markdown fixups
...
I am not sure these are necessary with `mkdocs` that I settled on,
but this allows `mdbook` to parse the markdown properly.
2023-08-28 10:43:48 -07:00
dependabot[bot]
9d7419497c
cargo: bump the cargo-dependencies group with 3 updates
...
Bumps the cargo-dependencies group with 3 updates: [regex](https://github.com/rust-lang/regex ), [rustix](https://github.com/bytecodealliance/rustix ) and [serde](https://github.com/serde-rs/serde ).
Updates `regex` from 1.9.3 to 1.9.4
- [Release notes](https://github.com/rust-lang/regex/releases )
- [Changelog](https://github.com/rust-lang/regex/blob/master/CHANGELOG.md )
- [Commits](https://github.com/rust-lang/regex/compare/1.9.3...1.9.4 )
Updates `rustix` from 0.38.8 to 0.38.9
- [Release notes](https://github.com/bytecodealliance/rustix/releases )
- [Commits](https://github.com/bytecodealliance/rustix/compare/v0.38.8...v0.38.9 )
Updates `serde` from 1.0.186 to 1.0.188
- [Release notes](https://github.com/serde-rs/serde/releases )
- [Commits](https://github.com/serde-rs/serde/compare/v1.0.186...v1.0.188 )
---
updated-dependencies:
- dependency-name: regex
dependency-type: direct:production
update-type: version-update:semver-patch
dependency-group: cargo-dependencies
- dependency-name: rustix
dependency-type: direct:production
update-type: version-update:semver-patch
dependency-group: cargo-dependencies
- dependency-name: serde
dependency-type: direct:production
update-type: version-update:semver-patch
dependency-group: cargo-dependencies
...
Signed-off-by: dependabot[bot] <support@github.com>
2023-08-28 09:13:46 -07:00
Martin von Zweigbergk
732e448458
diff_util: use MergedTree
throughout
...
This switches the whole `diff_util` module to working with
`MergedTree`, `Merge<Option<TreeValue>>` etc., so it can support
tree-level conflicts.
Since we want to avoid using `ConflictId`s, I switched the hash we use
for conflicts in `--git` style diffs to use an all-'0' id instead of
using the conflict id.
2023-08-27 07:50:28 -07:00
Martin von Zweigbergk
5309335405
diff_util: make diff_content()
return empty for missing path
...
I'm not sure this is a win on its own, but it simplifies coming
patches.
2023-08-27 07:50:28 -07:00
Martin von Zweigbergk
5ef925deb8
diff_util: unify handling of unexpected cases
...
This moves the error cases last in each `match` block, switches to
using format strings, and includes the full value in the message.
2023-08-27 07:50:28 -07:00
Martin von Zweigbergk
6df7db3dc0
merge_tools: pass MergedTree
to run_mergetool()
2023-08-27 07:35:01 -07:00
Martin von Zweigbergk
17fe5e39c5
merge_tools: pass MergedTree
s to edit_diff()
2023-08-27 07:35:01 -07:00
Martin von Zweigbergk
54b9ecce68
merge_tools: pass MergeTree
to run_mergetool_external()
2023-08-27 07:35:01 -07:00
Martin von Zweigbergk
a7e5ea06c0
tests: make test helper for snapshotting working copy return MergedTree
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
1895a55157
working_copy: make old_checkout
argument be MergedTreeId
...
I think this was the last piece for making the working copy handle
tree-level conflicts.
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
abf3853717
working_copy: return MergedTreeId
on snapshot
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
88e9933462
working_copy: enable storing multiple tree ids in state file
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
49e32aa532
merged_tree: teach tree builder to build multiple trees
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
1577b408a6
store: add function to look up MergedTree
by MergedTreeId
...
We'll start seeing `MergedTreeId` in more places and we'll want it to
be easy to look up the tree.
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
2dd2e77170
merged_tree: add entries()
for iterating over all entries
...
We already have `entries_matching()`, so this is just a version of
that that doesn't take a matcher.
2023-08-27 06:49:45 -07:00
Martin von Zweigbergk
36674e8f7e
merged_tree: make id()
return a MergedTreeId
...
We will rarely want to use the tree id without knowing whether it can
contain `TreeValue::Conflict` values, so let's make the callers check.
2023-08-27 06:49:45 -07:00
Yuya Nishihara
a0ae09f461
templates: reword signature placeholders to match description
2023-08-27 09:38:36 +09:00
Yuya Nishihara
f422f1300c
templater: move empty signature placeholder to user template
...
This patch also extracts format_detailed_signature() function to deduplicate
the "show" template bits.
The added placeholder templates aren't labeled as "empty". If needed, I think
the whole template can be labeled as "empty" (or "empty_commit") just like
"working_copy".
Closes #2112
2023-08-27 09:38:36 +09:00
Yuya Nishihara
b45da80c12
tests: add more tests for empty signature
...
As I'm going to change the Signature type to not fill out a placeholder
message, we need to test the builtin templates as well.
2023-08-27 09:38:36 +09:00
Yuya Nishihara
88b509f857
tests: do not use "author" template keyword to test string functions
...
I'm going to change the default formatting of empty Signature type, and
these tests should use a non-empty keyword.
2023-08-27 09:38:36 +09:00
Martin von Zweigbergk
a186b5ffce
cli: use MergedTree
in jj chmod
2023-08-26 08:16:57 -07:00
Martin von Zweigbergk
d0fb154e7e
cli: use MergedTreeBuilder
in jj chmod
2023-08-26 08:16:57 -07:00
Martin von Zweigbergk
389f27f042
working_copy: move writing of conflict objects into new tree builder
...
This introduces a `MergedTreeBuilder` type, which takes a set of base
trees and overrides. The idea is that it will be able to write
multiple trees or a legacy tree. For now, it's only able to write
legacy trees. To show that it works, the working copy's snaphotting
code has been updated to use it.
2023-08-26 08:16:57 -07:00
Martin von Zweigbergk
e4ba6a42fc
backends: store tree id conflicts as list with alternating signs
...
Now that we have `Merge::iter()` and friends, it's simpler to store
the tree ids in a single list.
2023-08-26 07:02:04 -07:00