2011-05-23 07:42:58 -07:00
|
|
|
@title Arcanist User Guide: Customizing Lint, Unit Tests and Workflows
|
|
|
|
@group userguide
|
|
|
|
|
|
|
|
Explains how to build new classes to control how Arcanist behaves.
|
2012-08-10 12:00:40 -07:00
|
|
|
|
|
|
|
This is a configuration guide that helps you set up advanced features. If you're
|
|
|
|
just getting started, you don't need to look at this yet. Instead, start with
|
|
|
|
the @{article:Arcanist User Guide}.
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
= Overview =
|
|
|
|
|
2012-06-01 07:55:30 -07:00
|
|
|
Arcanist has some basic configuration options available in the `.arcconfig`
|
2011-06-26 11:52:10 -07:00
|
|
|
file (see @{article:Arcanist User Guide: Configuring a New Project}), but it
|
|
|
|
can't handle everything. If you want to customize Arcanist at a deeper level,
|
|
|
|
you need to build new classes. For instance:
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
- if you want to configure linters, or add new linters, you need to create a
|
2011-06-26 11:52:10 -07:00
|
|
|
new class which extends @{class@arcanist:ArcanistLintEngine}.
|
2011-05-23 07:42:58 -07:00
|
|
|
- if you want to integrate with a unit testing framework, you need to create a
|
2014-07-22 07:56:27 +10:00
|
|
|
new class which extends @{class@arcanist:ArcanistUnitTestEngine}.
|
2011-05-23 07:42:58 -07:00
|
|
|
- if you you want to change how workflows behave, or add new workflows, you
|
2011-06-26 11:52:10 -07:00
|
|
|
need to create a new class which extends
|
|
|
|
@{class@arcanist:ArcanistConfiguration}.
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
Arcanist works through a sort of dependency-injection approach. For example,
|
2012-06-01 07:55:30 -07:00
|
|
|
Arcanist does not run lint rules by default, but you can set `lint.engine`
|
|
|
|
in your `.arcconfig` to the name of a class which extends
|
2011-06-26 11:52:10 -07:00
|
|
|
@{class@arcanist:ArcanistLintEngine}. When running from inside your project,
|
|
|
|
Arcanist will load this class and call methods on it in order to run lint. To
|
|
|
|
make this work, you need to do three things:
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
- actually write the class;
|
2015-05-31 10:07:45 +10:00
|
|
|
- add the library where the class exists to your `.arcconfig`;
|
|
|
|
- add the class name to your `.arcconfig` as the **lint.engine**,
|
2012-06-01 07:55:30 -07:00
|
|
|
**unit.engine**, or **arcanist_configuration**.
|
2011-05-23 07:42:58 -07:00
|
|
|
|
2011-12-02 15:12:45 -08:00
|
|
|
= Create a libphutil Library =
|
2011-05-23 07:42:58 -07:00
|
|
|
|
2011-12-02 15:12:45 -08:00
|
|
|
If you haven't created a library for the class to live in yet, you need to do
|
2014-06-24 04:26:06 +10:00
|
|
|
that first. Follow the instructions in
|
|
|
|
@{article:libphutil Libraries User Guide}, then make the library loadable by
|
2015-05-31 10:07:45 +10:00
|
|
|
adding it to your `.arcconfig` like this:
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
{
|
|
|
|
// ...
|
2012-07-26 12:01:39 -07:00
|
|
|
"load" : [
|
2011-05-23 07:42:58 -07:00
|
|
|
// ...
|
2012-06-01 07:55:30 -07:00
|
|
|
"/path/to/my/library", // Absolute path
|
|
|
|
"support/arcanist", // Relative path in this project
|
2011-05-23 07:42:58 -07:00
|
|
|
// ...
|
2012-06-01 07:55:30 -07:00
|
|
|
]
|
2011-05-23 07:42:58 -07:00
|
|
|
// ...
|
|
|
|
}
|
|
|
|
|
|
|
|
You can either specify an absolute path, or a path relative to the project root.
|
2015-05-31 10:07:45 +10:00
|
|
|
When you run `arc list --trace`, you should see a message to the effect that
|
2011-06-26 11:52:10 -07:00
|
|
|
it has loaded your library.
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
For debugging or testing, you can also run Arcanist with the
|
2014-08-06 14:18:32 -07:00
|
|
|
`--load-phutil-library` flag:
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
arc --load-phutil-library=/path/to/library <command>
|
|
|
|
|
|
|
|
You can specify this flag more than once to load several libraries. Note that
|
|
|
|
if you use this flag, Arcanist will ignore any libraries listed in
|
2014-08-06 14:18:32 -07:00
|
|
|
`.arcconfig`.
|
2011-05-23 07:42:58 -07:00
|
|
|
|
|
|
|
= Use the Class =
|
|
|
|
|
2015-05-31 10:07:45 +10:00
|
|
|
This step is easy: just edit `.arcconfig` to specify your class name as
|
2011-05-23 07:42:58 -07:00
|
|
|
the appropriate configuration value.
|
|
|
|
|
|
|
|
{
|
|
|
|
// ...
|
2012-06-01 07:55:30 -07:00
|
|
|
"lint.engine" : "CustomArcanistLintEngine",
|
2011-05-23 07:42:58 -07:00
|
|
|
// ...
|
|
|
|
}
|
|
|
|
|
|
|
|
Now, when you run Arcanist in your project, it will invoke your class when
|
|
|
|
appropriate.
|
|
|
|
|
2015-05-31 10:07:45 +10:00
|
|
|
For lint and unit tests, you can also use the `--engine` flag override the
|
2011-05-23 07:42:58 -07:00
|
|
|
default engine:
|
|
|
|
|
|
|
|
arc lint --engine MyCustomArcanistLintEngine
|
|
|
|
|
|
|
|
This is mostly useful for debugging and testing.
|
2012-01-28 11:17:10 -08:00
|
|
|
|
|
|
|
= Next Steps =
|
|
|
|
|
2014-05-19 12:40:20 -07:00
|
|
|
- Learn how to reuse existing linters by reading
|
2012-01-28 11:17:10 -08:00
|
|
|
@{article:Arcanist User Guide: Customizing Existing Linters}.
|