123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- file Copyright.txt or https://cmake.org/licensing for details. */
- #include "cmGetDirectoryPropertyCommand.h"
- #include "cmExecutionStatus.h"
- #include "cmGlobalGenerator.h"
- #include "cmMakefile.h"
- #include "cmSystemTools.h"
- #include "cmValue.h"
- namespace {
- void StoreResult(cmMakefile& makefile, std::string const& variable,
- cmValue prop);
- }
- // cmGetDirectoryPropertyCommand
- bool cmGetDirectoryPropertyCommand(std::vector<std::string> const& args,
- cmExecutionStatus& status)
- {
- if (args.size() < 2) {
- status.SetError("called with incorrect number of arguments");
- return false;
- }
- auto i = args.begin();
- std::string const& variable = *i;
- ++i;
- // get the directory argument if there is one
- cmMakefile* dir = &status.GetMakefile();
- if (*i == "DIRECTORY") {
- ++i;
- if (i == args.end()) {
- status.SetError(
- "DIRECTORY argument provided without subsequent arguments");
- return false;
- }
- std::string sd = cmSystemTools::CollapseFullPath(
- *i, status.GetMakefile().GetCurrentSourceDirectory());
- // lookup the makefile from the directory name
- dir = status.GetMakefile().GetGlobalGenerator()->FindMakefile(sd);
- if (!dir) {
- status.SetError(
- "DIRECTORY argument provided but requested directory not found. "
- "This could be because the directory argument was invalid or, "
- "it is valid but has not been processed yet.");
- return false;
- }
- ++i;
- if (i == args.end()) {
- status.SetError("called with incorrect number of arguments");
- return false;
- }
- }
- // OK, now we have the directory to process, we just get the requested
- // information out of it
- if (*i == "DEFINITION") {
- ++i;
- if (i == args.end()) {
- status.SetError("A request for a variable definition was made without "
- "providing the name of the variable to get.");
- return false;
- }
- std::string const& output = dir->GetSafeDefinition(*i);
- status.GetMakefile().AddDefinition(variable, output);
- return true;
- }
- if (i->empty()) {
- status.SetError("given empty string for the property name to get");
- return false;
- }
- StoreResult(status.GetMakefile(), variable, dir->GetProperty(*i));
- return true;
- }
- namespace {
- void StoreResult(cmMakefile& makefile, std::string const& variable,
- cmValue prop)
- {
- makefile.AddDefinition(variable, prop);
- }
- }
|