mirror of
https://github.com/facebook/sapling.git
synced 2024-10-10 16:57:49 +03:00
A Scalable, User-Friendly Source Control System.
be4ff47192
Summary: In the course of verifying a fix for `hg update --merge` in D6270272, I discovered a new bug in our merge logic in the Python code. As expained in the test plan, there was a case where a file was listed as "untracked" instead of "added" after a merge with `--tool :local`. I traced through what happens in stock Mercurial. After the call to `applyupdates()` in `update()` in `merge.py`, there is this code: ``` stats = applyupdates(repo, actions, wc, p2, overwrite, labels=labels) wc.flushall() if not partial: with repo.dirstate.parentchange(): repo.setparents(fp1, fp2) recordupdates(repo, actions, branchmerge) # update completed, clear state util.unlink(repo.vfs.join('updatestate')) if not branchmerge: repo.dirstate.setbranch(p2.branch()) ``` It turns out that `applyupdates()` can have the side-effect of adding new entries to the `actions` dict. In this case, we have a `'cd'` action for which an `'am'` action is generated. Our `merge_update()` function in `eden/hg/eden/__init__.py` did not have the `recordupdates()` call that the stock implementation of Mercurial does, so the `'am'` (for "add/merge") was not getting applied. It seems likely that introducing this `recordupdates()` call may fix other subtle bugs in Eden's Mercurial extension for which we do not yet have integration tests. Reviewed By: wez Differential Revision: D6279971 fbshipit-source-id: 901c1bc563a7a3910dde18cf2f0d8b8ff9cd6fbe |
||
---|---|---|
common | ||
eden | ||
external | ||
.buckconfig | ||
.gitignore | ||
CONTRIBUTING.md | ||
DEFS | ||
getdeps.py | ||
install | ||
LICENSE | ||
PATENTS | ||
README.md |
Eden
Eden is a project with several components, the most prominent of which is a virtual filesystem built using FUSE.
Caveat Emptor
Eden is still in early stages of development. We are making it available now because we plan to start making references to it from our other open source projects, such as Buck, Watchman, and Nuclide.
The version that we provide on GitHub does not build yet.
This is because the code is exported verbatim from an internal repository at Facebook, and not all of the scaffolding from our internal repository can be easily extracted. The key areas where we need to shore things up are:
- The reinterpretations of build macros in
DEFS
. - A process for including third-party dependencies (presumably via Git submodules) and wiring up the
external_deps
argument in the build macros to point to them. - Providing the toolchain needed to power the [undocumented]
thrift_library()
rule in Buck.
The goal is to get Eden building on both Linux and OS X, though Linux support is expected to come first.