OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include <sstream> | 5 #include <sstream> |
6 | 6 |
7 #include "testing/gtest/include/gtest/gtest.h" | 7 #include "testing/gtest/include/gtest/gtest.h" |
8 #include "tools/gn/config.h" | 8 #include "tools/gn/config.h" |
9 #include "tools/gn/config_values_extractors.h" | 9 #include "tools/gn/config_values_extractors.h" |
10 #include "tools/gn/target.h" | 10 #include "tools/gn/target.h" |
(...skipping 27 matching lines...) Expand all Loading... |
38 dep2_all.config_values().cflags().push_back("--dep2-all"); | 38 dep2_all.config_values().cflags().push_back("--dep2-all"); |
39 dep2_all.config_values().include_dirs().push_back(SourceDir("//dep2/all/")); | 39 dep2_all.config_values().include_dirs().push_back(SourceDir("//dep2/all/")); |
40 | 40 |
41 Config dep2_direct(setup.settings(), Label(SourceDir("//dep2/"), "direct")); | 41 Config dep2_direct(setup.settings(), Label(SourceDir("//dep2/"), "direct")); |
42 dep2_direct.config_values().cflags().push_back("--dep2-direct"); | 42 dep2_direct.config_values().cflags().push_back("--dep2-direct"); |
43 dep2_direct.config_values().include_dirs().push_back( | 43 dep2_direct.config_values().include_dirs().push_back( |
44 SourceDir("//dep2/direct/")); | 44 SourceDir("//dep2/direct/")); |
45 | 45 |
46 Target dep2(setup.settings(), Label(SourceDir("//dep2/"), "dep2")); | 46 Target dep2(setup.settings(), Label(SourceDir("//dep2/"), "dep2")); |
47 dep2.set_output_type(Target::SOURCE_SET); | 47 dep2.set_output_type(Target::SOURCE_SET); |
| 48 dep2.SetToolchain(setup.toolchain()); |
48 dep2.all_dependent_configs().push_back(LabelConfigPair(&dep2_all)); | 49 dep2.all_dependent_configs().push_back(LabelConfigPair(&dep2_all)); |
49 dep2.direct_dependent_configs().push_back(LabelConfigPair(&dep2_direct)); | 50 dep2.direct_dependent_configs().push_back(LabelConfigPair(&dep2_direct)); |
50 | 51 |
51 // Set up dep1, direct and all dependent configs. | 52 // Set up dep1, direct and all dependent configs. |
52 Config dep1_all(setup.settings(), Label(SourceDir("//dep1/"), "all")); | 53 Config dep1_all(setup.settings(), Label(SourceDir("//dep1/"), "all")); |
53 dep1_all.config_values().cflags().push_back("--dep1-all"); | 54 dep1_all.config_values().cflags().push_back("--dep1-all"); |
54 dep1_all.config_values().include_dirs().push_back(SourceDir("//dep1/all/")); | 55 dep1_all.config_values().include_dirs().push_back(SourceDir("//dep1/all/")); |
55 | 56 |
56 Config dep1_direct(setup.settings(), Label(SourceDir("//dep1/"), "direct")); | 57 Config dep1_direct(setup.settings(), Label(SourceDir("//dep1/"), "direct")); |
57 dep1_direct.config_values().cflags().push_back("--dep1-direct"); | 58 dep1_direct.config_values().cflags().push_back("--dep1-direct"); |
58 dep1_direct.config_values().include_dirs().push_back( | 59 dep1_direct.config_values().include_dirs().push_back( |
59 SourceDir("//dep1/direct/")); | 60 SourceDir("//dep1/direct/")); |
60 | 61 |
61 Target dep1(setup.settings(), Label(SourceDir("//dep1/"), "dep1")); | 62 Target dep1(setup.settings(), Label(SourceDir("//dep1/"), "dep1")); |
62 dep1.set_output_type(Target::SOURCE_SET); | 63 dep1.set_output_type(Target::SOURCE_SET); |
| 64 dep1.SetToolchain(setup.toolchain()); |
63 dep1.all_dependent_configs().push_back(LabelConfigPair(&dep1_all)); | 65 dep1.all_dependent_configs().push_back(LabelConfigPair(&dep1_all)); |
64 dep1.direct_dependent_configs().push_back(LabelConfigPair(&dep1_direct)); | 66 dep1.direct_dependent_configs().push_back(LabelConfigPair(&dep1_direct)); |
65 dep1.deps().push_back(LabelTargetPair(&dep2)); | 67 dep1.deps().push_back(LabelTargetPair(&dep2)); |
66 | 68 |
67 // Set up target, direct and all dependent configs. | 69 // Set up target, direct and all dependent configs. |
68 Config target_all(setup.settings(), Label(SourceDir("//target/"), "all")); | 70 Config target_all(setup.settings(), Label(SourceDir("//target/"), "all")); |
69 target_all.config_values().cflags().push_back("--target-all"); | 71 target_all.config_values().cflags().push_back("--target-all"); |
70 target_all.config_values().include_dirs().push_back( | 72 target_all.config_values().include_dirs().push_back( |
71 SourceDir("//target/all/")); | 73 SourceDir("//target/all/")); |
72 | 74 |
73 Config target_direct(setup.settings(), | 75 Config target_direct(setup.settings(), |
74 Label(SourceDir("//target/"), "direct")); | 76 Label(SourceDir("//target/"), "direct")); |
75 target_direct.config_values().cflags().push_back("--target-direct"); | 77 target_direct.config_values().cflags().push_back("--target-direct"); |
76 target_direct.config_values().include_dirs().push_back( | 78 target_direct.config_values().include_dirs().push_back( |
77 SourceDir("//target/direct/")); | 79 SourceDir("//target/direct/")); |
78 | 80 |
79 // This config is applied directly to target. | 81 // This config is applied directly to target. |
80 Config target_config(setup.settings(), | 82 Config target_config(setup.settings(), |
81 Label(SourceDir("//target/"), "config")); | 83 Label(SourceDir("//target/"), "config")); |
82 target_config.config_values().cflags().push_back("--target-config"); | 84 target_config.config_values().cflags().push_back("--target-config"); |
83 target_config.config_values().include_dirs().push_back( | 85 target_config.config_values().include_dirs().push_back( |
84 SourceDir("//target/config/")); | 86 SourceDir("//target/config/")); |
85 | 87 |
86 Target target(setup.settings(), Label(SourceDir("//target/"), "target")); | 88 Target target(setup.settings(), Label(SourceDir("//target/"), "target")); |
87 target.set_output_type(Target::SOURCE_SET); | 89 target.set_output_type(Target::SOURCE_SET); |
| 90 target.SetToolchain(setup.toolchain()); |
88 target.all_dependent_configs().push_back(LabelConfigPair(&target_all)); | 91 target.all_dependent_configs().push_back(LabelConfigPair(&target_all)); |
89 target.direct_dependent_configs().push_back(LabelConfigPair(&target_direct)); | 92 target.direct_dependent_configs().push_back(LabelConfigPair(&target_direct)); |
90 target.configs().push_back(LabelConfigPair(&target_config)); | 93 target.configs().push_back(LabelConfigPair(&target_config)); |
91 target.deps().push_back(LabelTargetPair(&dep1)); | 94 target.deps().push_back(LabelTargetPair(&dep1)); |
92 | 95 |
93 | 96 |
94 // Additionally add some values directly on "target". | 97 // Additionally add some values directly on "target". |
95 target.config_values().cflags().push_back("--target"); | 98 target.config_values().cflags().push_back("--target"); |
96 target.config_values().include_dirs().push_back( | 99 target.config_values().include_dirs().push_back( |
97 SourceDir("//target/")); | 100 SourceDir("//target/")); |
(...skipping 14 matching lines...) Expand all Loading... |
112 | 115 |
113 // Verify include dirs by serializing. | 116 // Verify include dirs by serializing. |
114 std::ostringstream include_out; | 117 std::ostringstream include_out; |
115 IncludeWriter include_writer; | 118 IncludeWriter include_writer; |
116 RecursiveTargetConfigToStream<SourceDir, IncludeWriter>( | 119 RecursiveTargetConfigToStream<SourceDir, IncludeWriter>( |
117 &target, &ConfigValues::include_dirs, include_writer, include_out); | 120 &target, &ConfigValues::include_dirs, include_writer, include_out); |
118 EXPECT_EQ(include_out.str(), | 121 EXPECT_EQ(include_out.str(), |
119 "//target/ //target/config/ //target/all/ //target/direct/ " | 122 "//target/ //target/config/ //target/all/ //target/direct/ " |
120 "//dep1/all/ //dep2/all/ //dep1/direct/ "); | 123 "//dep1/all/ //dep2/all/ //dep1/direct/ "); |
121 } | 124 } |
OLD | NEW |