2012-05-07 06:07:23 -07:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Read configuration settings.
|
|
|
|
*/
|
2014-07-22 07:49:15 +10:00
|
|
|
final class ArcanistGetConfigWorkflow extends ArcanistWorkflow {
|
2012-05-07 06:07:23 -07:00
|
|
|
|
Make Arcanist workflow names explicit
Summary:
Currently, adding a new workflow requires you to override ArcanistConfiguration, which is messy. Instead, just load everything that extends ArcanistBaseWorkflow.
Remove all the rules tying workflow names to class names through arcane incantations.
This has a very small performance cost in that we need to load every Workflow class every time now, but we don't hit __init__ and such anymore and it was pretty negligible on my machine (98ms vs 104ms or something).
Test Plan: Ran "arc help", "arc which", "arc diff", etc.
Reviewers: edward, vrana, btrahan
Reviewed By: edward
CC: aran, zeeg
Differential Revision: https://secure.phabricator.com/D3691
2012-10-17 08:35:03 -07:00
|
|
|
public function getWorkflowName() {
|
|
|
|
return 'get-config';
|
|
|
|
}
|
|
|
|
|
2012-05-07 06:07:23 -07:00
|
|
|
public function getCommandSynopses() {
|
|
|
|
return phutil_console_format(<<<EOTEXT
|
2014-05-20 11:34:28 -07:00
|
|
|
**get-config** [__options__] -- [__name__ ...]
|
2012-05-07 06:07:23 -07:00
|
|
|
EOTEXT
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCommandHelp() {
|
|
|
|
return phutil_console_format(<<<EOTEXT
|
|
|
|
Supports: cli
|
Enrich arc configuration and add stronger typing
Summary:
See <https://github.com/facebook/arcanist/issues/45>
Currently, when the user types `arc set-config x false`, we set it as the string "false", which is usually not desirable. We have some steps toward typed config already, but expand on what we have and move as much stuff as possible into it, including all the config settings that aren't currently documented (there are still some lint-specific and project-specific settings not present here, but this is most of it).
Also make the `phutil_libraries` key a legacy name for `load`, and `immutable_history` a legacy name for `history.immutable`. Generally the goal here is to make config simpler and bring it more in-line with Git/Mercurial, which use dotted hierarchies.
I'll add some documentation here but I think most of the changes should be fairly straightforward.
Test Plan:
- `arc set-config history.immutable on` (And similar -- sets to boolean true.)
- `arc set-config history.immutable off` (And similar -- sets to boolean false.)
- `arc set-config history.immutable derp` (And similar -- raises exception.)
- `arc set-config history.immutable ''` (And similar -- removes setting value.)
- `arc set-config --show`
- `arc get-config`
- `arc get-config base`
Reviewers: dschleimer, bos, btrahan, vrana
Reviewed By: dschleimer
CC: aran
Maniphest Tasks: T1546
Differential Revision: https://secure.phabricator.com/D3045
2012-07-25 18:37:09 -07:00
|
|
|
Reads an arc configuration option. With no argument, reads all
|
2012-05-07 06:07:23 -07:00
|
|
|
options.
|
2014-05-20 11:34:28 -07:00
|
|
|
|
|
|
|
With __--verbose__, shows detailed information about one or more
|
|
|
|
options.
|
2012-05-07 06:07:23 -07:00
|
|
|
EOTEXT
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getArguments() {
|
|
|
|
return array(
|
2014-05-20 11:34:28 -07:00
|
|
|
'verbose' => array(
|
|
|
|
'help' => pht('Show detailed information about options.'),
|
|
|
|
),
|
2012-05-07 06:07:23 -07:00
|
|
|
'*' => 'argv',
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-06-13 16:02:29 -07:00
|
|
|
public function desiresRepositoryAPI() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-05-07 06:07:23 -07:00
|
|
|
public function run() {
|
|
|
|
$argv = $this->getArgument('argv');
|
2014-05-20 11:34:28 -07:00
|
|
|
$verbose = $this->getArgument('verbose');
|
2012-05-07 06:07:23 -07:00
|
|
|
|
Enrich arc configuration and add stronger typing
Summary:
See <https://github.com/facebook/arcanist/issues/45>
Currently, when the user types `arc set-config x false`, we set it as the string "false", which is usually not desirable. We have some steps toward typed config already, but expand on what we have and move as much stuff as possible into it, including all the config settings that aren't currently documented (there are still some lint-specific and project-specific settings not present here, but this is most of it).
Also make the `phutil_libraries` key a legacy name for `load`, and `immutable_history` a legacy name for `history.immutable`. Generally the goal here is to make config simpler and bring it more in-line with Git/Mercurial, which use dotted hierarchies.
I'll add some documentation here but I think most of the changes should be fairly straightforward.
Test Plan:
- `arc set-config history.immutable on` (And similar -- sets to boolean true.)
- `arc set-config history.immutable off` (And similar -- sets to boolean false.)
- `arc set-config history.immutable derp` (And similar -- raises exception.)
- `arc set-config history.immutable ''` (And similar -- removes setting value.)
- `arc set-config --show`
- `arc get-config`
- `arc get-config base`
Reviewers: dschleimer, bos, btrahan, vrana
Reviewed By: dschleimer
CC: aran
Maniphest Tasks: T1546
Differential Revision: https://secure.phabricator.com/D3045
2012-07-25 18:37:09 -07:00
|
|
|
$settings = new ArcanistSettings();
|
|
|
|
|
2013-10-18 16:10:06 -07:00
|
|
|
$configuration_manager = $this->getConfigurationManager();
|
2012-06-13 16:02:29 -07:00
|
|
|
$configs = array(
|
2014-05-20 11:34:28 -07:00
|
|
|
ArcanistConfigurationManager::CONFIG_SOURCE_LOCAL =>
|
|
|
|
$configuration_manager->readLocalArcConfig(),
|
2013-10-18 16:10:06 -07:00
|
|
|
ArcanistConfigurationManager::CONFIG_SOURCE_PROJECT =>
|
|
|
|
$this->getWorkingCopy()->readProjectConfig(),
|
2014-05-20 11:34:28 -07:00
|
|
|
ArcanistConfigurationManager::CONFIG_SOURCE_USER =>
|
|
|
|
$configuration_manager->readUserArcConfig(),
|
|
|
|
ArcanistConfigurationManager::CONFIG_SOURCE_SYSTEM =>
|
|
|
|
$configuration_manager->readSystemArcConfig(),
|
|
|
|
ArcanistConfigurationManager::CONFIG_SOURCE_DEFAULT =>
|
|
|
|
$configuration_manager->readDefaultConfig(),
|
2012-06-13 16:02:29 -07:00
|
|
|
);
|
2012-07-25 20:14:28 -07:00
|
|
|
|
2012-05-07 06:07:23 -07:00
|
|
|
if ($argv) {
|
|
|
|
$keys = $argv;
|
|
|
|
} else {
|
2012-06-13 16:02:29 -07:00
|
|
|
$keys = array_mergev(array_map('array_keys', $configs));
|
2014-05-20 11:34:28 -07:00
|
|
|
$keys = array_merge($keys, $settings->getAllKeys());
|
2012-06-13 16:02:29 -07:00
|
|
|
$keys = array_unique($keys);
|
2012-05-07 06:07:23 -07:00
|
|
|
sort($keys);
|
|
|
|
}
|
|
|
|
|
2014-05-20 11:34:28 -07:00
|
|
|
$console = PhutilConsole::getConsole();
|
2012-07-25 20:14:28 -07:00
|
|
|
$multi = (count($keys) > 1);
|
|
|
|
|
2012-05-07 06:07:23 -07:00
|
|
|
foreach ($keys as $key) {
|
2014-05-20 11:34:28 -07:00
|
|
|
$console->writeOut("**%s**\n\n", $key);
|
|
|
|
|
|
|
|
if ($verbose) {
|
|
|
|
$help = $settings->getHelp($key);
|
|
|
|
if (!$help) {
|
|
|
|
$help = pht(
|
|
|
|
'(This configuration value is not recognized by arc. It may '.
|
|
|
|
'be misspelled or out of date.)');
|
|
|
|
}
|
|
|
|
|
|
|
|
$console->writeOut("%s\n\n", phutil_console_wrap($help, 4));
|
|
|
|
|
|
|
|
$console->writeOut(
|
|
|
|
"%s: %s\n\n",
|
|
|
|
sprintf('% 20.20s', pht('Example Value')),
|
|
|
|
$settings->getExample($key));
|
|
|
|
|
2012-07-25 20:14:28 -07:00
|
|
|
}
|
2014-05-20 11:34:28 -07:00
|
|
|
|
|
|
|
$values = array();
|
|
|
|
foreach ($configs as $config_key => $config) {
|
|
|
|
if (array_key_exists($key, $config)) {
|
|
|
|
$values[$config_key] = $config[$key];
|
|
|
|
} else {
|
|
|
|
// If we didn't find a value, look for a legacy value.
|
|
|
|
$source_project = ArcanistConfigurationManager::CONFIG_SOURCE_PROJECT;
|
|
|
|
if ($config_key === $source_project) {
|
|
|
|
$legacy_name = $settings->getLegacyName($key);
|
|
|
|
if (array_key_exists($legacy_name, $config)) {
|
|
|
|
$values[$config_key] = $config[$legacy_name];
|
|
|
|
}
|
|
|
|
}
|
2012-07-25 20:14:28 -07:00
|
|
|
}
|
2014-05-20 11:34:28 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
$console->writeOut(
|
|
|
|
'%s: ',
|
|
|
|
sprintf('% 20.20s', pht('Current Value')));
|
|
|
|
|
|
|
|
if ($values) {
|
|
|
|
$value = head($values);
|
|
|
|
$value = $settings->formatConfigValueForDisplay($key, $value);
|
|
|
|
$console->writeOut("%s\n", $value);
|
|
|
|
} else {
|
|
|
|
$console->writeOut("-\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
$console->writeOut(
|
|
|
|
'%s: ',
|
|
|
|
sprintf('% 20.20s', pht('Current Source')));
|
|
|
|
|
|
|
|
if ($values) {
|
|
|
|
$source = head_key($values);
|
|
|
|
$console->writeOut("%s\n", $source);
|
|
|
|
} else {
|
|
|
|
$console->writeOut("-\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($verbose) {
|
|
|
|
$console->writeOut("\n");
|
|
|
|
|
|
|
|
foreach ($configs as $name => $config) {
|
|
|
|
$have_value = false;
|
|
|
|
if (array_key_exists($name, $values)) {
|
|
|
|
$have_value = true;
|
|
|
|
$value = $values[$name];
|
|
|
|
}
|
|
|
|
|
|
|
|
$console->writeOut(
|
|
|
|
'%s: ',
|
|
|
|
sprintf('% 20.20s', pht('%s Value', $name)));
|
|
|
|
|
|
|
|
if ($have_value) {
|
|
|
|
$console->writeOut(
|
|
|
|
"%s\n",
|
|
|
|
$settings->formatConfigValueForDisplay($key, $value));
|
|
|
|
} else {
|
|
|
|
$console->writeOut("-\n");
|
|
|
|
}
|
2012-06-13 16:02:29 -07:00
|
|
|
}
|
|
|
|
}
|
2014-05-20 11:34:28 -07:00
|
|
|
|
2012-07-25 20:14:28 -07:00
|
|
|
if ($multi) {
|
|
|
|
echo "\n";
|
|
|
|
}
|
2012-05-07 06:07:23 -07:00
|
|
|
}
|
|
|
|
|
2014-05-20 11:34:28 -07:00
|
|
|
if (!$verbose) {
|
|
|
|
$console->writeOut(
|
2015-05-13 18:05:15 +10:00
|
|
|
"(%s)\n",
|
|
|
|
pht('Run with %s for more details.', '--verbose'));
|
2014-05-20 11:34:28 -07:00
|
|
|
}
|
|
|
|
|
2012-05-07 06:07:23 -07:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|