/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying file Copyright.txt or https://cmake.org/licensing for details. */ #ifndef cmSourceGroupCommand_h #define cmSourceGroupCommand_h #include "cmConfigure.h" // IWYU pragma: keep #include #include #include #include "cm_memory.hxx" #include "cmCommand.h" class cmExecutionStatus; /** \class cmSourceGroupCommand * \brief Adds a cmSourceGroup to the cmMakefile. * * cmSourceGroupCommand is used to define cmSourceGroups which split up * source files in to named, organized groups in the generated makefiles. */ class cmSourceGroupCommand : public cmCommand { public: /** * This is a virtual constructor for the command. */ std::unique_ptr Clone() override { return cm::make_unique(); } /** * This is called when the command is first encountered in * the CMakeLists.txt file. */ bool InitialPass(std::vector const& args, cmExecutionStatus& status) override; private: using ParsedArguments = std::map>; using ExpectedOptions = std::vector; ExpectedOptions getExpectedOptions() const; bool isExpectedOption(const std::string& argument, const ExpectedOptions& expectedOptions); void parseArguments(const std::vector& args, cmSourceGroupCommand::ParsedArguments& parsedArguments); bool processTree(ParsedArguments& parsedArguments, std::string& errorMsg); bool checkArgumentsPreconditions(const ParsedArguments& parsedArguments, std::string& errorMsg) const; bool checkSingleParameterArgumentPreconditions( const std::string& argument, const ParsedArguments& parsedArguments, std::string& errorMsg) const; }; #endif