| // Copyright 2019 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. |
| |
| #ifndef TOOLS_GN_NINJA_C_BINARY_TARGET_WRITER_H_ |
| #define TOOLS_GN_NINJA_C_BINARY_TARGET_WRITER_H_ |
| |
| #include "base/macros.h" |
| #include "gn/config_values.h" |
| #include "gn/ninja_binary_target_writer.h" |
| #include "gn/toolchain.h" |
| #include "gn/unique_vector.h" |
| |
| struct EscapeOptions; |
| |
| // Writes a .ninja file for a binary target type (an executable, a shared |
| // library, or a static library). |
| class NinjaCBinaryTargetWriter : public NinjaBinaryTargetWriter { |
| public: |
| NinjaCBinaryTargetWriter(const Target* target, std::ostream& out); |
| ~NinjaCBinaryTargetWriter() override; |
| |
| void Run() override; |
| |
| private: |
| using OutputFileSet = std::set<OutputFile>; |
| |
| // Writes all flags for the compiler: includes, defines, cflags, etc. |
| void WriteCompilerVars(); |
| |
| // Writes build lines required for precompiled headers. Any generated |
| // object files will be appended to the |object_files|. Any generated |
| // non-object files (for instance, .gch files from a GCC toolchain, are |
| // appended to |other_files|). |
| // |
| // input_deps is the stamp file collecting the dependencies required before |
| // compiling this target. It will be empty if there are no input deps. |
| void WritePCHCommands(const std::vector<OutputFile>& input_deps, |
| const std::vector<OutputFile>& order_only_deps, |
| std::vector<OutputFile>* object_files, |
| std::vector<OutputFile>* other_files); |
| |
| // Writes a .pch compile build line for a language type. |
| void WritePCHCommand(const Substitution* flag_type, |
| const char* tool_name, |
| CTool::PrecompiledHeaderType header_type, |
| const std::vector<OutputFile>& input_deps, |
| const std::vector<OutputFile>& order_only_deps, |
| std::vector<OutputFile>* object_files, |
| std::vector<OutputFile>* other_files); |
| |
| void WriteGCCPCHCommand(const Substitution* flag_type, |
| const char* tool_name, |
| const std::vector<OutputFile>& input_deps, |
| const std::vector<OutputFile>& order_only_deps, |
| std::vector<OutputFile>* gch_files); |
| |
| void WriteWindowsPCHCommand(const Substitution* flag_type, |
| const char* tool_name, |
| const std::vector<OutputFile>& input_deps, |
| const std::vector<OutputFile>& order_only_deps, |
| std::vector<OutputFile>* object_files); |
| |
| // pch_deps are additional dependencies to run before the rule. They are |
| // expected to abide by the naming conventions specified by GetPCHOutputFiles. |
| // |
| // order_only_dep are the dependencies that must be run before doing any |
| // compiles. |
| // |
| // The files produced by the compiler will be added to two output vectors. |
| void WriteSources(const std::vector<OutputFile>& pch_deps, |
| const std::vector<OutputFile>& input_deps, |
| const std::vector<OutputFile>& order_only_deps, |
| std::vector<OutputFile>* object_files, |
| std::vector<SourceFile>* other_files); |
| |
| void WriteLinkerStuff(const std::vector<OutputFile>& object_files, |
| const std::vector<SourceFile>& other_files, |
| const std::vector<OutputFile>& input_deps); |
| void WriteOutputSubstitutions(); |
| void WriteLibsList(const std::string& label, |
| const std::vector<OutputFile>& libs); |
| |
| // Writes the implicit dependencies for the link or stamp line. This is |
| // the "||" and everything following it on the ninja line. |
| // |
| // The order-only dependencies are the non-linkable deps passed in as an |
| // argument, plus the data file depdencies in the target. |
| void WriteOrderOnlyDependencies( |
| const UniqueVector<const Target*>& non_linkable_deps); |
| |
| // Checks for duplicates in the given list of output files. If any duplicates |
| // are found, throws an error and return false. |
| bool CheckForDuplicateObjectFiles(const std::vector<OutputFile>& files) const; |
| |
| const CTool* tool_; |
| |
| DISALLOW_COPY_AND_ASSIGN(NinjaCBinaryTargetWriter); |
| }; |
| |
| #endif // TOOLS_GN_NINJA_C_BINARY_TARGET_WRITER_H_ |