mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-12-01 01:36:09 +03:00
51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
|
// 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.
|
||
|
|
||
|
#include "tools/gn/config.h"
|
||
|
|
||
|
#include "tools/gn/err.h"
|
||
|
#include "tools/gn/input_file_manager.h"
|
||
|
#include "tools/gn/scheduler.h"
|
||
|
|
||
|
Config::Config(const Settings* settings,
|
||
|
const Label& label,
|
||
|
const std::set<SourceFile>& build_dependency_files)
|
||
|
: Item(settings, label, build_dependency_files), resolved_(false) {}
|
||
|
|
||
|
Config::~Config() = default;
|
||
|
|
||
|
Config* Config::AsConfig() {
|
||
|
return this;
|
||
|
}
|
||
|
|
||
|
const Config* Config::AsConfig() const {
|
||
|
return this;
|
||
|
}
|
||
|
|
||
|
bool Config::OnResolved(Err* err) {
|
||
|
DCHECK(!resolved_);
|
||
|
resolved_ = true;
|
||
|
|
||
|
if (!configs_.empty()) {
|
||
|
// Subconfigs, flatten.
|
||
|
//
|
||
|
// Implementation note for the future: Flattening these here means we
|
||
|
// lose the ability to de-dupe subconfigs. If a subconfig is listed as
|
||
|
// a separate config or a subconfig that also applies to the target, the
|
||
|
// subconfig's flags will be duplicated.
|
||
|
//
|
||
|
// If we want to be able to de-dupe these, here's one idea. As a config is
|
||
|
// resolved, inline any sub-sub configs so the configs_ vector is a flat
|
||
|
// list, much the same way that libs and lib_dirs are pushed through
|
||
|
// targets. Do the same for Target.configs_ when a target is resolved. This
|
||
|
// will naturally de-dupe and also prevents recursive config walking to
|
||
|
// compute every possible flag, although it will expand the configs list on
|
||
|
// a target nontrivially (depending on build configuration).
|
||
|
composite_values_ = own_values_;
|
||
|
for (const auto& pair : configs_)
|
||
|
composite_values_.AppendValues(pair.ptr->resolved_values());
|
||
|
}
|
||
|
return true;
|
||
|
}
|