blob: 0dbf911a26a679ac902359d52016c4f002eb52d0 [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <algorithm>
#include <set>
#include "base/command_line.h"
#include "gn/commands.h"
#include "gn/label_pattern.h"
#include "gn/setup.h"
#include "gn/standard_out.h"
#include "gn/switches.h"
#include "gn/target.h"
namespace commands {
const char kLs[] = "ls";
const char kLs_HelpShort[] = "ls: List matching targets.";
const char kLs_Help[] =
R"(gn ls <out_dir> [<label_pattern>] [--default-toolchain] [--as=...]
[--type=...] [--testonly=...]
Lists all targets matching the given pattern for the given build directory.
By default, only targets in the default toolchain will be matched unless a
toolchain is explicitly supplied.
If the label pattern is unspecified, list all targets. The label pattern is
not a general regular expression (see "gn help label_pattern"). If you need
more complex expressions, pipe the result through grep.
Options
)" TARGET_PRINTING_MODE_COMMAND_LINE_HELP "\n" DEFAULT_TOOLCHAIN_SWITCH_HELP
"\n" TARGET_TESTONLY_FILTER_COMMAND_LINE_HELP
"\n" TARGET_TYPE_FILTER_COMMAND_LINE_HELP
R"(
Examples
gn ls out/Debug
Lists all targets in the default toolchain.
gn ls out/Debug "//base/*"
Lists all targets in the directory base and all subdirectories.
gn ls out/Debug "//base:*"
Lists all targets defined in //base/BUILD.gn.
gn ls out/Debug //base --as=output
Lists the build output file for //base:base
gn ls out/Debug --type=executable
Lists all executables produced by the build.
gn ls out/Debug "//base/*" --as=output | xargs ninja -C out/Debug
Builds all targets in //base and all subdirectories.
)";
int RunLs(const std::vector<std::string>& args) {
if (args.size() == 0) {
Err(Location(), "Unknown command format. See \"gn help ls\"",
"Usage: \"gn ls <build dir> [<label_pattern>]*\"")
.PrintToStdout();
return 1;
}
// Deliberately leaked to avoid expensive process teardown.
Setup* setup = new Setup;
if (!setup->DoSetup(args[0], false) || !setup->Run())
return 1;
const base::CommandLine* cmdline = base::CommandLine::ForCurrentProcess();
bool default_toolchain_only = cmdline->HasSwitch(switches::kDefaultToolchain);
std::vector<const Target*> matches;
if (args.size() > 1) {
// Some patterns or explicit labels were specified.
std::vector<std::string> inputs(args.begin() + 1, args.end());
UniqueVector<const Target*> target_matches;
UniqueVector<const Config*> config_matches;
UniqueVector<const Toolchain*> toolchain_matches;
UniqueVector<SourceFile> file_matches;
if (!ResolveFromCommandLineInput(setup, inputs, default_toolchain_only,
&target_matches, &config_matches,
&toolchain_matches, &file_matches))
return 1;
matches.insert(matches.begin(), target_matches.begin(),
target_matches.end());
} else if (default_toolchain_only) {
// List all resolved targets in the default toolchain.
for (auto* target : setup->builder().GetAllResolvedTargets()) {
if (target->settings()->is_default())
matches.push_back(target);
}
} else {
// List all resolved targets.
matches = setup->builder().GetAllResolvedTargets();
}
FilterAndPrintTargets(false, &matches);
return 0;
}
} // namespace commands