sapling/eden/mononoke
Stefan Filip 3f0b08e46f segmented_changelog: add version field to IdMap
Summary:
The version is going to be used to seamlessly upgrade the IdMap. We can
generate the IdMap in a variety of ways. Naturally, algorithms for generating
the IdMap may change, so we want a mechanism for updating the shared IdMap.

A generated IdDag is going to require a specific IdMap version. To be more
precise, the IdDag is going to specify which version of IdMap it has to be
interpreted with.

Reviewed By: quark-zju

Differential Revision: D23501158

fbshipit-source-id: 370e6d9f87c433645d2a6b3336b139bea456c1a0
2020-09-03 16:33:20 -07:00
..
benchmark blobrepo: instantiate segmented changelog as an attribute 2020-09-02 17:20:42 -07:00
blobimport_lib mononoke: blobimport record highest imported generation number 2020-08-12 08:50:35 -07:00
blobrepo blobrepo: instantiate segmented changelog as an attribute 2020-09-02 17:20:42 -07:00
blobrepo_utils Regenerate all Cargo.tomls after upgrade to futures 0.3.5 2020-07-06 20:49:43 -07:00
blobstore Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
blobstore_sync_queue mononoke: add context to blobstore_sync_queue get error handling 2020-08-11 02:52:44 -07:00
bonsai_git_mapping pushrebase: remove OntoBookmarkParams and clean up interface 2020-08-14 02:28:55 -07:00
bonsai_globalrev_mapping pushrebase: remove OntoBookmarkParams and clean up interface 2020-08-14 02:28:55 -07:00
bonsai_hg_mapping Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
bookmarks bookmarks_movement: handle services with all or no permitted paths 2020-08-25 09:14:09 -07:00
bulkops Regenerate all Cargo.tomls after upgrade to futures 0.3.5 2020-07-06 20:49:43 -07:00
cache_warmup Regenerate all Cargo.tomls after upgrade to futures 0.3.5 2020-07-06 20:49:43 -07:00
changesets Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
cmdlib mononoke_api: add HookManager 2020-08-25 09:14:07 -07:00
cmds mononoke: asyncify one function in redaction admin subcommand 2020-09-03 12:22:24 -07:00
commit_rewriting megarepotool: add gradual-merge-progress subcommand 2020-09-02 12:18:31 -07:00
common rust: mem::replace without using return value is just an assignment 2020-07-31 18:38:35 -07:00
derived_data Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
edenapi_server edenapi_server: use LogMiddleware 2020-09-03 11:59:32 -07:00
fastreplay mononoke: add a flag to disable short history fetching 2020-08-13 10:37:40 -07:00
filenodes Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
filestore mononoke: add context to alias deserialize error handling 2020-07-21 06:11:46 -07:00
git Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
gotham_ext gotham_ext: make StreamBody automatically delay post-request callbacks 2020-09-03 11:59:32 -07:00
hgcli asyncify connection accepting 2020-08-18 09:09:14 -07:00
hgproto mononoke/{hgproto,mercurial_bundles}: eliminate O(N^2) behavior in decoding 2020-07-08 08:07:13 -07:00
hook_tailer mononoke_api: add HookManager 2020-08-25 09:14:07 -07:00
hooks monononke/hooks: make no_bad_filenames public 2020-09-03 02:40:43 -07:00
lfs_import_lib autocargo: regenerate 2020-05-19 16:08:40 -07:00
lfs_protocol mononoke: try to compress values if they above cachelib limit 2020-06-20 01:05:54 -07:00
lfs_server gotham_ext: make StreamBody automatically delay post-request callbacks 2020-09-03 11:59:32 -07:00
load_limiter Regenerate all Cargo.tomls after upgrade to futures 0.3.5 2020-07-06 20:49:43 -07:00
manifest Regenerate all Cargo.tomls after upgrade to futures 0.3.5 2020-07-06 20:49:43 -07:00
mercurial Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
metaconfig config: add segmented changelog config parsing 2020-09-02 17:20:42 -07:00
microwave Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
mononoke_api mononoke: parallelize operations in create_commit scs method 2020-09-03 04:12:35 -07:00
mononoke_hg_sync_job mononoke_api: use bookmarks_movement for repo_move_bookmark 2020-08-25 09:14:08 -07:00
mononoke_types undesired fetches: regex-based reporting 2020-09-01 12:01:00 -07:00
mutable_counters admin: add a subcommand to manipulate mutable_counters 2020-04-16 03:19:44 -07:00
newfilenodes RFC mononoke: limit number of filenodes get_all_filenodes_maybe_stale 2020-08-12 14:33:43 -07:00
permission_checker mononoke/x509 identity: add OSS parsing of x509 certificates (#32) 2020-07-24 09:05:52 -07:00
phases bookmarks: extract BundleReplayData from BookmarkUpdateReason 2020-07-10 04:50:24 -07:00
pushrebase pushrebase: remove OntoBookmarkParams and clean up interface 2020-08-14 02:28:55 -07:00
reachabilityindex Remove crate_root from Rust dependency info 2020-08-31 14:43:24 -07:00
regenerate_hg_filenodes mononoke/regenerate_hg_filenodes: make regenerate_hg_filenodes public (#39) 2020-07-30 06:50:54 -07:00
repo_client repo_client: get rid of unneeded perf counters 2020-09-02 05:02:46 -07:00
repo_import mononoke/repo_import: add backsyncing to rewrite file paths, remove backup file 2020-09-03 06:43:08 -07:00
revset mononoke: try to print warning about expensive getbundle earlier 2020-08-21 13:00:45 -07:00
scs_server add thrift metadata support 2020-09-03 12:18:18 -07:00
segmented_changelog segmented_changelog: add version field to IdMap 2020-09-03 16:33:20 -07:00
server repo_client: get rid of unneeded perf counters 2020-09-02 05:02:46 -07:00
sshrelay asyncify connection accepting 2020-08-18 09:09:14 -07:00
tests mononoke/repo_import: add backsyncing to rewrite file paths, remove backup file 2020-09-03 06:43:08 -07:00
time_window_counter mononoke/lfs_server: popularity: add ODS counters, timeouts and tests 2020-07-15 03:39:23 -07:00
tunables undesired fetches: regex-based reporting 2020-09-01 12:01:00 -07:00
unbundle_replay bookmarks_movement: move hook running into bookmarks_movement 2020-08-25 09:14:07 -07:00
walker blobrepo: instantiate segmented changelog as an attribute 2020-09-02 17:20:42 -07:00
Cargo.toml utility to keep streaming clone data warm 2020-09-01 07:13:33 -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