sapling/eden/mononoke
Stanislau Hlebik 4e232ea94d mononoke: add mapping for megarepo
Summary:
Adding mappng to keep track of two things:
1) keep track of the latest source commit that was synced into a given target - this will be used during sync_changeset() method to validate if a parent changeset of a given changeset was already synced
2) which source commit maps to what target commit

Reviewed By: ikostia

Differential Revision: D28319908

fbshipit-source-id: f776d294d779695e99d644bf5f0a5a331272cc14
2021-05-11 02:54:01 -07:00
..
admin rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
aliasverify rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
alpn rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
backfill_derived_data rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
benchmark_filestore rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
benchmarks rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
blobimport rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
blobimport_lib rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
blobrepo mononoke: add mapping for megarepo 2021-05-11 02:54:01 -07:00
blobrepo_utils rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
blobstore megarepo: basic version of async-requests crate 2021-05-10 06:51:37 -07:00
blobstore_healer rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
blobstore_sync_queue rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
bonsai_git_mapping rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
bonsai_globalrev_mapping rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
bonsai_hg_mapping rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
bonsai_svnrev_mapping rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
bookmarks rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
bulkops mononoke: return id from bulkops fetch_ids 2021-05-06 13:58:30 -07:00
cache_warmup rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
changesets rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
cmdlib cmdlib: add scuba sample builder to environment 2021-05-06 11:40:08 -07:00
cmds mononoke: sample size metadata for all component blobstores 2021-05-10 06:07:59 -07:00
commit_rewriting mononoke: add commit_rewriting logic to megarepo_api 2021-05-10 11:48:23 -07:00
common rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
derived_data rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
edenapi_server cmdlib: add scuba sample builder to environment 2021-05-06 11:40:08 -07:00
edenapi_service edenapi_service: use custom_cbor_stream for trees 2021-05-06 09:14:10 -07:00
fastreplay mononoke: sample size metadata for all component blobstores 2021-05-10 06:07:59 -07:00
filenodes rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
filestore rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
git rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
gotham_ext edenapi_service: add CustomCborStream 2021-05-06 09:14:10 -07:00
hgcli rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
hgproto rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
hook_tailer rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
hooks rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
lfs_import rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
lfs_import_lib rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
lfs_protocol rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
lfs_server cmdlib: add scuba sample builder to environment 2021-05-06 11:40:08 -07:00
load_limiter rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
manifest rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
megarepo_api mononoke: add mapping for megarepo 2021-05-11 02:54:01 -07:00
mercurial rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
metaconfig mononoke: sample harder in the walker 2021-05-06 07:07:02 -07:00
microwave cmdlib: add scuba sample builder to environment 2021-05-06 11:40:08 -07:00
mononoke_api rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
mononoke_api_hg rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
mononoke_hg_sync_job rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
mononoke_types mononoke: add mapping for megarepo 2021-05-11 02:54:01 -07:00
mutable_counters rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
newfilenodes rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
observability rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
permission_checker rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
phases rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
pushrebase rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
pushrebase_mutation_mapping rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
quiet_stream rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
reachabilityindex rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
regenerate_hg_filenodes rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
repo_attributes rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
repo_client mononoke: allow duplicate filenodes to be sent 2021-05-06 03:31:19 -07:00
repo_factory mononoke: sample size metadata for all component blobstores 2021-05-10 06:07:59 -07:00
repo_import disable debuginfo stripping to work around eu-strip failing 2021-05-10 08:35:16 -07:00
revset rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
scs move scm/service into eden/mononoke/scs 2021-05-10 05:53:38 -07:00
scs_server move scm/service into eden/mononoke/scs 2021-05-10 05:53:38 -07:00
segmented_changelog segmented_changelog: update version logging to obey context discard 2021-05-06 11:40:09 -07:00
server mononoke: sample size metadata for all component blobstores 2021-05-10 06:07:59 -07:00
sshrelay rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
statistics_collector rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
streaming_clone rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
tests mononoke: sample size metadata for all component blobstores 2021-05-10 06:07:59 -07:00
time_window_counter rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
tunables rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
unbundle_replay cmdlib: add scuba sample builder to environment 2021-05-06 11:40:08 -07:00
upload_globalrevs rust: remove patch for async-compression 2021-05-05 12:20:34 -07:00
walker mononoke: sample size metadata for all component blobstores 2021-05-10 06:07:59 -07:00
Cargo.toml mononoke: add mapping for megarepo 2021-05-11 02:54:01 -07:00
README.md mononoke: add README.md and the missing pieces for supporting cargo (#13) 2020-02-13 00:12:36 -08:00

Mononoke

Mononoke is a next-generation server for the Mercurial source control system, meant to scale up to accepting thousands of commits every hour across millions of files. It is primarily written in the Rust programming language.

Caveat Emptor

Mononoke 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.

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:

  • Full support for a standard cargo build.
  • Open source replacements for Facebook-internal services (blob store, logging etc).

The current goal is to get Mononoke working on Linux. Other Unix-like OSes may be supported in the future