mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-21 20:21:44 +01:00
66d204be81
Summary: This commit doesn't change license of any file. It just makes the license implicit (inherited from LICENSE file in the root directory). We are removing the headers for these reasons: - It wastes space in editors, less code is visible in editor upon opening a file. - It brings noise to diff of the first change of any file every year. - It confuses Git file copy detection when creating small files. - We don't have an explicit license header in other files (JS, CSS, images, documentation). - Using license header in every file is not obligatory: http://www.apache.org/dev/apply-license.html#new. This change is approved by Alma Chao (Lead Open Source and IP Counsel at Facebook). Test Plan: Verified that the license survived only in unit tests and LICENSE file. Reviewers: epriestley, btrahan, edward Reviewed By: epriestley CC: aran, Korvin, davidrecordon Maniphest Tasks: T2035 Differential Revision: https://secure.phabricator.com/D3881
205 lines
5.4 KiB
PHP
205 lines
5.4 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Seduces the reader with majestic prose.
|
|
*
|
|
* @group workflow
|
|
*/
|
|
final class ArcanistHelpWorkflow extends ArcanistBaseWorkflow {
|
|
|
|
public function getWorkflowName() {
|
|
return 'help';
|
|
}
|
|
|
|
public function getCommandSynopses() {
|
|
return phutil_console_format(<<<EOTEXT
|
|
**help** [__command__]
|
|
**help** --full
|
|
EOTEXT
|
|
);
|
|
}
|
|
|
|
public function getCommandHelp() {
|
|
return phutil_console_format(<<<EOTEXT
|
|
Supports: english
|
|
Shows this help. With __command__, shows help about a specific
|
|
command.
|
|
EOTEXT
|
|
);
|
|
}
|
|
|
|
public function getArguments() {
|
|
return array(
|
|
'full' => array(
|
|
'help' => 'Print detailed information about each command.',
|
|
),
|
|
'*' => 'command',
|
|
);
|
|
}
|
|
|
|
public function run() {
|
|
|
|
$arc_config = $this->getArcanistConfiguration();
|
|
$workflows = $arc_config->buildAllWorkflows();
|
|
ksort($workflows);
|
|
|
|
$target = null;
|
|
if ($this->getArgument('command')) {
|
|
$target = head($this->getArgument('command'));
|
|
if (empty($workflows[$target])) {
|
|
throw new ArcanistUsageException(
|
|
"Unrecognized command '{$target}'. Try 'arc help'.");
|
|
}
|
|
}
|
|
|
|
$cmdref = array();
|
|
foreach ($workflows as $command => $workflow) {
|
|
if ($target && $target != $command) {
|
|
continue;
|
|
}
|
|
if (!$target && !$this->getArgument('full')) {
|
|
$cmdref[] = $workflow->getCommandSynopses();
|
|
continue;
|
|
}
|
|
$optref = array();
|
|
$arguments = $workflow->getArguments();
|
|
|
|
$config_arguments = $arc_config->getCustomArgumentsForCommand($command);
|
|
|
|
// This juggling is to put the extension arguments after the normal
|
|
// arguments, and make sure the normal arguments aren't overwritten.
|
|
ksort($arguments);
|
|
ksort($config_arguments);
|
|
foreach ($config_arguments as $argument => $spec) {
|
|
if (empty($arguments[$argument])) {
|
|
$arguments[$argument] = $spec;
|
|
}
|
|
}
|
|
|
|
foreach ($arguments as $argument => $spec) {
|
|
if ($argument == '*') {
|
|
continue;
|
|
}
|
|
if (!empty($spec['hide'])) {
|
|
continue;
|
|
}
|
|
if (isset($spec['param'])) {
|
|
if (isset($spec['short'])) {
|
|
$optref[] = phutil_console_format(
|
|
" __--%s__ __%s__, __-%s__ __%s__",
|
|
$argument,
|
|
$spec['param'],
|
|
$spec['short'],
|
|
$spec['param']);
|
|
} else {
|
|
$optref[] = phutil_console_format(
|
|
" __--%s__ __%s__",
|
|
$argument,
|
|
$spec['param']);
|
|
}
|
|
} else {
|
|
if (isset($spec['short'])) {
|
|
$optref[] = phutil_console_format(
|
|
" __--%s__, __-%s__",
|
|
$argument,
|
|
$spec['short']);
|
|
} else {
|
|
$optref[] = phutil_console_format(
|
|
" __--%s__",
|
|
$argument);
|
|
}
|
|
}
|
|
|
|
if (isset($config_arguments[$argument])) {
|
|
$optref[] = " (This is a custom option for this ".
|
|
"project.)";
|
|
}
|
|
|
|
if (isset($spec['supports'])) {
|
|
$optref[] = " Supports: ".
|
|
implode(', ', $spec['supports']);
|
|
}
|
|
|
|
if (isset($spec['help'])) {
|
|
$docs = $spec['help'];
|
|
} else {
|
|
$docs = 'This option is not documented.';
|
|
}
|
|
$docs = phutil_console_wrap($docs, 14);
|
|
$optref[] = "{$docs}\n";
|
|
}
|
|
if ($optref) {
|
|
$optref = implode("\n", $optref);
|
|
$optref = "\n\n".$optref;
|
|
} else {
|
|
$optref = "\n";
|
|
}
|
|
|
|
$cmdref[] =
|
|
$workflow->getCommandSynopses()."\n".
|
|
$workflow->getCommandHelp().
|
|
$optref;
|
|
}
|
|
$cmdref = implode("\n\n", $cmdref);
|
|
|
|
if ($target) {
|
|
echo "\n".$cmdref."\n";
|
|
return;
|
|
}
|
|
|
|
$self = 'arc';
|
|
echo phutil_console_format(<<<EOTEXT
|
|
**NAME**
|
|
**{$self}** - arcanist, a code review and revision management utility
|
|
|
|
**SYNOPSIS**
|
|
**{$self}** __command__ [__options__] [__args__]
|
|
This help file provides a detailed command reference.
|
|
|
|
**COMMAND REFERENCE**
|
|
|
|
{$cmdref}
|
|
|
|
|
|
EOTEXT
|
|
);
|
|
|
|
if (!$this->getArgument('full')) {
|
|
echo "Run 'arc help --full' to get commands and options descriptions.\n";
|
|
return;
|
|
}
|
|
|
|
echo phutil_console_format(<<<EOTEXT
|
|
**OPTION REFERENCE**
|
|
|
|
__--trace__
|
|
Debugging command. Shows underlying commands as they are executed,
|
|
and full stack traces when exceptions are thrown.
|
|
|
|
__--no-ansi__
|
|
Output in plain ASCII text only, without color or style.
|
|
|
|
__--ansi__
|
|
Use formatting even in environments which probably don't support it.
|
|
Example: arc --ansi unit | less -r
|
|
|
|
__--load-phutil-library=/path/to/library__
|
|
Ignore libraries listed in .arcconfig and explicitly load specified
|
|
libraries instead. Mostly useful for Arcanist development.
|
|
|
|
__--conduit-uri__ __uri__
|
|
Ignore configured Conduit URI and use an explicit one instead. Mostly
|
|
useful for Arcanist development.
|
|
|
|
__--conduit-version__ __version__
|
|
Ignore software version and claim to be running some other version
|
|
instead. Mostly useful for Arcanist development. May cause bad things
|
|
to happen.
|
|
|
|
__--conduit-timeout__ __timeout__
|
|
Override the default Conduit timeout. Specified in seconds.
|
|
|
|
EOTEXT
|
|
);
|
|
}
|
|
}
|