2021-12-03 14:34:17 +01:00
|
|
|
scalar(1)
|
|
|
|
=========
|
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
2022-07-12 02:06:06 +02:00
|
|
|
scalar - A tool for managing large Git repositories
|
2021-12-03 14:34:17 +01:00
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
|
|
|
[verse]
|
2021-12-03 14:34:24 +01:00
|
|
|
scalar clone [--single-branch] [--branch <main-branch>] [--full-clone] <url> [<enlistment>]
|
2021-12-03 14:34:22 +01:00
|
|
|
scalar list
|
2021-12-03 14:34:19 +01:00
|
|
|
scalar register [<enlistment>]
|
2021-12-03 14:34:20 +01:00
|
|
|
scalar unregister [<enlistment>]
|
2021-12-03 14:34:25 +01:00
|
|
|
scalar run ( all | config | commit-graph | fetch | loose-objects | pack-files ) [<enlistment>]
|
2021-12-03 14:34:27 +01:00
|
|
|
scalar reconfigure [ --all | <enlistment> ]
|
scalar: implement `scalar diagnose`
Over the course of Scalar's development, it became obvious that there is
a need for a command that can gather all kinds of useful information
that can help identify the most typical problems with large
worktrees/repositories.
The `diagnose` command is the culmination of this hard-won knowledge: it
gathers the installed hooks, the config, a couple statistics describing
the data shape, among other pieces of information, and then wraps
everything up in a tidy, neat `.zip` archive.
Note: originally, Scalar was implemented in C# using the .NET API, where
we had the luxury of a comprehensive standard library that includes
basic functionality such as writing a `.zip` file. In the C version, we
lack such a commodity. Rather than introducing a dependency on, say,
libzip, we slightly abuse Git's `archive` machinery: we write out a
`.zip` of the empty try, augmented by a couple files that are added via
the `--add-file*` options. We are careful trying not to modify the
current repository in any way lest the very circumstances that required
`scalar diagnose` to be run are changed by the `diagnose` run itself.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2022-05-29 01:11:15 +02:00
|
|
|
scalar diagnose [<enlistment>]
|
2021-12-03 14:34:28 +01:00
|
|
|
scalar delete <enlistment>
|
2021-12-03 14:34:17 +01:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
|
|
|
|
2022-07-12 02:06:06 +02:00
|
|
|
Scalar is a repository management tool that optimizes Git for use in large
|
|
|
|
repositories. Scalar improves performance by configuring advanced Git settings,
|
|
|
|
maintaining repositories in the background, and helping to reduce data sent
|
2021-12-03 14:34:17 +01:00
|
|
|
across the network.
|
|
|
|
|
|
|
|
An important Scalar concept is the enlistment: this is the top-level directory
|
|
|
|
of the project. It usually contains the subdirectory `src/` which is a Git
|
|
|
|
worktree. This encourages the separation between tracked files (inside `src/`)
|
|
|
|
and untracked files, such as build artifacts (outside `src/`). When registering
|
|
|
|
an existing Git worktree with Scalar whose name is not `src`, the enlistment
|
|
|
|
will be identical to the worktree.
|
|
|
|
|
|
|
|
The `scalar` command implements various subcommands, and different options
|
2021-12-03 14:34:27 +01:00
|
|
|
depending on the subcommand. With the exception of `clone`, `list` and
|
|
|
|
`reconfigure --all`, all subcommands expect to be run in an enlistment.
|
2021-12-03 14:34:17 +01:00
|
|
|
|
2022-01-28 15:31:57 +01:00
|
|
|
The following options can be specified _before_ the subcommand:
|
|
|
|
|
|
|
|
-C <directory>::
|
|
|
|
Before running the subcommand, change the working directory. This
|
|
|
|
option imitates the same option of linkgit:git[1].
|
|
|
|
|
|
|
|
-c <key>=<value>::
|
|
|
|
For the duration of running the specified subcommand, configure this
|
|
|
|
setting. This option imitates the same option of linkgit:git[1].
|
|
|
|
|
2021-12-03 14:34:19 +01:00
|
|
|
COMMANDS
|
|
|
|
--------
|
|
|
|
|
2021-12-03 14:34:23 +01:00
|
|
|
Clone
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
clone [<options>] <url> [<enlistment>]::
|
|
|
|
Clones the specified repository, similar to linkgit:git-clone[1]. By
|
|
|
|
default, only commit and tree objects are cloned. Once finished, the
|
|
|
|
worktree is located at `<enlistment>/src`.
|
|
|
|
+
|
|
|
|
The sparse-checkout feature is enabled (except when run with `--full-clone`)
|
|
|
|
and the only files present are those in the top-level directory. Use
|
|
|
|
`git sparse-checkout set` to expand the set of directories you want to see,
|
|
|
|
or `git sparse-checkout disable` to expand to all files (see
|
|
|
|
linkgit:git-sparse-checkout[1] for more details). You can explore the
|
|
|
|
subdirectories outside your sparse-checkout by using `git ls-tree
|
|
|
|
HEAD[:<directory>]`.
|
|
|
|
|
|
|
|
-b <name>::
|
|
|
|
--branch <name>::
|
|
|
|
Instead of checking out the branch pointed to by the cloned
|
|
|
|
repository's HEAD, check out the `<name>` branch instead.
|
|
|
|
|
2021-12-03 14:34:24 +01:00
|
|
|
--[no-]single-branch::
|
|
|
|
Clone only the history leading to the tip of a single branch, either
|
|
|
|
specified by the `--branch` option or the primary branch remote's
|
|
|
|
`HEAD` points at.
|
|
|
|
+
|
|
|
|
Further fetches into the resulting repository will only update the
|
|
|
|
remote-tracking branch for the branch this option was used for the initial
|
|
|
|
cloning. If the HEAD at the remote did not point at any branch when
|
|
|
|
`--single-branch` clone was made, no remote-tracking branch is created.
|
|
|
|
|
2021-12-03 14:34:23 +01:00
|
|
|
--[no-]full-clone::
|
|
|
|
A sparse-checkout is initialized by default. This behavior can be
|
|
|
|
turned off via `--full-clone`.
|
|
|
|
|
2021-12-03 14:34:22 +01:00
|
|
|
List
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
list::
|
|
|
|
List enlistments that are currently registered by Scalar. This
|
|
|
|
subcommand does not need to be run inside an enlistment.
|
|
|
|
|
2021-12-03 14:34:19 +01:00
|
|
|
Register
|
|
|
|
~~~~~~~~
|
|
|
|
|
|
|
|
register [<enlistment>]::
|
|
|
|
Adds the enlistment's repository to the list of registered repositories
|
|
|
|
and starts background maintenance. If `<enlistment>` is not provided,
|
|
|
|
then the enlistment associated with the current working directory is
|
|
|
|
registered.
|
|
|
|
+
|
|
|
|
Note: when this subcommand is called in a worktree that is called `src/`, its
|
|
|
|
parent directory is considered to be the Scalar enlistment. If the worktree is
|
|
|
|
_not_ called `src/`, it itself will be considered to be the Scalar enlistment.
|
|
|
|
|
2021-12-03 14:34:20 +01:00
|
|
|
Unregister
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
unregister [<enlistment>]::
|
|
|
|
Remove the specified repository from the list of repositories
|
|
|
|
registered with Scalar and stop the scheduled background maintenance.
|
|
|
|
|
2021-12-03 14:34:25 +01:00
|
|
|
Run
|
|
|
|
~~~
|
|
|
|
|
|
|
|
scalar run ( all | config | commit-graph | fetch | loose-objects | pack-files ) [<enlistment>]::
|
|
|
|
Run the given maintenance task (or all tasks, if `all` was specified).
|
|
|
|
Except for `all` and `config`, this subcommand simply hands off to
|
|
|
|
linkgit:git-maintenance[1] (mapping `fetch` to `prefetch` and
|
|
|
|
`pack-files` to `incremental-repack`).
|
|
|
|
+
|
|
|
|
These tasks are run automatically as part of the scheduled maintenance,
|
|
|
|
as soon as the repository is registered with Scalar. It should therefore
|
|
|
|
not be necessary to run this subcommand manually.
|
|
|
|
+
|
|
|
|
The `config` task is specific to Scalar and configures all those
|
|
|
|
opinionated default settings that make Git work more efficiently with
|
|
|
|
large repositories. As this task is run as part of `scalar clone`
|
|
|
|
automatically, explicit invocations of this task are rarely needed.
|
|
|
|
|
2021-12-03 14:34:26 +01:00
|
|
|
Reconfigure
|
|
|
|
~~~~~~~~~~~
|
|
|
|
|
|
|
|
After a Scalar upgrade, or when the configuration of a Scalar enlistment
|
|
|
|
was somehow corrupted or changed by mistake, this subcommand allows to
|
|
|
|
reconfigure the enlistment.
|
|
|
|
|
2021-12-03 14:34:27 +01:00
|
|
|
With the `--all` option, all enlistments currently registered with Scalar
|
|
|
|
will be reconfigured. Use this option after each Scalar upgrade.
|
|
|
|
|
scalar: implement `scalar diagnose`
Over the course of Scalar's development, it became obvious that there is
a need for a command that can gather all kinds of useful information
that can help identify the most typical problems with large
worktrees/repositories.
The `diagnose` command is the culmination of this hard-won knowledge: it
gathers the installed hooks, the config, a couple statistics describing
the data shape, among other pieces of information, and then wraps
everything up in a tidy, neat `.zip` archive.
Note: originally, Scalar was implemented in C# using the .NET API, where
we had the luxury of a comprehensive standard library that includes
basic functionality such as writing a `.zip` file. In the C version, we
lack such a commodity. Rather than introducing a dependency on, say,
libzip, we slightly abuse Git's `archive` machinery: we write out a
`.zip` of the empty try, augmented by a couple files that are added via
the `--add-file*` options. We are careful trying not to modify the
current repository in any way lest the very circumstances that required
`scalar diagnose` to be run are changed by the `diagnose` run itself.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2022-05-29 01:11:15 +02:00
|
|
|
Diagnose
|
|
|
|
~~~~~~~~
|
|
|
|
|
|
|
|
diagnose [<enlistment>]::
|
|
|
|
When reporting issues with Scalar, it is often helpful to provide the
|
|
|
|
information gathered by this command, including logs and certain
|
|
|
|
statistics describing the data shape of the current enlistment.
|
|
|
|
+
|
|
|
|
The output of this command is a `.zip` file that is written into
|
|
|
|
a directory adjacent to the worktree in the `src` directory.
|
|
|
|
|
2021-12-03 14:34:28 +01:00
|
|
|
Delete
|
|
|
|
~~~~~~
|
|
|
|
|
|
|
|
delete <enlistment>::
|
|
|
|
This subcommand lets you delete an existing Scalar enlistment from your
|
|
|
|
local file system, unregistering the repository.
|
|
|
|
|
2021-12-03 14:34:17 +01:00
|
|
|
SEE ALSO
|
|
|
|
--------
|
2021-12-03 14:34:23 +01:00
|
|
|
linkgit:git-clone[1], linkgit:git-maintenance[1].
|
2021-12-03 14:34:17 +01:00
|
|
|
|
|
|
|
Scalar
|
|
|
|
---
|
|
|
|
Associated with the linkgit:git[1] suite
|