2011-01-09 15:22:25 -08:00
|
|
|
#!/usr/bin/env php
|
|
|
|
<?php
|
|
|
|
|
2011-12-22 10:23:29 -08:00
|
|
|
sanity_check_environment();
|
|
|
|
|
2011-01-09 15:22:25 -08:00
|
|
|
require_once dirname(__FILE__).'/__init_script__.php';
|
|
|
|
|
2011-02-19 11:36:08 -08:00
|
|
|
ini_set('memory_limit', -1);
|
|
|
|
|
2012-03-08 12:20:26 -08:00
|
|
|
$original_argv = $argv;
|
2014-06-16 15:28:04 -07:00
|
|
|
$base_args = new PhutilArgumentParser($argv);
|
|
|
|
$base_args->parseStandardArguments();
|
|
|
|
$base_args->parsePartial(
|
2012-06-03 08:31:49 -07:00
|
|
|
array(
|
|
|
|
array(
|
|
|
|
'name' => 'load-phutil-library',
|
|
|
|
'param' => 'path',
|
2015-01-06 23:14:04 +11:00
|
|
|
'help' => pht('Load a libphutil library.'),
|
2012-06-03 08:31:49 -07:00
|
|
|
'repeat' => true,
|
|
|
|
),
|
2013-01-30 16:26:41 -08:00
|
|
|
array(
|
|
|
|
'name' => 'skip-arcconfig',
|
|
|
|
),
|
2013-10-25 15:57:38 -07:00
|
|
|
array(
|
|
|
|
'name' => 'arcrc-file',
|
|
|
|
'param' => 'filename',
|
|
|
|
),
|
2012-06-03 08:31:49 -07:00
|
|
|
array(
|
|
|
|
'name' => 'conduit-uri',
|
|
|
|
'param' => 'uri',
|
2015-01-06 23:14:04 +11:00
|
|
|
'help' => pht('Connect to Phabricator install specified by __uri__.'),
|
2012-06-03 08:31:49 -07:00
|
|
|
),
|
|
|
|
array(
|
|
|
|
'name' => 'conduit-version',
|
|
|
|
'param' => 'version',
|
2015-01-06 23:14:04 +11:00
|
|
|
'help' => pht(
|
|
|
|
'(Developers) Mock client version in protocol handshake.'),
|
2012-06-03 08:31:49 -07:00
|
|
|
),
|
|
|
|
array(
|
|
|
|
'name' => 'conduit-timeout',
|
|
|
|
'param' => 'timeout',
|
2015-01-06 23:14:04 +11:00
|
|
|
'help' => pht('Set Conduit timeout (in seconds).'),
|
2012-06-03 08:31:49 -07:00
|
|
|
),
|
2014-06-16 15:28:04 -07:00
|
|
|
array(
|
|
|
|
'name' => 'config',
|
|
|
|
'param' => 'key=value',
|
|
|
|
'repeat' => true,
|
2015-01-06 23:14:04 +11:00
|
|
|
'help' => pht(
|
2014-06-16 15:28:04 -07:00
|
|
|
'Specify a runtime configuration value. This will take precedence '.
|
2015-01-06 23:14:04 +11:00
|
|
|
'over static values, and only affect the current arcanist invocation.'),
|
2014-06-16 15:28:04 -07:00
|
|
|
),
|
|
|
|
));
|
2012-03-08 12:20:26 -08:00
|
|
|
|
2014-06-16 15:28:04 -07:00
|
|
|
$config_trace_mode = $base_args->getArg('trace');
|
2012-06-03 08:31:49 -07:00
|
|
|
|
2014-06-16 15:28:04 -07:00
|
|
|
$force_conduit = $base_args->getArg('conduit-uri');
|
|
|
|
$force_conduit_version = $base_args->getArg('conduit-version');
|
|
|
|
$conduit_timeout = $base_args->getArg('conduit-timeout');
|
|
|
|
$skip_arcconfig = $base_args->getArg('skip-arcconfig');
|
|
|
|
$custom_arcrc = $base_args->getArg('arcrc-file');
|
|
|
|
$load = $base_args->getArg('load-phutil-library');
|
|
|
|
$help = $base_args->getArg('help');
|
|
|
|
$args = array_values($base_args->getUnconsumedArgumentVector());
|
2011-01-09 15:22:25 -08:00
|
|
|
|
2011-12-23 23:48:46 -08:00
|
|
|
$working_directory = getcwd();
|
2012-07-06 10:05:49 -07:00
|
|
|
$console = PhutilConsole::getConsole();
|
2012-10-30 10:44:49 -07:00
|
|
|
$config = null;
|
2012-12-30 16:01:59 -08:00
|
|
|
$workflow = null;
|
2011-01-09 15:22:25 -08:00
|
|
|
|
|
|
|
try {
|
|
|
|
|
2012-09-05 11:45:54 -07:00
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht(
|
|
|
|
"libphutil loaded from '%s'.",
|
|
|
|
phutil_get_library_root('phutil')));
|
2012-09-05 11:45:54 -07:00
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht(
|
|
|
|
"arcanist loaded from '%s'.",
|
|
|
|
phutil_get_library_root('arcanist')));
|
2012-07-06 10:05:49 -07:00
|
|
|
|
2011-01-09 15:22:25 -08:00
|
|
|
if (!$args) {
|
2012-11-22 08:36:28 -08:00
|
|
|
if ($help) {
|
|
|
|
$args = array('help');
|
|
|
|
} else {
|
2015-01-06 23:14:04 +11:00
|
|
|
throw new ArcanistUsageException(
|
|
|
|
pht('No command provided. Try `%s`.', 'arc help'));
|
2012-11-22 08:36:28 -08:00
|
|
|
}
|
|
|
|
} else if ($help) {
|
|
|
|
array_unshift($args, 'help');
|
2011-01-09 15:22:25 -08:00
|
|
|
}
|
|
|
|
|
2013-10-18 16:10:06 -07:00
|
|
|
$configuration_manager = new ArcanistConfigurationManager();
|
2014-05-23 14:06:29 -07:00
|
|
|
if ($custom_arcrc) {
|
|
|
|
$configuration_manager->setUserConfigurationFileLocation($custom_arcrc);
|
|
|
|
}
|
2013-10-18 16:10:06 -07:00
|
|
|
|
|
|
|
$global_config = $configuration_manager->readUserArcConfig();
|
|
|
|
$system_config = $configuration_manager->readSystemArcConfig();
|
2014-06-16 15:28:04 -07:00
|
|
|
$runtime_config = $configuration_manager->applyRuntimeArcConfig($base_args);
|
|
|
|
|
2013-01-30 16:26:41 -08:00
|
|
|
if ($skip_arcconfig) {
|
|
|
|
$working_copy = ArcanistWorkingCopyIdentity::newDummyWorkingCopy();
|
|
|
|
} else {
|
|
|
|
$working_copy =
|
|
|
|
ArcanistWorkingCopyIdentity::newFromPath($working_directory);
|
|
|
|
}
|
2013-10-18 16:10:06 -07:00
|
|
|
$configuration_manager->setWorkingCopyIdentity($working_copy);
|
2011-06-30 19:20:41 -07:00
|
|
|
|
2012-12-17 16:35:03 -08:00
|
|
|
reenter_if_this_is_arcanist_or_libphutil(
|
|
|
|
$console,
|
|
|
|
$working_copy,
|
|
|
|
$original_argv);
|
|
|
|
|
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 11:41:39 -07:00
|
|
|
// Load additional libraries, which can provide new classes like configuration
|
|
|
|
// overrides, linters and lint engines, unit test engines, etc.
|
2011-06-30 19:20:41 -07: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 11:41:39 -07:00
|
|
|
// If the user specified "--load-phutil-library" one or more times from
|
|
|
|
// the command line, we load those libraries **instead** of whatever else
|
|
|
|
// is configured. This is basically a debugging feature to let you force
|
|
|
|
// specific libraries to load regardless of the state of the world.
|
|
|
|
if ($load) {
|
2013-04-29 12:19:15 -07:00
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht(
|
|
|
|
'Using `%s` flag, configuration will be ignored and configured '.
|
|
|
|
'libraries will not be loaded.',
|
|
|
|
'--load-phutil-library'));
|
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 11:41:39 -07:00
|
|
|
// Load the flag libraries. These must load, since the user specified them
|
|
|
|
// explicitly.
|
|
|
|
arcanist_load_libraries(
|
|
|
|
$load,
|
|
|
|
$must_load = true,
|
2015-01-06 23:14:04 +11:00
|
|
|
$lib_source = pht('a "%s" flag', '--load-phutil-library'),
|
2012-09-05 11:45:54 -07:00
|
|
|
$working_copy);
|
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 11:41:39 -07:00
|
|
|
} else {
|
2012-07-06 10:05:55 -07:00
|
|
|
// Load libraries in system 'load' config. In contrast to global config, we
|
|
|
|
// fail hard here because this file is edited manually, so if 'arc' breaks
|
|
|
|
// that doesn't make it any more difficult to correct.
|
|
|
|
arcanist_load_libraries(
|
|
|
|
idx($system_config, 'load', array()),
|
|
|
|
$must_load = true,
|
2015-01-06 23:14:04 +11:00
|
|
|
$lib_source = pht('the "%s" setting in system config', 'load'),
|
2012-09-05 11:45:54 -07:00
|
|
|
$working_copy);
|
2012-07-06 10:05:55 -07: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 11:41:39 -07:00
|
|
|
// Load libraries in global 'load' config, as per "arc set-config load". We
|
|
|
|
// need to fail softly if these break because errors would prevent the user
|
|
|
|
// from running "arc set-config" to correct them.
|
|
|
|
arcanist_load_libraries(
|
|
|
|
idx($global_config, 'load', array()),
|
|
|
|
$must_load = false,
|
2015-01-06 23:14:04 +11:00
|
|
|
$lib_source = pht('the "%s" setting in global config', 'load'),
|
2012-09-05 11:45:54 -07:00
|
|
|
$working_copy);
|
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 11:41:39 -07:00
|
|
|
|
|
|
|
// Load libraries in ".arcconfig". Libraries here must load.
|
|
|
|
arcanist_load_libraries(
|
2013-10-22 15:34:06 -07:00
|
|
|
$working_copy->getProjectConfig('load'),
|
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 11:41:39 -07:00
|
|
|
$must_load = true,
|
2015-01-06 23:14:04 +11:00
|
|
|
$lib_source = pht('the "%s" setting in "%s"', 'load', '.arcconfig'),
|
2012-09-05 11:45:54 -07:00
|
|
|
$working_copy);
|
2014-06-16 15:28:04 -07:00
|
|
|
|
|
|
|
// Load libraries in ".arcconfig". Libraries here must load.
|
|
|
|
arcanist_load_libraries(
|
|
|
|
idx($runtime_config, 'load', array()),
|
|
|
|
$must_load = true,
|
2015-01-06 23:14:04 +11:00
|
|
|
$lib_source = pht('the %s argument', '--config "load=[...]"'),
|
2014-06-16 15:28:04 -07:00
|
|
|
$working_copy);
|
2011-01-09 15:22:25 -08:00
|
|
|
}
|
2011-02-05 23:32:04 -08:00
|
|
|
|
2013-10-18 16:10:06 -07:00
|
|
|
$user_config = $configuration_manager->readUserConfigurationFile();
|
2011-01-09 15:22:25 -08:00
|
|
|
|
2013-10-22 15:34:06 -07:00
|
|
|
$config_class = $working_copy->getProjectConfig('arcanist_configuration');
|
2012-10-30 10:44:49 -07:00
|
|
|
if ($config_class) {
|
|
|
|
$config = new $config_class();
|
2011-01-09 15:22:25 -08:00
|
|
|
} else {
|
|
|
|
$config = new ArcanistConfiguration();
|
|
|
|
}
|
|
|
|
|
|
|
|
$command = strtolower($args[0]);
|
2012-02-21 13:16:52 -08:00
|
|
|
$args = array_slice($args, 1);
|
2013-10-18 16:10:06 -07:00
|
|
|
$workflow = $config->selectWorkflow(
|
|
|
|
$command,
|
|
|
|
$args,
|
|
|
|
$configuration_manager,
|
|
|
|
$console);
|
|
|
|
$workflow->setConfigurationManager($configuration_manager);
|
2011-01-09 15:22:25 -08:00
|
|
|
$workflow->setArcanistConfiguration($config);
|
|
|
|
$workflow->setCommand($command);
|
2011-06-14 12:18:40 -07:00
|
|
|
$workflow->setWorkingDirectory($working_directory);
|
2012-02-21 13:16:52 -08:00
|
|
|
$workflow->parseArguments($args);
|
2011-01-09 15:22:25 -08:00
|
|
|
|
2013-10-10 06:18:37 -07:00
|
|
|
// Write the command into the environment so that scripts (for example, local
|
|
|
|
// Git commit hooks) can detect that they're being run via `arc` and change
|
|
|
|
// their behaviors.
|
|
|
|
putenv('ARCANIST='.$command);
|
|
|
|
|
2012-05-21 16:45:03 -07:00
|
|
|
if ($force_conduit_version) {
|
|
|
|
$workflow->forceConduitVersion($force_conduit_version);
|
|
|
|
}
|
2012-06-03 08:31:49 -07:00
|
|
|
if ($conduit_timeout) {
|
|
|
|
$workflow->setConduitTimeout($conduit_timeout);
|
|
|
|
}
|
2012-05-21 16:45:03 -07:00
|
|
|
|
2011-01-09 15:22:25 -08:00
|
|
|
$need_working_copy = $workflow->requiresWorkingCopy();
|
|
|
|
$need_conduit = $workflow->requiresConduit();
|
|
|
|
$need_auth = $workflow->requiresAuthentication();
|
|
|
|
$need_repository_api = $workflow->requiresRepositoryAPI();
|
|
|
|
|
2012-06-13 16:02:29 -07:00
|
|
|
$want_repository_api = $workflow->desiresRepositoryAPI();
|
|
|
|
$want_working_copy = $workflow->desiresWorkingCopy() ||
|
|
|
|
$want_repository_api;
|
|
|
|
|
2011-01-09 15:22:25 -08:00
|
|
|
$need_conduit = $need_conduit ||
|
|
|
|
$need_auth;
|
|
|
|
$need_working_copy = $need_working_copy ||
|
|
|
|
$need_repository_api;
|
|
|
|
|
2012-06-13 16:02:29 -07:00
|
|
|
if ($need_working_copy || $want_working_copy) {
|
2014-03-25 17:32:58 -07:00
|
|
|
if ($need_working_copy && !$working_copy->getVCSType()) {
|
2011-01-13 15:36:15 -08:00
|
|
|
throw new ArcanistUsageException(
|
2015-01-06 23:14:04 +11:00
|
|
|
pht(
|
|
|
|
'This command must be run in a Git, Mercurial or Subversion '.
|
|
|
|
'working copy.'));
|
2011-01-13 15:36:15 -08:00
|
|
|
}
|
2013-10-18 16:10:06 -07:00
|
|
|
$configuration_manager->setWorkingCopyIdentity($working_copy);
|
2011-01-09 15:22:25 -08:00
|
|
|
}
|
|
|
|
|
2011-07-13 15:03:40 -07:00
|
|
|
if ($force_conduit) {
|
|
|
|
$conduit_uri = $force_conduit;
|
|
|
|
} else {
|
2014-05-13 11:36:56 -07:00
|
|
|
$conduit_uri = $configuration_manager->getConfigFromAnySource(
|
Allow `arc` to identify repositories without "project_id"
Summary:
Ref T4343. Continues the process of reducing the prominence of Arcanist Projects. Primarily:
- Query Phabricator to identify the working copy based on explicit configuration, or guess based on heuristics.
- Enhance `arc which` to explain the process to the user.
- The `project_id` key is no longer required in `.arcconfig`.
Minor/cleanup changes:
- Rename `project_id` to `project.name` (consistency, clarity).
- Rename `conduit_uri` to `phabricator.uri` (consistency, clairty).
- These both need documentation updates.
- Add `repository.callsign` to explicitly bind to a repository.
- Updated `.arcconfig` for the new values.
- Fix a unit test which broke a while ago when we fixed a rare definition of "unstaged".
- Make `getRepositoryUUID()` generic so we can get rid of one `instanceof`.
Test Plan:
- Ran `arc which`.
- Ran `arc diff`.
- This doesn't really change anything, so the only real risk is version compatibility breaks. This //does// introduce such a break, but the window is very narrow: if you upgrade `arc` after this commit, and try to diff against a Phabricator which was updated after yesterday (D8068) but before D8072 lands, the lookup will work so we'll add `repositoryPHID` to the `differential.creatediff` call, but it won't exist in Phabricator yet. This window is so narrow that I'm not going to try to fix it, as I'd guess there is a significant chance that no users will be affected. I don't see a clever way to fix it that doesn't involve a lot of work, either.
Reviewers: btrahan
Reviewed By: btrahan
CC: aran
Maniphest Tasks: T4343
Differential Revision: https://secure.phabricator.com/D8073
2014-01-26 15:31:30 -08:00
|
|
|
'phabricator.uri');
|
2014-05-13 11:36:56 -07:00
|
|
|
if ($conduit_uri === null) {
|
2015-01-06 23:14:04 +11:00
|
|
|
$conduit_uri = $configuration_manager->getConfigFromAnySource('default');
|
Allow 'arc' to run without '.arcconfig'
Summary:
This is mostly an onboarding thing, but also allows "arc upload", "arc download", and "arc paste" to work anywhere on the system.
- Try to read the Phabricator install URI from arc global config if we can't find ".arcconfig".
- Build a WorkingCopy anyway if we can't find ".arcconfig", as long as we can find ".svn", ".git", or ".hg".
- Make all the workflows handle "no project ID" at least somewhat gracefully.
Test Plan:
- Ran "arc diff" in .arcconfig-less Mercurial, Git, and Subversion working copies.
- Ran "arc upload" and "arc download" from my desktop.
- Ran "arc paste" from somewhere random.
- Cleared my config and hit the error, got useful instructions.
Reviewers: btrahan, csilvers
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2424
2012-05-07 15:24:58 -07:00
|
|
|
}
|
2011-07-13 15:03:40 -07:00
|
|
|
}
|
2014-05-13 11:36:56 -07:00
|
|
|
|
2011-07-13 15:03:40 -07:00
|
|
|
if ($conduit_uri) {
|
|
|
|
// Set the URI path to '/api/'. TODO: Originally, I contemplated letting
|
|
|
|
// you deploy Phabricator somewhere other than the domain root, but ended
|
|
|
|
// up never pursuing that. We should get rid of all "/api/" silliness
|
|
|
|
// in things users are expected to configure. This is already happening
|
|
|
|
// to some degree, e.g. "arc install-certificate" does it for you.
|
|
|
|
$conduit_uri = new PhutilURI($conduit_uri);
|
|
|
|
$conduit_uri->setPath('/api/');
|
|
|
|
$conduit_uri = (string)$conduit_uri;
|
|
|
|
}
|
|
|
|
$workflow->setConduitURI($conduit_uri);
|
|
|
|
|
2013-08-04 08:21:35 -07:00
|
|
|
// Apply global CA bundle from configs.
|
2013-10-18 16:10:06 -07:00
|
|
|
$ca_bundle = $configuration_manager->getConfigFromAnySource('https.cabundle');
|
|
|
|
if ($ca_bundle) {
|
2013-08-04 08:21:35 -07:00
|
|
|
$ca_bundle = Filesystem::resolvePath(
|
|
|
|
$ca_bundle, $working_copy->getProjectRoot());
|
|
|
|
HTTPSFuture::setGlobalCABundleFromPath($ca_bundle);
|
|
|
|
}
|
|
|
|
|
2013-09-25 15:26:38 -07:00
|
|
|
$blind_key = 'https.blindly-trust-domains';
|
2013-10-18 16:10:06 -07:00
|
|
|
$blind_trust = $configuration_manager->getConfigFromAnySource($blind_key);
|
2013-09-25 15:26:38 -07:00
|
|
|
if ($blind_trust) {
|
|
|
|
HTTPSFuture::setBlindlyTrustDomains($blind_trust);
|
|
|
|
}
|
|
|
|
|
2011-07-13 15:03:40 -07:00
|
|
|
if ($need_conduit) {
|
2011-01-09 15:22:25 -08:00
|
|
|
if (!$conduit_uri) {
|
Allow 'arc' to run without '.arcconfig'
Summary:
This is mostly an onboarding thing, but also allows "arc upload", "arc download", and "arc paste" to work anywhere on the system.
- Try to read the Phabricator install URI from arc global config if we can't find ".arcconfig".
- Build a WorkingCopy anyway if we can't find ".arcconfig", as long as we can find ".svn", ".git", or ".hg".
- Make all the workflows handle "no project ID" at least somewhat gracefully.
Test Plan:
- Ran "arc diff" in .arcconfig-less Mercurial, Git, and Subversion working copies.
- Ran "arc upload" and "arc download" from my desktop.
- Ran "arc paste" from somewhere random.
- Cleared my config and hit the error, got useful instructions.
Reviewers: btrahan, csilvers
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2424
2012-05-07 15:24:58 -07:00
|
|
|
|
|
|
|
$message = phutil_console_format(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n\n - %s\n - %s\n - %s\n",
|
|
|
|
pht(
|
|
|
|
'This command requires arc to connect to a Phabricator install, '.
|
|
|
|
'but no Phabricator installation is configured. To configure a '.
|
|
|
|
'Phabricator URI:'),
|
|
|
|
pht(
|
|
|
|
'set a default location with `%s`; or',
|
|
|
|
'arc set-config default <uri>'),
|
|
|
|
pht(
|
|
|
|
'specify `%s` explicitly; or',
|
|
|
|
'--conduit-uri=uri'),
|
|
|
|
pht(
|
|
|
|
"run `%s` in a working copy with an '%s'.",
|
|
|
|
'arc',
|
|
|
|
'.arcconfig'));
|
Allow 'arc' to run without '.arcconfig'
Summary:
This is mostly an onboarding thing, but also allows "arc upload", "arc download", and "arc paste" to work anywhere on the system.
- Try to read the Phabricator install URI from arc global config if we can't find ".arcconfig".
- Build a WorkingCopy anyway if we can't find ".arcconfig", as long as we can find ".svn", ".git", or ".hg".
- Make all the workflows handle "no project ID" at least somewhat gracefully.
Test Plan:
- Ran "arc diff" in .arcconfig-less Mercurial, Git, and Subversion working copies.
- Ran "arc upload" and "arc download" from my desktop.
- Ran "arc paste" from somewhere random.
- Cleared my config and hit the error, got useful instructions.
Reviewers: btrahan, csilvers
Reviewed By: csilvers
CC: aran
Differential Revision: https://secure.phabricator.com/D2424
2012-05-07 15:24:58 -07:00
|
|
|
|
|
|
|
$message = phutil_console_wrap($message);
|
|
|
|
throw new ArcanistUsageException($message);
|
2011-01-09 15:22:25 -08:00
|
|
|
}
|
2011-07-13 15:03:40 -07:00
|
|
|
$workflow->establishConduit();
|
|
|
|
}
|
2011-02-05 23:32:04 -08:00
|
|
|
|
2011-07-13 15:03:40 -07:00
|
|
|
$hosts_config = idx($user_config, 'hosts', array());
|
|
|
|
$host_config = idx($hosts_config, $conduit_uri, array());
|
|
|
|
$user_name = idx($host_config, 'user');
|
|
|
|
$certificate = idx($host_config, 'cert');
|
2014-12-15 11:12:38 -08:00
|
|
|
$conduit_token = idx($host_config, 'token');
|
2011-01-09 15:22:25 -08:00
|
|
|
|
2012-03-08 12:20:26 -08:00
|
|
|
$description = implode(' ', $original_argv);
|
2011-07-13 15:03:40 -07:00
|
|
|
$credentials = array(
|
2014-12-15 11:12:38 -08:00
|
|
|
'user' => $user_name,
|
2011-07-13 15:03:40 -07:00
|
|
|
'certificate' => $certificate,
|
|
|
|
'description' => $description,
|
2014-12-15 11:12:38 -08:00
|
|
|
'token' => $conduit_token,
|
2011-07-13 15:03:40 -07:00
|
|
|
);
|
|
|
|
$workflow->setConduitCredentials($credentials);
|
|
|
|
|
|
|
|
if ($need_auth) {
|
2014-12-15 11:12:38 -08:00
|
|
|
if ((!$user_name || !$certificate) && (!$conduit_token)) {
|
2013-05-24 20:20:20 -07:00
|
|
|
$arc = 'arc';
|
|
|
|
if ($force_conduit) {
|
|
|
|
$arc .= csprintf(' --conduit-uri=%s', $conduit_uri);
|
|
|
|
}
|
|
|
|
|
2014-12-15 11:12:38 -08:00
|
|
|
$conduit_domain = id(new PhutilURI($conduit_uri))->getDomain();
|
|
|
|
|
2011-06-26 20:43:24 -07:00
|
|
|
throw new ArcanistUsageException(
|
|
|
|
phutil_console_format(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n\n%s\n\n%s **%s:**\n\n $ **{$arc} install-certificate**\n",
|
|
|
|
pht('YOU NEED TO AUTHENTICATE TO CONTINUE'),
|
|
|
|
pht(
|
|
|
|
'You are trying to connect to a server (%s) that you '.
|
|
|
|
'do not have any credentials stored for.',
|
|
|
|
$conduit_domain),
|
|
|
|
pht('To retrieve and store credentials for this server,'),
|
|
|
|
pht('run this command')));
|
2011-06-26 20:43:24 -07:00
|
|
|
}
|
2011-07-13 15:03:40 -07:00
|
|
|
$workflow->authenticateConduit();
|
2011-01-09 15:22:25 -08:00
|
|
|
}
|
|
|
|
|
2014-03-25 17:32:58 -07:00
|
|
|
if ($need_repository_api ||
|
|
|
|
($want_repository_api && $working_copy->getVCSType())) {
|
2013-10-18 16:10:06 -07:00
|
|
|
$repository_api = ArcanistRepositoryAPI::newAPIFromConfigurationManager(
|
|
|
|
$configuration_manager);
|
2011-01-09 15:22:25 -08:00
|
|
|
$workflow->setRepositoryAPI($repository_api);
|
|
|
|
}
|
|
|
|
|
2013-10-18 16:10:06 -07:00
|
|
|
$listeners = $configuration_manager->getConfigFromAnySource(
|
|
|
|
'events.listeners');
|
2011-11-10 13:47:45 -08:00
|
|
|
if ($listeners) {
|
|
|
|
foreach ($listeners as $listener) {
|
2012-09-05 11:45:54 -07:00
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht("Registering event listener '%s'.", $listener));
|
2012-09-05 11:45:54 -07:00
|
|
|
try {
|
|
|
|
id(new $listener())->register();
|
|
|
|
} catch (PhutilMissingSymbolException $ex) {
|
2014-07-13 00:45:38 +10:00
|
|
|
// Continue anyway, since you may otherwise be unable to run commands
|
2012-10-16 10:01:35 -07:00
|
|
|
// like `arc set-config events.listeners` in order to repair the damage
|
2013-11-20 12:46:38 -08:00
|
|
|
// you've caused. We're writing out the entire exception here because
|
|
|
|
// it might not have been triggered by the listener itself (for example,
|
|
|
|
// the listener might use a bad class in its register() method).
|
2012-09-05 11:45:54 -07:00
|
|
|
$console->writeErr(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht(
|
|
|
|
"ERROR: Failed to load event listener '%s': %s",
|
|
|
|
$listener,
|
|
|
|
$ex->getMessage()));
|
2012-09-05 11:45:54 -07:00
|
|
|
}
|
2011-11-10 13:47:45 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-01-09 15:22:25 -08:00
|
|
|
$config->willRunWorkflow($command, $workflow);
|
|
|
|
$workflow->willRunWorkflow();
|
2013-03-21 15:51:39 -07:00
|
|
|
try {
|
|
|
|
$err = $workflow->run();
|
|
|
|
$config->didRunWorkflow($command, $workflow, $err);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
$workflow->finalize();
|
|
|
|
throw $e;
|
|
|
|
}
|
|
|
|
$workflow->finalize();
|
2012-06-13 16:01:29 -07:00
|
|
|
exit((int)$err);
|
2011-01-09 15:22:25 -08:00
|
|
|
|
2013-01-24 14:45:21 -08:00
|
|
|
} catch (ArcanistNoEffectException $ex) {
|
|
|
|
echo $ex->getMessage()."\n";
|
|
|
|
|
2012-10-16 10:21:56 -07:00
|
|
|
} catch (Exception $ex) {
|
|
|
|
$is_usage = ($ex instanceof ArcanistUsageException);
|
|
|
|
if ($is_usage) {
|
|
|
|
echo phutil_console_format(
|
2015-01-06 23:14:04 +11:00
|
|
|
"**%s** %s\n",
|
|
|
|
pht('Usage Exception:'),
|
2012-10-16 10:21:56 -07:00
|
|
|
$ex->getMessage());
|
2011-01-09 15:22:25 -08:00
|
|
|
}
|
|
|
|
|
2012-10-30 10:44:49 -07:00
|
|
|
if ($config) {
|
|
|
|
$config->didAbortWorkflow($command, $workflow, $ex);
|
|
|
|
}
|
2012-10-16 10:21:56 -07:00
|
|
|
|
2011-01-09 15:22:25 -08:00
|
|
|
if ($config_trace_mode) {
|
2012-10-16 10:21:56 -07:00
|
|
|
echo "\n";
|
2011-01-09 15:22:25 -08:00
|
|
|
throw $ex;
|
|
|
|
}
|
|
|
|
|
2012-10-16 10:21:56 -07:00
|
|
|
if (!$is_usage) {
|
2015-01-06 23:14:04 +11:00
|
|
|
echo phutil_console_format("**%s**\n", pht('Exception'));
|
2014-06-24 09:24:00 +10:00
|
|
|
|
|
|
|
while ($ex) {
|
|
|
|
echo $ex->getMessage()."\n";
|
|
|
|
|
|
|
|
if ($ex instanceof PhutilProxyException) {
|
|
|
|
$ex = $ex->getPreviousException();
|
|
|
|
} else {
|
|
|
|
$ex = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-06 23:14:04 +11:00
|
|
|
echo phutil_console_format(
|
|
|
|
"(%s)\n",
|
|
|
|
pht('Run with `%s` for a full exception trace.', '--trace'));
|
2012-10-16 10:21:56 -07:00
|
|
|
}
|
2011-01-09 15:22:25 -08:00
|
|
|
|
|
|
|
exit(1);
|
|
|
|
}
|
2011-12-22 10:23:29 -08:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Perform some sanity checks against the possible diversity of PHP builds in
|
|
|
|
* the wild, like very old versions and builds that were compiled with flags
|
|
|
|
* that exclude core functionality.
|
|
|
|
*/
|
|
|
|
function sanity_check_environment() {
|
2012-09-17 13:53:04 -07:00
|
|
|
// NOTE: We don't have phutil_is_windows() yet here.
|
|
|
|
$is_windows = (DIRECTORY_SEPARATOR != '/');
|
|
|
|
|
|
|
|
// We use stream_socket_pair() which is not available on Windows earlier.
|
|
|
|
$min_version = ($is_windows ? '5.3.0' : '5.2.3');
|
2011-12-22 10:23:29 -08:00
|
|
|
$cur_version = phpversion();
|
|
|
|
if (version_compare($cur_version, $min_version, '<')) {
|
|
|
|
die_with_bad_php(
|
|
|
|
"You are running PHP version '{$cur_version}', which is older than ".
|
|
|
|
"the minimum version, '{$min_version}'. Update to at least ".
|
|
|
|
"'{$min_version}'.");
|
|
|
|
}
|
|
|
|
|
2012-09-17 13:53:04 -07:00
|
|
|
if ($is_windows) {
|
2012-03-05 10:02:37 -08:00
|
|
|
$need_functions = array(
|
|
|
|
'curl_init' => array('builtin-dll', 'php_curl.dll'),
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$need_functions = array(
|
2012-05-07 06:06:38 -07:00
|
|
|
'curl_init' => array(
|
|
|
|
'text',
|
|
|
|
"You need to install the cURL PHP extension, maybe with ".
|
|
|
|
"'apt-get install php5-curl' or 'yum install php53-curl' or ".
|
2014-09-27 10:21:23 +10:00
|
|
|
"something similar.",),
|
2012-05-07 06:06:38 -07:00
|
|
|
'json_decode' => array('flag', '--without-json'),
|
2012-03-05 10:02:37 -08:00
|
|
|
);
|
|
|
|
}
|
2011-12-22 10:23:29 -08:00
|
|
|
|
|
|
|
$problems = array();
|
|
|
|
|
|
|
|
$config = null;
|
|
|
|
$show_config = false;
|
2012-03-05 10:02:37 -08:00
|
|
|
foreach ($need_functions as $fname => $resolution) {
|
2011-12-22 10:23:29 -08:00
|
|
|
if (function_exists($fname)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
static $info;
|
|
|
|
if ($info === null) {
|
|
|
|
ob_start();
|
|
|
|
phpinfo(INFO_GENERAL);
|
|
|
|
$info = ob_get_clean();
|
|
|
|
$matches = null;
|
|
|
|
if (preg_match('/^Configure Command =>\s*(.*?)$/m', $info, $matches)) {
|
|
|
|
$config = $matches[1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-05 10:02:37 -08:00
|
|
|
$generic = true;
|
|
|
|
list($what, $which) = $resolution;
|
|
|
|
|
|
|
|
if ($what == 'flag' && strpos($config, $which) !== false) {
|
2011-12-22 10:23:29 -08:00
|
|
|
$show_config = true;
|
2012-03-05 10:02:37 -08:00
|
|
|
$generic = false;
|
2011-12-22 10:23:29 -08:00
|
|
|
$problems[] =
|
2012-03-05 10:02:37 -08:00
|
|
|
"This build of PHP was compiled with the configure flag '{$which}', ".
|
2011-12-22 10:23:29 -08:00
|
|
|
"which means it does not have the function '{$fname}()'. This ".
|
|
|
|
"function is required for arc to run. Rebuild PHP without this flag. ".
|
|
|
|
"You may also be able to build or install the relevant extension ".
|
|
|
|
"separately.";
|
2012-03-05 10:02:37 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($what == 'builtin-dll') {
|
|
|
|
$generic = false;
|
|
|
|
$problems[] =
|
|
|
|
"Your install of PHP does not have the '{$which}' extension enabled. ".
|
|
|
|
"Edit your php.ini file and uncomment the line which reads ".
|
|
|
|
"'extension={$which}'.";
|
|
|
|
}
|
|
|
|
|
2012-05-07 06:06:38 -07:00
|
|
|
if ($what == 'text') {
|
|
|
|
$generic = false;
|
|
|
|
$problems[] = $which;
|
|
|
|
}
|
|
|
|
|
2012-03-05 10:02:37 -08:00
|
|
|
if ($generic) {
|
2011-12-22 10:23:29 -08:00
|
|
|
$problems[] =
|
|
|
|
"This build of PHP is missing the required function '{$fname}()'. ".
|
|
|
|
"Rebuild PHP or install the extension which provides '{$fname}()'.";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($problems) {
|
|
|
|
if ($show_config) {
|
|
|
|
$problems[] = "PHP was built with this configure command:\n\n{$config}";
|
|
|
|
}
|
|
|
|
die_with_bad_php(implode("\n\n", $problems));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function die_with_bad_php($message) {
|
2015-01-06 09:53:11 -08:00
|
|
|
// NOTE: We're bailing because PHP is broken. We can't call any library
|
|
|
|
// functions because they won't be loaded yet.
|
|
|
|
|
|
|
|
echo "\n";
|
|
|
|
echo 'PHP CONFIGURATION ERRORS';
|
|
|
|
echo "\n\n";
|
|
|
|
echo $message;
|
|
|
|
echo "\n\n";
|
2011-12-22 10:23:29 -08:00
|
|
|
exit(1);
|
|
|
|
}
|
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 11:41:39 -07:00
|
|
|
|
|
|
|
function arcanist_load_libraries(
|
|
|
|
$load,
|
|
|
|
$must_load,
|
|
|
|
$lib_source,
|
2012-09-05 11:45:54 -07:00
|
|
|
ArcanistWorkingCopyIdentity $working_copy) {
|
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 11:41:39 -07:00
|
|
|
|
|
|
|
if (!$load) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-07-06 10:05:55 -07:00
|
|
|
if (!is_array($load)) {
|
2015-01-06 23:14:04 +11:00
|
|
|
$error = pht(
|
|
|
|
'Libraries specified by %s are invalid; expected a list. '.
|
|
|
|
'Check your configuration.',
|
|
|
|
$lib_source);
|
2012-07-06 10:05:55 -07:00
|
|
|
$console = PhutilConsole::getConsole();
|
2015-01-06 23:14:04 +11:00
|
|
|
$console->writeErr("%s: %s\n", pht('WARNING'), $error);
|
2012-07-06 10:05:55 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
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 11:41:39 -07:00
|
|
|
foreach ($load as $location) {
|
|
|
|
|
|
|
|
// Try to resolve the library location. We look in several places, in
|
|
|
|
// order:
|
|
|
|
//
|
|
|
|
// 1. Inside the working copy. This is for phutil libraries within the
|
|
|
|
// project. For instance "library/src" will resolve to
|
|
|
|
// "./library/src" if it exists.
|
|
|
|
// 2. In the same directory as the working copy. This allows you to
|
|
|
|
// check out a library alongside a working copy and reference it.
|
|
|
|
// If we haven't resolved yet, "library/src" will try to resolve to
|
|
|
|
// "../library/src" if it exists.
|
|
|
|
// 3. Using normal libphutil resolution rules. Generally, this means
|
|
|
|
// that it checks for libraries next to libphutil, then libraries
|
|
|
|
// in the PHP include_path.
|
|
|
|
//
|
|
|
|
// Note that absolute paths will just resolve absolutely through rule (1).
|
|
|
|
|
|
|
|
$resolved = false;
|
|
|
|
|
|
|
|
// Check inside the working copy. This also checks absolute paths, since
|
|
|
|
// they'll resolve absolute and just ignore the project root.
|
|
|
|
$resolved_location = Filesystem::resolvePath(
|
|
|
|
$location,
|
|
|
|
$working_copy->getProjectRoot());
|
|
|
|
if (Filesystem::pathExists($resolved_location)) {
|
|
|
|
$location = $resolved_location;
|
|
|
|
$resolved = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we didn't find anything, check alongside the working copy.
|
|
|
|
if (!$resolved) {
|
|
|
|
$resolved_location = Filesystem::resolvePath(
|
|
|
|
$location,
|
|
|
|
dirname($working_copy->getProjectRoot()));
|
|
|
|
if (Filesystem::pathExists($resolved_location)) {
|
|
|
|
$location = $resolved_location;
|
|
|
|
$resolved = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-09-05 11:45:54 -07:00
|
|
|
$console = PhutilConsole::getConsole();
|
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht("Loading phutil library from '%s'...", $location));
|
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 11:41:39 -07:00
|
|
|
|
|
|
|
$error = null;
|
|
|
|
try {
|
|
|
|
phutil_load_library($location);
|
|
|
|
} catch (PhutilBootloaderException $ex) {
|
2015-01-06 23:14:04 +11:00
|
|
|
$error = pht(
|
|
|
|
"Failed to load phutil library at location '%s'. This library ".
|
|
|
|
"is specified by %s. Check that the setting is correct and the ".
|
|
|
|
"library is located in the right place.",
|
|
|
|
$location,
|
|
|
|
$lib_source);
|
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 11:41:39 -07:00
|
|
|
if ($must_load) {
|
|
|
|
throw new ArcanistUsageException($error);
|
|
|
|
} else {
|
2015-01-06 23:14:04 +11:00
|
|
|
fwrite(STDERR, phutil_console_wrap(
|
|
|
|
"%s: %s\n\n",
|
|
|
|
pht('WARNING'),
|
|
|
|
$error));
|
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 11:41:39 -07:00
|
|
|
}
|
|
|
|
} catch (PhutilLibraryConflictException $ex) {
|
|
|
|
if ($ex->getLibrary() != 'arcanist') {
|
|
|
|
throw $ex;
|
|
|
|
}
|
|
|
|
$arc_dir = dirname(dirname(__FILE__));
|
2015-01-06 23:14:04 +11:00
|
|
|
$error = pht(
|
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 11:41:39 -07:00
|
|
|
"You are trying to run one copy of Arcanist on another copy of ".
|
|
|
|
"Arcanist. This operation is not supported. To execute Arcanist ".
|
2015-01-06 23:14:04 +11:00
|
|
|
"operations against this working copy, run `%s` (from the current ".
|
|
|
|
"working copy) not some other copy of '%s' (you ran one from '%s').",
|
|
|
|
'./bin/arc',
|
|
|
|
'arc',
|
|
|
|
$arc_dir);
|
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 11:41:39 -07:00
|
|
|
throw new ArcanistUsageException($error);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-12-17 16:35:03 -08:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NOTE: SPOOKY BLACK MAGIC
|
|
|
|
*
|
|
|
|
* When arc is run in a copy of arcanist other than itself, or a copy of
|
|
|
|
* libphutil other than the one we loaded, reenter the script and force it
|
|
|
|
* to use the current working directory instead of the default.
|
|
|
|
*
|
|
|
|
* In the case of execution inside arcanist/, we force execution of the local
|
|
|
|
* arc binary.
|
|
|
|
*
|
|
|
|
* In the case of execution inside libphutil/, we force the local copy to load
|
|
|
|
* instead of the one selected by default rules.
|
|
|
|
*
|
|
|
|
* @param PhutilConsole Console.
|
|
|
|
* @param ArcanistWorkingCopyIdentity The current working copy.
|
|
|
|
* @param array Original arc arguments.
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function reenter_if_this_is_arcanist_or_libphutil(
|
|
|
|
PhutilConsole $console,
|
|
|
|
ArcanistWorkingCopyIdentity $working_copy,
|
|
|
|
array $original_argv) {
|
|
|
|
|
|
|
|
$project_id = $working_copy->getProjectID();
|
|
|
|
if ($project_id != 'arcanist' && $project_id != 'libphutil') {
|
|
|
|
// We're not in a copy of arcanist or libphutil.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$library_names = array(
|
|
|
|
'arcanist' => 'arcanist',
|
|
|
|
'libphutil' => 'phutil',
|
|
|
|
);
|
|
|
|
|
|
|
|
$library_root = phutil_get_library_root($library_names[$project_id]);
|
|
|
|
$project_root = $working_copy->getProjectRoot();
|
|
|
|
if (Filesystem::isDescendant($library_root, $project_root)) {
|
|
|
|
// We're in a copy of arcanist or libphutil, but already loaded the correct
|
|
|
|
// copy. Continue execution normally.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($project_id == 'libphutil') {
|
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht('This is libphutil! Forcing this copy to load...'));
|
2012-12-17 16:35:03 -08:00
|
|
|
$original_argv[0] = dirname(phutil_get_library_root('arcanist')).'/bin/arc';
|
|
|
|
$libphutil_path = $project_root;
|
|
|
|
} else {
|
|
|
|
$console->writeLog(
|
2015-01-06 23:14:04 +11:00
|
|
|
"%s\n",
|
|
|
|
pht('This is arcanist! Forcing this copy to run...'));
|
2012-12-17 16:35:03 -08:00
|
|
|
$original_argv[0] = $project_root.'/bin/arc';
|
|
|
|
$libphutil_path = dirname(phutil_get_library_root('phutil'));
|
|
|
|
}
|
|
|
|
|
2013-02-03 15:00:23 -08:00
|
|
|
if (phutil_is_windows()) {
|
|
|
|
$err = phutil_passthru(
|
|
|
|
'set ARC_PHUTIL_PATH=%s & %Ls',
|
|
|
|
$libphutil_path,
|
|
|
|
$original_argv);
|
|
|
|
} else {
|
|
|
|
$err = phutil_passthru(
|
|
|
|
'ARC_PHUTIL_PATH=%s %Ls',
|
|
|
|
$libphutil_path,
|
|
|
|
$original_argv);
|
|
|
|
}
|
2012-12-17 16:35:03 -08:00
|
|
|
|
|
|
|
exit($err);
|
|
|
|
}
|