sapling/eden/mononoke
Mark Thomas 9e7badc92c metaconfig/parser: refactor storage config
Summary:
Refactor parsing of storage config using a new `Convert` trait to allow
definition of each part of parsing separately.

Differential Revision: D21766761

fbshipit-source-id: 7e224e9d322a3a16a64f5ebba2243bbe6341c8f0
2020-06-02 09:30:02 -07:00
..
apiserver mononoke: Add tunables - a simple form of config hot reloading 2020-04-30 16:08:30 -07:00
backsyncer cross_repo: record sync map version_name in synced_commit_mapping 2020-06-01 07:16:52 -07:00
benchmark mononoke: add Changesets::get_sql_changesets 2020-05-13 16:53:16 -07:00
blobimport_lib cross_repo: record sync map version_name in synced_commit_mapping 2020-06-01 07:16:52 -07:00
blobrepo RFC: introduce FilenodeResult 2020-06-01 05:27:34 -07:00
blobrepo_utils autocargo: regenerate 2020-05-19 16:08:40 -07:00
blobstore Rip out internal cache from SQLBlob 2020-06-01 10:09:55 -07:00
blobstore_sync_queue autocargo: regenerate 2020-05-19 16:08:40 -07:00
bonsai_git_mapping autocargo: regenerate 2020-05-19 16:08:40 -07:00
bonsai_globalrev_mapping mononoke: add merge commit validation 2020-05-20 11:17:21 -07:00
bonsai_hg_mapping rust: remove abandoned heapsize crate 2020-05-07 23:45:44 -07:00
bookmarks autocargo: regenerate 2020-05-19 16:08:40 -07:00
bulkops mononoke: update bulkops::fetch_all_public_changesets to return commits in order 2020-05-21 20:43:45 -07:00
cache_warmup RFC: introduce FilenodeResult 2020-06-01 05:27:34 -07:00
changesets mononoke: update bulkops::fetch_all_public_changesets to return commits in order 2020-05-21 20:43:45 -07:00
cmdlib mononoke: Use MononokeApp for mononoke server 2020-05-20 05:47:17 -07:00
cmds cross_repo: record sync map version_name in synced_commit_mapping 2020-06-01 07:16:52 -07:00
commit_rewriting cross_repo: record sync map version_name in synced_commit_mapping 2020-06-01 07:16:52 -07:00
common autocargo: regenerate 2020-05-19 16:08:40 -07:00
config_structs Replace hardcoded hgsql db address in mononoke_hg_sync_job 2020-06-01 06:05:36 -07:00
derived_data mononoke: remove DefferedDerivedMapping 2020-06-02 01:46:08 -07:00
edenapi_server/src edenapi_server: add history endpoint 2020-05-12 16:26:22 -07:00
fastreplay autocargo: regenerate 2020-05-19 16:08:40 -07:00
filenodes RFC: introduce FilenodeResult 2020-06-01 05:27:34 -07:00
filestore autocargo: regenerate 2020-05-19 16:08:40 -07:00
git autocargo: regenerate 2020-05-19 16:08:40 -07:00
gotham_ext/src edenapi_server: add repos endpoint 2020-05-08 12:07:02 -07:00
hgcli common/rust/{scuba, scribe}: use a Duration for flush 2020-06-01 01:38:58 -07:00
hgproto autocargo: regenerate 2020-05-19 16:08:40 -07:00
hook_tailer autocargo: regenerate 2020-05-19 16:08:40 -07:00
hooks autocargo: regenerate 2020-05-19 16:08:40 -07:00
lfs_import_lib autocargo: regenerate 2020-05-19 16:08:40 -07:00
lfs_protocol lfs_protocol: move LFS MIME type into protocol crate 2020-04-23 13:58:04 -07:00
lfs_server/src common/rust/failure_ext: get rid of error chain 2020-05-05 05:44:52 -07:00
load_limiter mononoke: remove getfiles from ratelimiter and perf counter 2020-05-19 04:43:00 -07:00
manifest Expose ctime from Blobstore::get() in mononoke 2020-05-06 00:55:07 -07:00
megarepolib autocargo: regenerate 2020-05-19 16:08:40 -07:00
mercurial autocargo: regenerate 2020-05-19 16:08:40 -07:00
metaconfig metaconfig/parser: refactor storage config 2020-06-02 09:30:02 -07:00
microwave autocargo: regenerate 2020-05-19 16:08:40 -07:00
mononoke_api/src scs_server: add track_history_across_deletions parameter 2020-05-26 05:38:55 -07:00
mononoke_types autocargo: regenerate 2020-05-19 16:08:40 -07:00
mutable_counters admin: add a subcommand to manipulate mutable_counters 2020-04-16 03:19:44 -07:00
newfilenodes mononoke: update various error enums to use #[source] 2020-05-05 05:44:52 -07:00
permission_checker mononoke/rust-shed: apply new coding style convention that separates oss-only code 2020-05-07 04:52:16 -07:00
phases Clean out unused deps from our TARGETS files 2020-04-14 03:38:11 -07:00
pushrebase tests_utils: add_file content can take ownership 2020-05-28 06:22:33 -07:00
reachabilityindex autocargo: regenerate 2020-05-19 16:08:40 -07:00
repo_client mononoke: process wantslfspointers from clienttelemtry 2020-06-01 15:19:36 -07:00
revset common/rust/failure_ext: get rid of error chain 2020-05-05 05:44:52 -07:00
scs_server/src Revert "rust/thrift: add an option to stop processing requests if client disconnected" 2020-05-28 07:41:09 -07:00
segmented_changelog mononoke: add IdMap::get_last_entry 2020-05-26 07:37:11 -07:00
server mononoke: remove unused deps for a couple of targets 2020-05-20 17:00:08 -07:00
sshrelay Clean out unused deps from our TARGETS files 2020-04-14 03:38:11 -07:00
tests mononoke: process wantslfspointers from clienttelemtry 2020-06-01 15:19:36 -07:00
time_window_counter mononoke/rust-shed: apply new coding style convention that separates oss-only code 2020-05-07 04:52:16 -07:00
tunables mononoke: add filenodes_disable tunable 2020-06-02 09:22:43 -07:00
unbundle_replay autocargo: regenerate 2020-05-19 16:08:40 -07:00
walker/src RFC: introduce FilenodeResult 2020-06-01 05:27:34 -07:00
Cargo.toml mononoke: Add logging blobstore 2020-05-15 10:28:31 -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