|  | // Copyright (c) 2013 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_BINARY_TARGET_WRITER_H_ | 
|  | #define TOOLS_GN_NINJA_BINARY_TARGET_WRITER_H_ | 
|  |  | 
|  | #include "base/macros.h" | 
|  | #include "tools/gn/config_values.h" | 
|  | #include "tools/gn/ninja_target_writer.h" | 
|  | #include "tools/gn/toolchain.h" | 
|  | #include "tools/gn/unique_vector.h" | 
|  |  | 
|  | struct EscapeOptions; | 
|  | class SourceFileTypeSet; | 
|  |  | 
|  | // Writes a .ninja file for a binary target type (an executable, a shared | 
|  | // library, or a static library). | 
|  | class NinjaBinaryTargetWriter : public NinjaTargetWriter { | 
|  | public: | 
|  | class SourceFileTypeSet; | 
|  |  | 
|  | NinjaBinaryTargetWriter(const Target* target, std::ostream& out); | 
|  | ~NinjaBinaryTargetWriter() override; | 
|  |  | 
|  | void Run() override; | 
|  |  | 
|  | private: | 
|  | typedef std::set<OutputFile> OutputFileSet; | 
|  |  | 
|  | // Writes all flags for the compiler: includes, defines, cflags, etc. | 
|  | void WriteCompilerVars(const SourceFileTypeSet& used_types); | 
|  |  | 
|  | // Writes to the output stream a stamp rule for inputs, and | 
|  | // returns the file to be appended to source rules that encodes the | 
|  | // implicit dependencies for the current target. The returned OutputFile | 
|  | // will be empty if there are no inputs. | 
|  | OutputFile WriteInputsStampAndGetDep() const; | 
|  |  | 
|  | // has_precompiled_headers is set when this substitution matches a tool type | 
|  | // that supports precompiled headers, and this target supports precompiled | 
|  | // headers. It doesn't indicate if the tool has precompiled headers (this | 
|  | // will be looked up by this function). | 
|  | // | 
|  | // The tool_type indicates the corresponding tool for flags that are | 
|  | // tool-specific (e.g. "cflags_c"). For non-tool-specific flags (e.g. | 
|  | // "defines") tool_type should be TYPE_NONE. | 
|  | void WriteOneFlag( | 
|  | SubstitutionType subst_enum, | 
|  | bool has_precompiled_headers, | 
|  | Toolchain::ToolType tool_type, | 
|  | const std::vector<std::string>& (ConfigValues::* getter)() const, | 
|  | EscapeOptions flag_escape_options); | 
|  |  | 
|  | // 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_dep 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 SourceFileTypeSet& used_types, | 
|  | const OutputFile& input_dep, | 
|  | 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(SubstitutionType flag_type, | 
|  | Toolchain::ToolType tool_type, | 
|  | Tool::PrecompiledHeaderType header_type, | 
|  | const OutputFile& input_dep, | 
|  | const std::vector<OutputFile>& order_only_deps, | 
|  | std::vector<OutputFile>* object_files, | 
|  | std::vector<OutputFile>* other_files); | 
|  |  | 
|  | void WriteGCCPCHCommand(SubstitutionType flag_type, | 
|  | Toolchain::ToolType tool_type, | 
|  | const OutputFile& input_dep, | 
|  | const std::vector<OutputFile>& order_only_deps, | 
|  | std::vector<OutputFile>* gch_files); | 
|  |  | 
|  | void WriteWindowsPCHCommand(SubstitutionType flag_type, | 
|  | Toolchain::ToolType tool_type, | 
|  | const OutputFile& input_dep, | 
|  | 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 OutputFile& input_dep, | 
|  | const std::vector<OutputFile>& order_only_deps, | 
|  | std::vector<OutputFile>* object_files, | 
|  | std::vector<SourceFile>* other_files); | 
|  |  | 
|  | // Writes a build line. | 
|  | void WriteCompilerBuildLine(const SourceFile& source, | 
|  | const std::vector<OutputFile>& extra_deps, | 
|  | const std::vector<OutputFile>& order_only_deps, | 
|  | Toolchain::ToolType tool_type, | 
|  | const std::vector<OutputFile>& outputs); | 
|  |  | 
|  | void WriteLinkerStuff(const std::vector<OutputFile>& object_files, | 
|  | const std::vector<SourceFile>& other_files, | 
|  | const OutputFile& input_dep); | 
|  | void WriteLinkerFlags(const SourceFile* optional_def_file); | 
|  | void WriteLibs(); | 
|  | void WriteOutputSubstitutions(); | 
|  | void WriteSolibs(const std::vector<OutputFile>& solibs); | 
|  |  | 
|  | // Writes the stamp line for a source set. These are not linked. | 
|  | void WriteSourceSetStamp(const std::vector<OutputFile>& object_files); | 
|  |  | 
|  | // Gets all target dependencies and classifies them, as well as accumulates | 
|  | // object files from source sets we need to link. | 
|  | void GetDeps(UniqueVector<OutputFile>* extra_object_files, | 
|  | UniqueVector<const Target*>* linkable_deps, | 
|  | UniqueVector<const Target*>* non_linkable_deps) const; | 
|  |  | 
|  | // Classifies the dependency as linkable or nonlinkable with the current | 
|  | // target, adding it to the appropriate vector. If the dependency is a source | 
|  | // set we should link in, the source set's object files will be appended to | 
|  | // |extra_object_files|. | 
|  | void ClassifyDependency(const Target* dep, | 
|  | UniqueVector<OutputFile>* extra_object_files, | 
|  | UniqueVector<const Target*>* linkable_deps, | 
|  | UniqueVector<const Target*>* non_linkable_deps) const; | 
|  |  | 
|  | // 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); | 
|  |  | 
|  | // Returns the computed name of the Windows .pch file for the given | 
|  | // tool type. The tool must support precompiled headers. | 
|  | OutputFile GetWindowsPCHFile(Toolchain::ToolType tool_type) const; | 
|  |  | 
|  | // 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 Tool* tool_; | 
|  |  | 
|  | // Cached version of the prefix used for rule types for this toolchain. | 
|  | std::string rule_prefix_; | 
|  |  | 
|  | DISALLOW_COPY_AND_ASSIGN(NinjaBinaryTargetWriter); | 
|  | }; | 
|  |  | 
|  | #endif  // TOOLS_GN_NINJA_BINARY_TARGET_WRITER_H_ | 
|  |  |