2011-05-23 16:42:58 +02:00
|
|
|
@title Arcanist User Guide: Configuring a New Project
|
|
|
|
@group userguide
|
|
|
|
|
2012-08-10 21:00:40 +02:00
|
|
|
Explains how to configure Arcanist projects with `.arcconfig` files.
|
2012-05-08 02:58:05 +02:00
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
= Overview =
|
2011-05-23 16:42:58 +02:00
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
In most cases, you should be able to use `arc` without specifically configuring
|
|
|
|
your project for it. If you want to adjust `arc` behaviors, you can create a
|
|
|
|
`.arcconfig` file in your project to provide project-specific settings.
|
2012-08-10 21:00:40 +02:00
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
= .arcconfig Basics =
|
2011-05-23 16:42:58 +02:00
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
An `.arcconfig` file is a JSON file which you check into your project's root.
|
2011-05-23 16:42:58 +02:00
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
Arcanist uses `.arcconfig` files to customize a number of things about its
|
|
|
|
behavior. The first thing you're likely to want to configure is the URI
|
|
|
|
for your Phabricator install. A simple, valid file looks something like this:
|
2011-05-23 16:42:58 +02:00
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
name=.arcconfig
|
2011-05-23 16:42:58 +02:00
|
|
|
{
|
2014-03-14 22:33:53 +01:00
|
|
|
"phabricator.uri" : "https://phabricator.example.com/"
|
2011-05-23 16:42:58 +02:00
|
|
|
}
|
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
For details on available options, see below.
|
2011-05-23 16:42:58 +02:00
|
|
|
|
2012-08-10 21:00:40 +02:00
|
|
|
NOTE: You should commit your `.arcconfig` file! It contains project
|
|
|
|
configuration, not user configuration.
|
|
|
|
|
2011-05-23 16:42:58 +02:00
|
|
|
= Advanced .arcconfig =
|
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
Common options are:
|
|
|
|
|
|
|
|
- **phabricator.uri**: the URI for the Phabricator install that `arc` should
|
|
|
|
connect to when run in this project. This option was previously called
|
|
|
|
`conduit_uri`.
|
|
|
|
- **repository.callsign**: The callsign of this repository in Diffusion.
|
|
|
|
Normally, `arc` can detect this automatically, but if it can't figure it out
|
|
|
|
you can specify it explicitly. Use `arc which` to understand the detection
|
|
|
|
process.
|
|
|
|
- **history.immutable**: Configures `arc` to use workflows which never rewrite
|
|
|
|
history in the working copy. By default, `arc` will perform some rewriting
|
|
|
|
of unpublished history (amending commit messages, squash merging) on some
|
|
|
|
workflows in Git. The distinctions are covered in detail below.
|
|
|
|
|
2011-05-23 16:42:58 +02:00
|
|
|
Other options include:
|
|
|
|
|
2014-03-14 22:33:53 +01:00
|
|
|
- **load**: list of additional Phutil libraries to load at startup.
|
|
|
|
See below for details about path resolution, or see
|
2015-06-20 14:25:08 +02:00
|
|
|
@{article@contributor:Adding New Classes} for a general introduction to
|
2014-03-14 22:33:53 +01:00
|
|
|
libphutil libraries.
|
|
|
|
- **https.cabundle**: specifies the path to an alternate certificate bundle
|
|
|
|
for use when making HTTPS connections.
|
2012-06-01 16:55:30 +02:00
|
|
|
- **lint.engine**: the name of a subclass of
|
2011-06-26 20:52:10 +02:00
|
|
|
@{class@arcanist:ArcanistLintEngine}, which should be used to apply lint
|
2012-06-01 16:55:30 +02:00
|
|
|
rules to this project. See @{article:Arcanist User Guide: Lint}.
|
|
|
|
- **unit.engine**: the name of a subclass of
|
2014-07-21 23:56:27 +02:00
|
|
|
@{class@arcanist:ArcanistUnitTestEngine}, which should be used to apply
|
2011-06-26 20:52:10 +02:00
|
|
|
unit test rules to this project. See
|
|
|
|
@{article:Arcanist User Guide: Customizing Lint, Unit Tests and Workflows}.
|
2014-03-14 22:33:53 +01:00
|
|
|
|
|
|
|
These options are supported, but their use is discouraged:
|
|
|
|
|
|
|
|
- **http.basicauth.user**: specify an HTTP basic auth username for use when
|
|
|
|
connecting to Phabricator.
|
|
|
|
- **http.basicauth.pass**: specify an HTTP basic auth password for use when
|
|
|
|
connecting to Phabricator.
|
|
|
|
- **https.blindly-trust-domains**: a list of domains to trust blindly over
|
|
|
|
HTTPS, even if their certificates are invalid. This is a brute force
|
|
|
|
solution to certificate validity problems, and is discouraged. Instead,
|
|
|
|
use valid certificates.
|
|
|
|
|
2014-05-26 12:52:24 +02:00
|
|
|
For a complete list of options, run `arc get-config`. Although all
|
2014-03-14 22:33:53 +01:00
|
|
|
options can be set in `.arcconfig`, some options (like `editor`) usually do not
|
|
|
|
make sense to set here because they're likely to vary from user to user.
|
2012-03-22 20:06:46 +01:00
|
|
|
|
2012-07-26 21:01:39 +02:00
|
|
|
= History Mutability =
|
2012-04-07 19:39:51 +02:00
|
|
|
|
2012-07-26 21:01:39 +02:00
|
|
|
Arcanist workflows run in two broad modes: either history is //mutable// or
|
|
|
|
//immutable//. Under a //mutable// history, `arc` commands may rewrite the
|
|
|
|
working copy history; under an //immutable// history, they may not.
|
2012-04-07 19:39:51 +02:00
|
|
|
|
2012-07-26 21:01:39 +02:00
|
|
|
You control history mutability by setting `history.immutable` to `true` or
|
|
|
|
`false` in your configuration. By default, it is `false` in Git (i.e.,
|
|
|
|
//mutable//) and `true` in Mercurial (i.e., //immutable//). The sections below
|
|
|
|
explain how these settings affect workflows.
|
2012-04-07 19:39:51 +02:00
|
|
|
|
2012-07-26 21:01:39 +02:00
|
|
|
== History Mutability: Git ==
|
2012-04-07 19:39:51 +02:00
|
|
|
|
2012-07-26 21:01:39 +02:00
|
|
|
In a workflow with //mutable// history, you rewrite local history. You develop
|
2015-05-31 02:07:45 +02:00
|
|
|
in feature branches, but squash or amend before pushing by using `git commit
|
|
|
|
--amend`, `git rebase -i`, or `git merge --squash`. Generally, one idea in
|
2012-07-26 21:01:39 +02:00
|
|
|
the remote is represented by one commit.
|
|
|
|
|
|
|
|
In a workflow with //immutable// history, you do not rewrite local history. You
|
|
|
|
develop in feature branches and push them without squashing commits. You do not
|
2015-05-31 02:07:45 +02:00
|
|
|
use `git commit --amend` or `git rebase -i`. Generally, one idea in the
|
2012-07-26 21:01:39 +02:00
|
|
|
remote is represented by many commits.
|
2012-04-07 19:39:51 +02:00
|
|
|
|
|
|
|
Practically, these are the differences you'll see based on your setting:
|
|
|
|
|
|
|
|
- **Mutable**
|
|
|
|
- `arc diff` will prompt you to amend lint changes into HEAD.
|
|
|
|
- `arc diff` will amend the commit message in HEAD after creating a
|
|
|
|
revision.
|
|
|
|
- `arc land` will default to the `--squash` strategy.
|
2012-07-26 21:01:39 +02:00
|
|
|
- `arc amend` will amend the commit message in HEAD with information from
|
|
|
|
the corresponding or specified Differential revision.
|
2012-04-07 19:39:51 +02:00
|
|
|
- **Immutable**
|
|
|
|
- `arc diff` will abort if it makes lint changes.
|
|
|
|
- `arc diff` will not amend the commit message in HEAD after creating a
|
|
|
|
revision.
|
|
|
|
- `arc land` will default to the `--merge` strategy.
|
2012-07-26 21:01:39 +02:00
|
|
|
- `arc amend` will exit with an error message.
|
|
|
|
|
|
|
|
== History Mutability: Mercurial ==
|
|
|
|
|
|
|
|
Before version 2.2, stock Mercurial has no history mutation commands, so
|
|
|
|
this setting has no effect. With Mercurial 2.2. or newer, making history
|
|
|
|
//mutable// means:
|
|
|
|
|
|
|
|
- **Mutable** (versions 2.2 and newer)
|
|
|
|
- `arc diff` will amend the commit message in `.` after creating a
|
|
|
|
revision.
|
|
|
|
- `arc amend` will amend the commit message in `.` with information from
|
|
|
|
the corresponding or specified Differential revision.
|
|
|
|
- **Immutable** (or versions prior to 2.2)
|
|
|
|
- `arc diff` will not amend the commit message in `.` after creating a
|
|
|
|
revision.
|
|
|
|
- `arc amend` will exit with an error message.
|
2012-04-07 19:39:51 +02:00
|
|
|
|
2012-03-22 20:06:46 +01:00
|
|
|
= How Libraries Are Located =
|
|
|
|
|
|
|
|
If you specify an external library to load, like 'examplelib', and use a
|
|
|
|
relative path like this:
|
|
|
|
|
|
|
|
{
|
|
|
|
...
|
2012-07-26 21:01:39 +02:00
|
|
|
"load": [
|
|
|
|
"examplelib/src"
|
|
|
|
],
|
2012-03-22 20:06:46 +01:00
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
...arc looks for it by trying these paths:
|
|
|
|
|
|
|
|
- `path/to/root/examplelib/src/` First, arc looks in the project's root
|
2014-06-26 03:56:17 +02:00
|
|
|
directory (where the `.arcconfig` lives) to see if the library is part of
|
2012-03-22 20:06:46 +01:00
|
|
|
the project. This makes it easy to just put project-specific code in a
|
|
|
|
project.
|
|
|
|
- `path/to/root/../examplelib/src/` Next, arc looks //next to// the project's
|
|
|
|
root directory to see if the library is in a sibling directory. If you
|
|
|
|
work with several repositories, this makes it easy to put all the `arc`
|
|
|
|
code in one repository and just check it out in the same directory as
|
|
|
|
everything else.
|
|
|
|
- `php/include/path/examplelib/src` Finally, arc falls back to PHP, which
|
|
|
|
will look in paths described in the `include_path` php.ini setting. This
|
|
|
|
allows you to install libraries in some global location if you prefer.
|
|
|
|
|
|
|
|
You can alternately supply an absolute path, like `/var/arc/examplelib/src`, but
|
|
|
|
then everyone will need to install the library at that exact location.
|
|
|
|
|
|
|
|
NOTE: Specify the path to the directory which includes
|
|
|
|
`__phutil_library_init__.php`. For example, if your init file is in
|
|
|
|
`examplelib/src/__phutil_library_init__.php`, specify `examplelib/src`,
|
|
|
|
not just `examplelib/`.
|
|
|
|
|
|
|
|
The general intent here is:
|
|
|
|
|
|
|
|
- Put project-specific code in some directory in the project, like
|
|
|
|
`support/arc/src/`.
|
|
|
|
- Put shared code (e.g., which enforces general coding standards or hooks
|
|
|
|
up to unit tests or whatever) in a separate repository and check it out
|
|
|
|
next to other repositories.
|
|
|
|
- Or put everything in some standard location and add it to `include_path`.
|
|
|
|
|
2012-08-10 21:00:40 +02:00
|
|
|
= Running Without .arcconfig =
|
|
|
|
|
|
|
|
Although you don't need to set up `.arcconfig`, and you can run `arc` command
|
|
|
|
that require a working copy in any Git, Subversion or Mercurial working copy,
|
|
|
|
some features won't work unless you set up an `.arcconfig` file.
|
|
|
|
|
|
|
|
Without `.arcconfig`:
|
|
|
|
|
|
|
|
- You will need to set a default Phabricator URI with
|
|
|
|
`arc set-config default <uri>`, or specify an explicit URI
|
|
|
|
with `--conduit-uri` each time you run a command.
|
|
|
|
- You will not be able to run linters through arc unless you pass `--engine`
|
|
|
|
explicitly.
|
|
|
|
- You will not be able to customize certain linter parameters even with
|
|
|
|
`--engine`.
|
|
|
|
- You will not be able to run unit tests through arc unless you pass
|
|
|
|
`--engine` explicitly.
|
|
|
|
- You will not be able to trigger lint and unit integration through
|
|
|
|
`arc diff`.
|
|
|
|
- You will not be able to put Git working copies into immutable history mode
|
|
|
|
(see below).
|
|
|
|
- You will not be able to specify a repository encoding. UTF-8 will be assumed
|
|
|
|
if you do not pass `--encoding`.
|
|
|
|
- You will not be able to add plugins to arc to modify existing workflows or
|
|
|
|
add new ones.
|
|
|
|
- You will not be able to load additional libraries unless you specify them
|
|
|
|
explicitly with `--load-phutil-library`.
|
|
|
|
- Symbol index integration, which allows users to click function or class
|
|
|
|
names in Differential and jump to their definitions, will not work.
|
|
|
|
- `arc patch` will be unable to detect that you are applying changes to the
|
|
|
|
wrong project.
|
|
|
|
- In Subversion, `arc` will be unable to determine the canonical root
|
|
|
|
of a project, and will assume it is the working directory (in Subversion
|
|
|
|
prior to 1.7) or the root of the checkout (in Subversion after 1.7). This
|
|
|
|
means the paths of files in diffs won't be anchored to the same place,
|
|
|
|
and will have different amounts of path context, which may be confusing for
|
|
|
|
reviewers and will sometimes prevent patches from applying properly if they
|
|
|
|
are applied against a different directory than they were generated from.
|
|
|
|
- In Subversion, `arc` will be unable to guess that you intend to update
|
|
|
|
an existing revision; you must use `--update` explicitly or `--preview`
|
|
|
|
and attach diffs via the web interface.
|
|
|
|
|
|
|
|
= Next Steps =
|
|
|
|
|
|
|
|
Continue by:
|
|
|
|
|
|
|
|
- returning to @{article:Arcanist User Guide}.
|