| 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 28 matching lines...) Expand all Loading... |
| 39 dep2_all.config_values().cflags().push_back("--dep2-all"); | 39 dep2_all.config_values().cflags().push_back("--dep2-all"); |
| 40 dep2_all.config_values().include_dirs().push_back(SourceDir("//dep2/all/")); | 40 dep2_all.config_values().include_dirs().push_back(SourceDir("//dep2/all/")); |
| 41 | 41 |
| 42 Config dep2_direct(setup.settings(), Label(SourceDir("//dep2/"), "direct")); | 42 Config dep2_direct(setup.settings(), Label(SourceDir("//dep2/"), "direct")); |
| 43 dep2_direct.config_values().cflags().push_back("--dep2-direct"); | 43 dep2_direct.config_values().cflags().push_back("--dep2-direct"); |
| 44 dep2_direct.config_values().include_dirs().push_back( | 44 dep2_direct.config_values().include_dirs().push_back( |
| 45 SourceDir("//dep2/direct/")); | 45 SourceDir("//dep2/direct/")); |
| 46 | 46 |
| 47 Target dep2(setup.settings(), Label(SourceDir("//dep2/"), "dep2")); | 47 Target dep2(setup.settings(), Label(SourceDir("//dep2/"), "dep2")); |
| 48 dep2.set_output_type(Target::SOURCE_SET); | 48 dep2.set_output_type(Target::SOURCE_SET); |
| 49 dep2.visibility().SetPublic(); |
| 49 dep2.SetToolchain(setup.toolchain()); | 50 dep2.SetToolchain(setup.toolchain()); |
| 50 dep2.all_dependent_configs().push_back(LabelConfigPair(&dep2_all)); | 51 dep2.all_dependent_configs().push_back(LabelConfigPair(&dep2_all)); |
| 51 dep2.direct_dependent_configs().push_back(LabelConfigPair(&dep2_direct)); | 52 dep2.public_configs().push_back(LabelConfigPair(&dep2_direct)); |
| 52 | 53 |
| 53 // Set up dep1, direct and all dependent configs. | 54 // Set up dep1, direct and all dependent configs. |
| 54 Config dep1_all(setup.settings(), Label(SourceDir("//dep1/"), "all")); | 55 Config dep1_all(setup.settings(), Label(SourceDir("//dep1/"), "all")); |
| 55 dep1_all.config_values().cflags().push_back("--dep1-all"); | 56 dep1_all.config_values().cflags().push_back("--dep1-all"); |
| 56 dep1_all.config_values().include_dirs().push_back(SourceDir("//dep1/all/")); | 57 dep1_all.config_values().include_dirs().push_back(SourceDir("//dep1/all/")); |
| 57 | 58 |
| 58 Config dep1_direct(setup.settings(), Label(SourceDir("//dep1/"), "direct")); | 59 Config dep1_direct(setup.settings(), Label(SourceDir("//dep1/"), "direct")); |
| 59 dep1_direct.config_values().cflags().push_back("--dep1-direct"); | 60 dep1_direct.config_values().cflags().push_back("--dep1-direct"); |
| 60 dep1_direct.config_values().include_dirs().push_back( | 61 dep1_direct.config_values().include_dirs().push_back( |
| 61 SourceDir("//dep1/direct/")); | 62 SourceDir("//dep1/direct/")); |
| 62 | 63 |
| 63 Target dep1(setup.settings(), Label(SourceDir("//dep1/"), "dep1")); | 64 Target dep1(setup.settings(), Label(SourceDir("//dep1/"), "dep1")); |
| 64 dep1.set_output_type(Target::SOURCE_SET); | 65 dep1.set_output_type(Target::SOURCE_SET); |
| 66 dep1.visibility().SetPublic(); |
| 65 dep1.SetToolchain(setup.toolchain()); | 67 dep1.SetToolchain(setup.toolchain()); |
| 66 dep1.all_dependent_configs().push_back(LabelConfigPair(&dep1_all)); | 68 dep1.all_dependent_configs().push_back(LabelConfigPair(&dep1_all)); |
| 67 dep1.direct_dependent_configs().push_back(LabelConfigPair(&dep1_direct)); | 69 dep1.public_configs().push_back(LabelConfigPair(&dep1_direct)); |
| 68 dep1.deps().push_back(LabelTargetPair(&dep2)); | 70 dep1.private_deps().push_back(LabelTargetPair(&dep2)); |
| 69 | 71 |
| 70 // Set up target, direct and all dependent configs. | 72 // Set up target, direct and all dependent configs. |
| 71 Config target_all(setup.settings(), Label(SourceDir("//target/"), "all")); | 73 Config target_all(setup.settings(), Label(SourceDir("//target/"), "all")); |
| 72 target_all.config_values().cflags().push_back("--target-all"); | 74 target_all.config_values().cflags().push_back("--target-all"); |
| 73 target_all.config_values().include_dirs().push_back( | 75 target_all.config_values().include_dirs().push_back( |
| 74 SourceDir("//target/all/")); | 76 SourceDir("//target/all/")); |
| 75 | 77 |
| 76 Config target_direct(setup.settings(), | 78 Config target_direct(setup.settings(), |
| 77 Label(SourceDir("//target/"), "direct")); | 79 Label(SourceDir("//target/"), "direct")); |
| 78 target_direct.config_values().cflags().push_back("--target-direct"); | 80 target_direct.config_values().cflags().push_back("--target-direct"); |
| 79 target_direct.config_values().include_dirs().push_back( | 81 target_direct.config_values().include_dirs().push_back( |
| 80 SourceDir("//target/direct/")); | 82 SourceDir("//target/direct/")); |
| 81 | 83 |
| 82 // This config is applied directly to target. | 84 // This config is applied directly to target. |
| 83 Config target_config(setup.settings(), | 85 Config target_config(setup.settings(), |
| 84 Label(SourceDir("//target/"), "config")); | 86 Label(SourceDir("//target/"), "config")); |
| 85 target_config.config_values().cflags().push_back("--target-config"); | 87 target_config.config_values().cflags().push_back("--target-config"); |
| 86 target_config.config_values().include_dirs().push_back( | 88 target_config.config_values().include_dirs().push_back( |
| 87 SourceDir("//target/config/")); | 89 SourceDir("//target/config/")); |
| 88 | 90 |
| 89 Target target(setup.settings(), Label(SourceDir("//target/"), "target")); | 91 Target target(setup.settings(), Label(SourceDir("//target/"), "target")); |
| 90 target.set_output_type(Target::SOURCE_SET); | 92 target.set_output_type(Target::SOURCE_SET); |
| 91 target.SetToolchain(setup.toolchain()); | 93 target.SetToolchain(setup.toolchain()); |
| 92 target.all_dependent_configs().push_back(LabelConfigPair(&target_all)); | 94 target.all_dependent_configs().push_back(LabelConfigPair(&target_all)); |
| 93 target.direct_dependent_configs().push_back(LabelConfigPair(&target_direct)); | 95 target.public_configs().push_back(LabelConfigPair(&target_direct)); |
| 94 target.configs().push_back(LabelConfigPair(&target_config)); | 96 target.configs().push_back(LabelConfigPair(&target_config)); |
| 95 target.deps().push_back(LabelTargetPair(&dep1)); | 97 target.private_deps().push_back(LabelTargetPair(&dep1)); |
| 96 | 98 |
| 97 | 99 |
| 98 // Additionally add some values directly on "target". | 100 // Additionally add some values directly on "target". |
| 99 target.config_values().cflags().push_back("--target"); | 101 target.config_values().cflags().push_back("--target"); |
| 100 target.config_values().include_dirs().push_back( | 102 target.config_values().include_dirs().push_back( |
| 101 SourceDir("//target/")); | 103 SourceDir("//target/")); |
| 102 | 104 |
| 103 // Mark targets resolved. This should push dependent configs. | 105 // Mark targets resolved. This should push dependent configs. |
| 104 ASSERT_TRUE(dep2.OnResolved(&err)); | 106 ASSERT_TRUE(dep2.OnResolved(&err)); |
| 105 ASSERT_TRUE(dep1.OnResolved(&err)); | 107 ASSERT_TRUE(dep1.OnResolved(&err)); |
| (...skipping 10 matching lines...) Expand all Loading... |
| 116 | 118 |
| 117 // Verify include dirs by serializing. | 119 // Verify include dirs by serializing. |
| 118 std::ostringstream include_out; | 120 std::ostringstream include_out; |
| 119 IncludeWriter include_writer; | 121 IncludeWriter include_writer; |
| 120 RecursiveTargetConfigToStream<SourceDir, IncludeWriter>( | 122 RecursiveTargetConfigToStream<SourceDir, IncludeWriter>( |
| 121 &target, &ConfigValues::include_dirs, include_writer, include_out); | 123 &target, &ConfigValues::include_dirs, include_writer, include_out); |
| 122 EXPECT_EQ(include_out.str(), | 124 EXPECT_EQ(include_out.str(), |
| 123 "//target/ //target/config/ //target/all/ //target/direct/ " | 125 "//target/ //target/config/ //target/all/ //target/direct/ " |
| 124 "//dep1/all/ //dep2/all/ //dep1/direct/ "); | 126 "//dep1/all/ //dep2/all/ //dep1/direct/ "); |
| 125 } | 127 } |
| OLD | NEW |