blob: ee27557e82f0ccc4a63dfbfa36ea441268c763d8 [file] [log] [blame]
// Copyright 2016 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_CREATE_BUNDLE_TARGET_WRITER_H_
#define TOOLS_GN_NINJA_CREATE_BUNDLE_TARGET_WRITER_H_
#include "gn/ninja_target_writer.h"
class BundleFileRule;
// Writes a .ninja file for a bundle_data target type.
class NinjaCreateBundleTargetWriter : public NinjaTargetWriter {
public:
NinjaCreateBundleTargetWriter(const Target* target, std::ostream& out);
~NinjaCreateBundleTargetWriter() override;
void Run() override;
private:
// Writes the Ninja rule for invoking the post-processing script.
//
// Returns the name of the custom rule generated for the post-processing step
// if defined, otherwise returns an empty string.
std::string WritePostProcessingRuleDefinition();
// Writes the steps to copy files into the bundle.
//
// The list of newly created files will be added to |output_files|.
void WriteCopyBundleDataSteps(const std::vector<OutputFile>& order_only_deps,
std::vector<OutputFile>* output_files);
// Writes the step to copy files BundleFileRule into the bundle.
//
// The list of newly created files will be added to |output_files|.
void WriteCopyBundleFileRuleSteps(
const BundleFileRule& file_rule,
const std::vector<OutputFile>& order_only_deps,
std::vector<OutputFile>* output_files);
// Writes the step to compile assets catalogs.
//
// The list of newly created files will be added to |output_files|.
void WriteCompileAssetsCatalogStep(
const std::vector<OutputFile>& order_only_deps,
std::vector<OutputFile>* output_files);
// Writes the phony target for the assets catalog compilation input
// dependencies.
OutputFile WriteCompileAssetsCatalogInputDepsStampOrPhony(
const std::vector<const Target*>& dependencies);
// Writes the post-processing step (if a script is defined).
//
// The list of newly created files will be added to |output_files|. As the
// post-processing may depends on the full bundle structure, this step will
// depends on all files generated via other rules.
void WritePostProcessingStep(const std::string& post_processing_rule_name,
const std::vector<OutputFile>& order_only_deps,
std::vector<OutputFile>* output_files);
// Writes the stamp file or phony target for the post-processing input
// dependencies.
OutputFile WritePostProcessingInputDepsStampOrPhony(
const std::vector<OutputFile>& order_only_deps,
std::vector<OutputFile>* output_files);
NinjaCreateBundleTargetWriter(const NinjaCreateBundleTargetWriter&) = delete;
NinjaCreateBundleTargetWriter& operator=(
const NinjaCreateBundleTargetWriter&) = delete;
};
#endif // TOOLS_GN_NINJA_CREATE_BUNDLE_TARGET_WRITER_H_