2012-05-07 15:07:23 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright 2012 Facebook, Inc.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write configuration settings.
|
|
|
|
*
|
|
|
|
* @group workflow
|
|
|
|
*/
|
|
|
|
final class ArcanistSetConfigWorkflow extends ArcanistBaseWorkflow {
|
|
|
|
|
|
|
|
public function getCommandSynopses() {
|
|
|
|
return phutil_console_format(<<<EOTEXT
|
2012-06-14 01:02:29 +02:00
|
|
|
**set-config** [__options__] -- __name__ __value__
|
2012-05-07 15:07:23 +02:00
|
|
|
EOTEXT
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCommandHelp() {
|
|
|
|
return phutil_console_format(<<<EOTEXT
|
|
|
|
Supports: cli
|
|
|
|
Sets an arc configuration option.
|
|
|
|
|
2012-06-14 01:02:29 +02:00
|
|
|
Options are either global (apply to all arc commands you invoke
|
|
|
|
from the current user) or local (apply only to the current working
|
|
|
|
copy). By default, global configuration is written. Use __--local__
|
|
|
|
to write local configuration.
|
|
|
|
|
|
|
|
Global values are written to '~/.arcrc' on Linux and Mac OS X, and an
|
|
|
|
undisclosed location on Windows. Local values are written to an arc
|
|
|
|
directory under either .git, .hg, or .svn as appropriate.
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
|
|
|
|
With __--show__, a description of supported configuration values
|
|
|
|
is shown.
|
2012-05-07 15:07:23 +02:00
|
|
|
EOTEXT
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getArguments() {
|
|
|
|
return array(
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
'show' => array(
|
|
|
|
'help' => 'Show available configuration values.',
|
|
|
|
),
|
2012-06-14 01:02:29 +02:00
|
|
|
'local' => array(
|
|
|
|
'help' => 'Set a local config value instead of a global one',
|
|
|
|
),
|
2012-05-07 15:07:23 +02:00
|
|
|
'*' => 'argv',
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-06-14 01:02:29 +02:00
|
|
|
public function requiresRepositoryAPI() {
|
|
|
|
return $this->getArgument('local');
|
|
|
|
}
|
|
|
|
|
2012-05-07 15:07:23 +02:00
|
|
|
public function run() {
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
if ($this->getArgument('show')) {
|
|
|
|
return $this->show();
|
|
|
|
}
|
|
|
|
|
2012-05-07 15:07:23 +02:00
|
|
|
$argv = $this->getArgument('argv');
|
|
|
|
if (count($argv) != 2) {
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
throw new ArcanistUsageException(
|
|
|
|
"Specify a key and a value, or --show.");
|
2012-05-07 15:07:23 +02:00
|
|
|
}
|
|
|
|
|
2012-06-14 01:02:29 +02:00
|
|
|
$is_local = $this->getArgument('local');
|
|
|
|
|
|
|
|
if ($is_local) {
|
|
|
|
$config = $this->readLocalArcConfig();
|
|
|
|
$which = 'local';
|
|
|
|
} else {
|
|
|
|
$config = self::readGlobalArcConfig();
|
|
|
|
$which = 'global';
|
|
|
|
}
|
2012-05-07 15:07:23 +02:00
|
|
|
|
|
|
|
$key = $argv[0];
|
|
|
|
$val = $argv[1];
|
|
|
|
|
|
|
|
$old = null;
|
|
|
|
if (array_key_exists($key, $config)) {
|
|
|
|
$old = $config[$key];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!strlen($val)) {
|
|
|
|
unset($config[$key]);
|
2012-06-14 01:02:29 +02:00
|
|
|
if ($is_local) {
|
|
|
|
$this->writeLocalArcConfig($config);
|
|
|
|
} else {
|
|
|
|
self::writeGlobalArcConfig($config);
|
|
|
|
}
|
2012-05-07 15:07:23 +02:00
|
|
|
|
|
|
|
if ($old === null) {
|
2012-06-14 01:02:29 +02:00
|
|
|
echo "Deleted key '{$key}' from {$which} config.\n";
|
2012-05-07 15:07:23 +02:00
|
|
|
} else {
|
2012-06-14 01:02:29 +02:00
|
|
|
echo "Deleted key '{$key}' from {$which} config (was '{$old}').\n";
|
2012-05-07 15:07:23 +02:00
|
|
|
}
|
|
|
|
} else {
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
$val = $this->parse($key, $val);
|
|
|
|
|
2012-05-07 15:07:23 +02:00
|
|
|
$config[$key] = $val;
|
2012-06-14 01:02:29 +02:00
|
|
|
if ($is_local) {
|
|
|
|
$this->writeLocalArcConfig($config);
|
|
|
|
} else {
|
|
|
|
self::writeGlobalArcConfig($config);
|
|
|
|
}
|
2012-05-07 15:07:23 +02:00
|
|
|
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
$val = self::formatConfigValueForDisplay($val);
|
|
|
|
$old = self::formatConfigValueForDisplay($old);
|
|
|
|
|
2012-05-07 15:07:23 +02:00
|
|
|
if ($old === null) {
|
2012-06-14 01:02:29 +02:00
|
|
|
echo "Set key '{$key}' = '{$val}' in {$which} config.\n";
|
2012-05-07 15:07:23 +02:00
|
|
|
} else {
|
2012-06-14 01:02:29 +02:00
|
|
|
echo "Set key '{$key}' = '{$val}' in {$which} config (was '{$old}').\n";
|
2012-05-07 15:07:23 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
Allow global config to load libraries and set test engines
Summary:
Khan Academy is looking into lint configuration, but doesn't use ".arcconfig" because they have a large number of repositories. Making configuration more flexible generally gives us more options for onboarding installs.
- Currently, only project config (".arcconfig") can load libraries. Allow user config ("~/.arcrc") to load libraries as well.
- Currently, only project config can set lint/unit engines. Allow user config to set default lint/unit engines.
- Add some type checking to "arc set-config".
- Add "arc set-config --show".
Test Plan:
- **load**
- Ran `arc set-config load xxx`, got error about format.
- Ran `arc set-config load ["apple"]`, got warning on running 'arc' commands (no such library) but was able to run 'arc set-config' again to clear it.
- Ran `arc set-config load ["/path/to/a/lib/src/"]`, worked.
- Ran `arc list --trace`, verified my library loaded in addition to `.arcconfig` libraries.
- Ran `arc list --load-phutil-library=xxx --trace`, verified only that library loaded.
- Ran `arc list --trace --load-phutil-library=apple --trace`, got hard error about bad library.
- Set `.arcconfig` to point at a bad library, verified hard error.
- **lint.engine** / **unit.engine**
- Removed lint engine from `.arcconfig`, ran "arc lint", got a run with specified engine.
- Removed unit engine from `.arcconfig`, ran "arc unit", got a run with specified engine.
- **--show**
- Ran `arc set-config --show`.
- **misc**
- Ran `arc get-config`.
Reviewers: csilvers, btrahan, vrana
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2618
2012-05-31 20:41:39 +02:00
|
|
|
private function show() {
|
|
|
|
$keys = array(
|
|
|
|
'default' => array(
|
|
|
|
'help' =>
|
|
|
|
'The URI of a Phabricator install to connect to by default, if '.
|
|
|
|
'arc is run in a project without a Phabricator URI or run outside '.
|
|
|
|
'of a project.',
|
|
|
|
'example' => 'http://phabricator.example.com/',
|
|
|
|
),
|
|
|
|
'load' => array(
|
|
|
|
'help' =>
|
|
|
|
'A list of paths to phutil libraries that should be loaded at '.
|
|
|
|
'startup. This can be used to make classes available, like lint or '.
|
|
|
|
'unit test engines.',
|
|
|
|
'example' => '["/var/arc/customlib/src"]',
|
|
|
|
),
|
|
|
|
'lint.engine' => array(
|
|
|
|
'help' =>
|
|
|
|
'The name of a default lint engine to use, if no lint engine is '.
|
|
|
|
'specified by the current project.',
|
|
|
|
'example' => 'ExampleLintEngine',
|
|
|
|
),
|
|
|
|
'unit.engine' => array(
|
|
|
|
'help' =>
|
|
|
|
'The name of a default unit test engine to use, if no unit test '.
|
|
|
|
'engine is specified by the current project.',
|
|
|
|
'example' => 'ExampleUnitTestEngine',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
|
|
|
|
$config = self::readGlobalArcConfig();
|
|
|
|
|
|
|
|
foreach ($keys as $key => $spec) {
|
|
|
|
$type = $this->getType($key);
|
|
|
|
|
|
|
|
$value = idx($config, $key);
|
|
|
|
$value = self::formatConfigValueForDisplay($value);
|
|
|
|
|
|
|
|
echo phutil_console_format("**__%s__** (%s)\n\n", $key, $type);
|
|
|
|
echo phutil_console_format(" Example: %s\n", $spec['example']);
|
|
|
|
if (strlen($value)) {
|
|
|
|
echo phutil_console_format(" Global Setting: %s\n", $value);
|
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
echo phutil_console_wrap($spec['help'], 4);
|
|
|
|
echo "\n\n\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getType($key) {
|
|
|
|
static $types = array(
|
|
|
|
'load' => 'list',
|
|
|
|
);
|
|
|
|
|
|
|
|
return idx($types, $key, 'string');
|
|
|
|
}
|
|
|
|
|
|
|
|
private function parse($key, $val) {
|
|
|
|
$type = $this->getType($key);
|
|
|
|
|
|
|
|
switch ($type) {
|
|
|
|
case 'string':
|
|
|
|
return $val;
|
|
|
|
case 'list':
|
|
|
|
$val = json_decode($val, true);
|
|
|
|
if (!is_array($val)) {
|
|
|
|
$example = '["apple", "banana", "cherry"]';
|
|
|
|
throw new ArcanistUsageException(
|
|
|
|
"Value for key '{$key}' must be specified as a JSON-encoded ".
|
|
|
|
"list. Example: {$example}");
|
|
|
|
}
|
|
|
|
return $val;
|
|
|
|
default:
|
|
|
|
throw new Exception("Unknown config key type '{$type}'!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-05-07 15:07:23 +02:00
|
|
|
}
|