| // Copyright 2018 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_GENERATED_FILE_TARGET_GENERATOR_H_ |
| #define TOOLS_GN_GENERATED_FILE_TARGET_GENERATOR_H_ |
| |
| #include "base/macros.h" |
| #include "tools/gn/target.h" |
| #include "tools/gn/target_generator.h" |
| |
| // Collects and writes specified data. |
| class GeneratedFileTargetGenerator : public TargetGenerator { |
| public: |
| GeneratedFileTargetGenerator(Target* target, |
| Scope* scope, |
| const FunctionCallNode* function_call, |
| Target::OutputType type, |
| Err* err); |
| ~GeneratedFileTargetGenerator() override; |
| |
| protected: |
| void DoRun() override; |
| |
| private: |
| bool FillGeneratedFileOutput(); |
| bool FillOutputConversion(); |
| bool FillContents(); |
| bool FillDataKeys(); |
| bool FillWalkKeys(); |
| bool FillRebase(); |
| |
| // Returns false if `contents` is defined (i.e. if this target was provided |
| // with explicit contents to write). Returns false otherwise, indicating that |
| // it is okay to set metadata collection variables on this target. |
| // |
| // Should be called before FillContents(). |
| bool IsMetadataCollectionTarget(const base::StringPiece& variable, |
| const ParseNode* origin); |
| |
| bool contents_defined_; |
| bool data_keys_defined_; |
| |
| Target::OutputType output_type_; |
| |
| DISALLOW_COPY_AND_ASSIGN(GeneratedFileTargetGenerator); |
| }; |
| |
| #endif // TOOLS_GN_GENERATED_FILE_TARGET_GENERATOR_H_ |