OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef TOOLS_GN_CONFIG_H_ | 5 #ifndef TOOLS_GN_CONFIG_H_ |
6 #define TOOLS_GN_CONFIG_H_ | 6 #define TOOLS_GN_CONFIG_H_ |
7 | 7 |
| 8 #include "base/logging.h" |
8 #include "base/macros.h" | 9 #include "base/macros.h" |
9 #include "tools/gn/config_values.h" | 10 #include "tools/gn/config_values.h" |
10 #include "tools/gn/item.h" | 11 #include "tools/gn/item.h" |
| 12 #include "tools/gn/label_ptr.h" |
| 13 #include "tools/gn/unique_vector.h" |
11 | 14 |
12 // Represents a named config in the dependency graph. | 15 // Represents a named config in the dependency graph. |
| 16 // |
| 17 // A config can list other configs. We track both the data assigned directly |
| 18 // on the config, this list of sub-configs, and (when the config is resolved) |
| 19 // the resulting values of everything merged together. The flatten step |
| 20 // means we can avoid doing a recursive config walk for every target to compute |
| 21 // flags. |
13 class Config : public Item { | 22 class Config : public Item { |
14 public: | 23 public: |
15 Config(const Settings* settings, const Label& label); | 24 Config(const Settings* settings, const Label& label); |
16 ~Config() override; | 25 ~Config() override; |
17 | 26 |
| 27 // Item implementation. |
18 Config* AsConfig() override; | 28 Config* AsConfig() override; |
19 const Config* AsConfig() const override; | 29 const Config* AsConfig() const override; |
| 30 bool OnResolved(Err* err) override; |
20 | 31 |
21 ConfigValues& config_values() { return config_values_; } | 32 // The values set directly on this config. This will not contain data from |
22 const ConfigValues& config_values() const { return config_values_; } | 33 // sub-configs. |
| 34 ConfigValues& own_values() { return own_values_; } |
| 35 const ConfigValues& own_values() const { return own_values_; } |
| 36 |
| 37 // The values that represent this config and all sub-configs combined into |
| 38 // one. This is only valid after the config is resolved (when we know the |
| 39 // contents of the sub-configs). |
| 40 const ConfigValues& resolved_values() const { |
| 41 DCHECK(resolved_); |
| 42 if (configs_.empty()) // No sub configs, just use the regular values. |
| 43 return own_values_; |
| 44 return composite_values_; |
| 45 } |
| 46 |
| 47 // List of sub-configs. |
| 48 const UniqueVector<LabelConfigPair>& configs() const { return configs_; } |
| 49 UniqueVector<LabelConfigPair>& configs() { return configs_; } |
23 | 50 |
24 private: | 51 private: |
25 ConfigValues config_values_; | 52 ConfigValues own_values_; |
| 53 |
| 54 // Contains the own_values combined with sub-configs. Most configs don't have |
| 55 // sub-configs. So as an optimization, this is not populated if there are no |
| 56 // items in configs_. The resolved_values() getter handles this. |
| 57 bool resolved_; |
| 58 ConfigValues composite_values_; |
| 59 |
| 60 UniqueVector<LabelConfigPair> configs_; |
26 | 61 |
27 DISALLOW_COPY_AND_ASSIGN(Config); | 62 DISALLOW_COPY_AND_ASSIGN(Config); |
28 }; | 63 }; |
29 | 64 |
30 #endif // TOOLS_GN_CONFIG_H_ | 65 #endif // TOOLS_GN_CONFIG_H_ |
OLD | NEW |