GitXplorerGitXplorer
f

sapling

public
6245 stars
289 forks
245 issues

Commits

List of commits on branch main.
Unverified
8b50e204228076280ded49d36bf3be929e238026

Add glob_files function to EdenFsInstance

jjdelliot committed 7 hours ago
Unverified
d663e6f3568c93f5f5567d33dee1741128e138b2

absorb: fix deleted chunks' selectedRev

qquark-zju committed 8 hours ago
Unverified
7ecf5801c604f383a7129d864b09cb97bdf91d54

Fix wording of goto off warm warning

committed 9 hours ago
Unverified
07a63cdec490dfbbfcbfdae8ae6d8cef19e2066c

Add missing scopes to rust.Name

iiahs committed 10 hours ago
Unverified
dd355fc8e993e84b6a48c441e257b63184fe3692

Update large number formatting in eden stats

llyahdav committed 12 hours ago
Unverified
f475dc476a5430b4ea722df15f6be3b7d975050a

update "bytes" crate: 1.6.0 -> 1.9.0

committed 12 hours ago

README

The README file for this repository.

Sapling SCM

Sapling SCM is a cross-platform, highly scalable, Git-compatible source control system.

It aims to provide both user-friendly and powerful interfaces for users, as well as extreme scalability to deal with repositories containing many millions of files and many millions of commits.

Using Sapling

To start using Sapling, see the Getting Started page for how to clone your existing Git repositories. Checkout the Overview for a peek at the various features. Coming from Git? Checkout the Git Cheat Sheet.

Sapling also comes with an Interactive Smartlog (ISL) web UI for seeing and interacting with your repository, as well as a VS Code integrated Interactive Smartlog.

The Sapling Ecosystem

Sapling SCM is comprised of three main components:

  • The Sapling client: The client-side sl command line and web interface for users to interact with Sapling SCM.
  • Mononoke: A highly scalable distributed source control server. Not yet supported publicly, OSS is buildable for unsupported experimentation.
  • EdenFS: A virtual filesystem for efficiently checking out large repositories. Not yet supported publicly, OSS is buildable for unsupported experimentation.

Sapling SCM's scalability goals are to ensure that all source control operations scale with the number of files in use by a developer, and not with the size of the repository itself. This enables fast, performant developer experiences even in massive repositories with millions of files and extremely long commit histories.

Sapling CLI

The Sapling CLI, sl, was originally based on Mercurial, and shares various aspects of the UI and features of Mercurial.

The CLI code can be found in the eden/scm subdirectory.

Mononoke

Mononoke is the server-side component of Sapling SCM.

While it is used in production within Meta it is not yet supported for external usage. OSS builds in GitHub Actions are available for unsupported experimentation.

EdenFS

EdenFS is a virtual file system for managing Sapling checkouts.

While it is used in production within Meta it is not yet supported for external usage. OSS builds in GitHub Actions are available for unsupported experimentation.

EdenFS speeds up operations in large repositories by only populating working directory files on demand, as they are accessed. This makes operations like checkout much faster, in exchange for a small performance hit when first accessing new files. This is quite beneficial in large repositories where developers often only work with a small subset of the repository at a time.

More detailed EdenFS design documentation can be found at eden/fs/docs/Overview.md.

Building the Sapling CLI

The Sapling CLI currently builds and runs on Linux, Mac, and Windows. It can be built by running make oss in the eden/scm directory and running the resulting sl executable.

Building the Sapling CLI requires Python 3.8, Rust, CMake, and OpenSSL for the main cli, and Node and Yarn for the ISL web UI.

Getting in Contact

You can Report an Issue on GitHub or Join the Discord

License

The main project is licensed under GPL-2.0.

The website and ISL are licensed under MIT.

Library subprojects, such as minibytes, might have different licenses. Please refer to the LICENSE file and source code headers in each library for detailed information.