| 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 #include <algorithm> | 5 #include <algorithm> |
| 6 #include <sstream> | 6 #include <sstream> |
| 7 | 7 |
| 8 #include "testing/gtest/include/gtest/gtest.h" | 8 #include "testing/gtest/include/gtest/gtest.h" |
| 9 #include "tools/gn/file_template.h" | 9 #include "tools/gn/file_template.h" |
| 10 #include "tools/gn/ninja_action_target_writer.h" | 10 #include "tools/gn/ninja_action_target_writer.h" |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 | 22 |
| 23 std::ostringstream out; | 23 std::ostringstream out; |
| 24 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 24 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 25 | 25 |
| 26 FileTemplate output_template = writer.GetOutputTemplate(); | 26 FileTemplate output_template = writer.GetOutputTemplate(); |
| 27 | 27 |
| 28 SourceFile source("//foo/bar.in"); | 28 SourceFile source("//foo/bar.in"); |
| 29 std::vector<OutputFile> output_files; | 29 std::vector<OutputFile> output_files; |
| 30 writer.WriteOutputFilesForBuildLine(output_template, source, &output_files); | 30 writer.WriteOutputFilesForBuildLine(output_template, source, &output_files); |
| 31 | 31 |
| 32 std::string out_str = out.str(); | 32 EXPECT_EQ(" gen/a$ bbar.h gen/bar.cc", out.str()); |
| 33 #if defined(OS_WIN) | |
| 34 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 35 #endif | |
| 36 EXPECT_EQ(" gen/a$ bbar.h gen/bar.cc", out_str); | |
| 37 } | 33 } |
| 38 | 34 |
| 39 TEST(NinjaActionTargetWriter, WriteOutputFilesForBuildLineWithDepfile) { | 35 TEST(NinjaActionTargetWriter, WriteOutputFilesForBuildLineWithDepfile) { |
| 40 TestWithScope setup; | 36 TestWithScope setup; |
| 41 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); | 37 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); |
| 42 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); | 38 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); |
| 43 | 39 |
| 44 target.action_values().set_depfile( | 40 target.action_values().set_depfile( |
| 45 SourceFile("//out/Debug/gen/{{source_name_part}}.d")); | 41 SourceFile("//out/Debug/gen/{{source_name_part}}.d")); |
| 46 target.action_values().outputs().push_back( | 42 target.action_values().outputs().push_back( |
| 47 SourceFile("//out/Debug/gen/{{source_name_part}}.h")); | 43 SourceFile("//out/Debug/gen/{{source_name_part}}.h")); |
| 48 target.action_values().outputs().push_back( | 44 target.action_values().outputs().push_back( |
| 49 SourceFile("//out/Debug/gen/{{source_name_part}}.cc")); | 45 SourceFile("//out/Debug/gen/{{source_name_part}}.cc")); |
| 50 | 46 |
| 51 std::ostringstream out; | 47 std::ostringstream out; |
| 52 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 48 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 53 | 49 |
| 54 FileTemplate output_template = writer.GetOutputTemplate(); | 50 FileTemplate output_template = writer.GetOutputTemplate(); |
| 55 | 51 |
| 56 SourceFile source("//foo/bar.in"); | 52 SourceFile source("//foo/bar.in"); |
| 57 std::vector<OutputFile> output_files; | 53 std::vector<OutputFile> output_files; |
| 58 writer.WriteOutputFilesForBuildLine(output_template, source, &output_files); | 54 writer.WriteOutputFilesForBuildLine(output_template, source, &output_files); |
| 59 | 55 |
| 60 std::string out_str = out.str(); | 56 EXPECT_EQ(" gen/bar.d gen/bar.h gen/bar.cc", out.str()); |
| 61 #if defined(OS_WIN) | |
| 62 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 63 #endif | |
| 64 EXPECT_EQ(" gen/bar.d gen/bar.h gen/bar.cc", out_str); | |
| 65 } | 57 } |
| 66 | 58 |
| 67 TEST(NinjaActionTargetWriter, WriteArgsSubstitutions) { | 59 TEST(NinjaActionTargetWriter, WriteArgsSubstitutions) { |
| 68 TestWithScope setup; | 60 TestWithScope setup; |
| 69 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); | 61 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); |
| 70 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); | 62 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); |
| 71 | 63 |
| 72 std::ostringstream out; | 64 std::ostringstream out; |
| 73 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 65 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 74 | 66 |
| 75 std::vector<std::string> args; | 67 std::vector<std::string> args; |
| 76 args.push_back("-i"); | 68 args.push_back("-i"); |
| 77 args.push_back("{{source}}"); | 69 args.push_back("{{source}}"); |
| 78 args.push_back("--out=foo bar{{source_name_part}}.o"); | 70 args.push_back("--out=foo bar{{source_name_part}}.o"); |
| 79 FileTemplate args_template(args); | 71 FileTemplate args_template(args); |
| 80 | 72 |
| 81 writer.WriteArgsSubstitutions(SourceFile("//foo/b ar.in"), args_template); | 73 writer.WriteArgsSubstitutions(SourceFile("//foo/b ar.in"), args_template); |
| 82 | |
| 83 std::string out_str = out.str(); | |
| 84 #if defined(OS_WIN) | 74 #if defined(OS_WIN) |
| 85 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | 75 EXPECT_EQ(" source = \"../../foo/b$ ar.in\"\n" |
| 76 " source_name_part = \"b$ ar\"\n", |
| 77 out.str()); |
| 78 #else |
| 79 EXPECT_EQ(" source = ../../foo/b\\$ ar.in\n" |
| 80 " source_name_part = b\\$ ar\n", |
| 81 out.str()); |
| 86 #endif | 82 #endif |
| 87 EXPECT_EQ(" source = ../../foo/b$ ar.in\n source_name_part = b$ ar\n", | |
| 88 out_str); | |
| 89 } | 83 } |
| 90 | 84 |
| 91 // Makes sure that we write sources as input dependencies for actions with | 85 // Makes sure that we write sources as input dependencies for actions with |
| 92 // both sources and source_prereqs (ACTION_FOREACH treats the sources | 86 // both sources and source_prereqs (ACTION_FOREACH treats the sources |
| 93 // differently). | 87 // differently). |
| 94 TEST(NinjaActionTargetWriter, ActionWithSources) { | 88 TEST(NinjaActionTargetWriter, ActionWithSources) { |
| 95 TestWithScope setup; | 89 TestWithScope setup; |
| 96 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); | 90 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); |
| 97 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); | 91 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); |
| 98 target.set_output_type(Target::ACTION); | 92 target.set_output_type(Target::ACTION); |
| (...skipping 20 matching lines...) Expand all Loading... |
| 119 "rule __foo_bar___rule\n" | 113 "rule __foo_bar___rule\n" |
| 120 " command = /usr/bin/python ../../foo/script.py\n" | 114 " command = /usr/bin/python ../../foo/script.py\n" |
| 121 " description = ACTION //foo:bar()\n" | 115 " description = ACTION //foo:bar()\n" |
| 122 " restat = 1\n" | 116 " restat = 1\n" |
| 123 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " | 117 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " |
| 124 "../../foo/included.txt ../../foo/source.txt\n" | 118 "../../foo/included.txt ../../foo/source.txt\n" |
| 125 "\n" | 119 "\n" |
| 126 "build foo.out: __foo_bar___rule | obj/foo/bar.inputdeps.stamp\n" | 120 "build foo.out: __foo_bar___rule | obj/foo/bar.inputdeps.stamp\n" |
| 127 "\n" | 121 "\n" |
| 128 "build obj/foo/bar.stamp: stamp foo.out\n"; | 122 "build obj/foo/bar.stamp: stamp foo.out\n"; |
| 129 std::string out_str = out.str(); | 123 EXPECT_EQ(expected_linux, out.str()); |
| 130 #if defined(OS_WIN) | |
| 131 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 132 #endif | |
| 133 EXPECT_EQ(expected_linux, out_str); | |
| 134 } | 124 } |
| 135 | 125 |
| 136 // Windows. | 126 // Windows. |
| 137 { | 127 { |
| 138 // Note: we use forward slashes here so that the output will be the same on | 128 // Note: we use forward slashes here so that the output will be the same on |
| 139 // Linux and Windows. | 129 // Linux and Windows. |
| 140 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( | 130 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( |
| 141 "C:/python/python.exe"))); | 131 "C:/python/python.exe"))); |
| 142 setup.settings()->set_target_os(Settings::WIN); | 132 setup.settings()->set_target_os(Settings::WIN); |
| 143 | 133 |
| 144 std::ostringstream out; | 134 std::ostringstream out; |
| 145 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 135 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 146 writer.Run(); | 136 writer.Run(); |
| 147 | 137 |
| 148 // TODO(brettw) I think we'll need to worry about backslashes here | |
| 149 // depending if we're on actual Windows or Linux pretending to be Windows. | |
| 150 const char expected_win[] = | 138 const char expected_win[] = |
| 151 "rule __foo_bar___rule\n" | 139 "rule __foo_bar___rule\n" |
| 152 " command = C$:/python/python.exe gyp-win-tool action-wrapper environme
nt.x86 __foo_bar___rule.$unique_name.rsp\n" | 140 " command = C$:/python/python.exe gyp-win-tool action-wrapper environme
nt.x86 __foo_bar___rule.$unique_name.rsp\n" |
| 153 " description = ACTION //foo:bar()\n" | 141 " description = ACTION //foo:bar()\n" |
| 154 " restat = 1\n" | 142 " restat = 1\n" |
| 155 " rspfile = __foo_bar___rule.$unique_name.rsp\n" | 143 " rspfile = __foo_bar___rule.$unique_name.rsp\n" |
| 156 " rspfile_content = C$:/python/python.exe ../../foo/script.py\n" | 144 " rspfile_content = C$:/python/python.exe ../../foo/script.py\n" |
| 157 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " | 145 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " |
| 158 "../../foo/included.txt ../../foo/source.txt\n" | 146 "../../foo/included.txt ../../foo/source.txt\n" |
| 159 "\n" | 147 "\n" |
| 160 "build foo.out: __foo_bar___rule | obj/foo/bar.inputdeps.stamp\n" | 148 "build foo.out: __foo_bar___rule | obj/foo/bar.inputdeps.stamp\n" |
| 161 "\n" | 149 "\n" |
| 162 "build obj/foo/bar.stamp: stamp foo.out\n"; | 150 "build obj/foo/bar.stamp: stamp foo.out\n"; |
| 163 std::string out_str = out.str(); | 151 EXPECT_EQ(expected_win, out.str()); |
| 164 #if defined(OS_WIN) | |
| 165 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 166 #endif | |
| 167 EXPECT_EQ(expected_win, out_str); | |
| 168 } | 152 } |
| 169 } | 153 } |
| 170 | 154 |
| 171 TEST(NinjaActionTargetWriter, ForEach) { | 155 TEST(NinjaActionTargetWriter, ForEach) { |
| 172 TestWithScope setup; | 156 TestWithScope setup; |
| 173 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); | 157 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); |
| 174 | 158 |
| 175 // Some dependencies that the action can depend on. Use actions for these | 159 // Some dependencies that the action can depend on. Use actions for these |
| 176 // so they have a nice platform-independent stamp file that can appear in the | 160 // so they have a nice platform-independent stamp file that can appear in the |
| 177 // output (rather than having to worry about how the current platform names | 161 // output (rather than having to worry about how the current platform names |
| (...skipping 29 matching lines...) Expand all Loading... |
| 207 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( | 191 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( |
| 208 "/usr/bin/python"))); | 192 "/usr/bin/python"))); |
| 209 | 193 |
| 210 std::ostringstream out; | 194 std::ostringstream out; |
| 211 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 195 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 212 writer.Run(); | 196 writer.Run(); |
| 213 | 197 |
| 214 const char expected_linux[] = | 198 const char expected_linux[] = |
| 215 "rule __foo_bar___rule\n" | 199 "rule __foo_bar___rule\n" |
| 216 " command = /usr/bin/python ../../foo/script.py -i ${source} " | 200 " command = /usr/bin/python ../../foo/script.py -i ${source} " |
| 201 // Escaping is different between Windows and Posix. |
| 202 #if defined(OS_WIN) |
| 217 "\"--out=foo$ bar${source_name_part}.o\"\n" | 203 "\"--out=foo$ bar${source_name_part}.o\"\n" |
| 204 #else |
| 205 "--out=foo\\$ bar${source_name_part}.o\n" |
| 206 #endif |
| 218 " description = ACTION //foo:bar()\n" | 207 " description = ACTION //foo:bar()\n" |
| 219 " restat = 1\n" | 208 " restat = 1\n" |
| 220 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " | 209 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " |
| 221 "../../foo/included.txt obj/foo/dep.stamp\n" | 210 "../../foo/included.txt obj/foo/dep.stamp\n" |
| 222 "\n" | 211 "\n" |
| 223 "build input1.out: __foo_bar___rule ../../foo/input1.txt | " | 212 "build input1.out: __foo_bar___rule ../../foo/input1.txt | " |
| 224 "obj/foo/bar.inputdeps.stamp\n" | 213 "obj/foo/bar.inputdeps.stamp\n" |
| 225 " source = ../../foo/input1.txt\n" | 214 " source = ../../foo/input1.txt\n" |
| 226 " source_name_part = input1\n" | 215 " source_name_part = input1\n" |
| 227 "build input2.out: __foo_bar___rule ../../foo/input2.txt | " | 216 "build input2.out: __foo_bar___rule ../../foo/input2.txt | " |
| 228 "obj/foo/bar.inputdeps.stamp\n" | 217 "obj/foo/bar.inputdeps.stamp\n" |
| 229 " source = ../../foo/input2.txt\n" | 218 " source = ../../foo/input2.txt\n" |
| 230 " source_name_part = input2\n" | 219 " source_name_part = input2\n" |
| 231 "\n" | 220 "\n" |
| 232 "build obj/foo/bar.stamp: " | 221 "build obj/foo/bar.stamp: " |
| 233 "stamp input1.out input2.out obj/foo/datadep.stamp\n"; | 222 "stamp input1.out input2.out obj/foo/datadep.stamp\n"; |
| 234 | 223 |
| 235 std::string out_str = out.str(); | 224 std::string out_str = out.str(); |
| 236 #if defined(OS_WIN) | 225 #if defined(OS_WIN) |
| 237 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | 226 std::replace(out_str.begin(), out_str.end(), '\\', '/'); |
| 238 #endif | 227 #endif |
| 239 EXPECT_EQ(expected_linux, out_str); | 228 EXPECT_EQ(expected_linux, out_str); |
| 240 } | 229 } |
| 241 | 230 |
| 242 // Windows. | 231 // Windows. |
| 243 { | 232 { |
| 244 // Note: we use forward slashes here so that the output will be the same on | |
| 245 // Linux and Windows. | |
| 246 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( | 233 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( |
| 247 "C:/python/python.exe"))); | 234 "C:/python/python.exe"))); |
| 248 setup.settings()->set_target_os(Settings::WIN); | 235 setup.settings()->set_target_os(Settings::WIN); |
| 249 | 236 |
| 250 std::ostringstream out; | 237 std::ostringstream out; |
| 251 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 238 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 252 writer.Run(); | 239 writer.Run(); |
| 253 | 240 |
| 254 // TODO(brettw) I think we'll need to worry about backslashes here | |
| 255 // depending if we're on actual Windows or Linux pretending to be Windows. | |
| 256 const char expected_win[] = | 241 const char expected_win[] = |
| 257 "rule __foo_bar___rule\n" | 242 "rule __foo_bar___rule\n" |
| 258 " command = C$:/python/python.exe gyp-win-tool action-wrapper " | 243 " command = C$:/python/python.exe gyp-win-tool action-wrapper " |
| 259 "environment.x86 __foo_bar___rule.$unique_name.rsp\n" | 244 "environment.x86 __foo_bar___rule.$unique_name.rsp\n" |
| 260 " description = ACTION //foo:bar()\n" | 245 " description = ACTION //foo:bar()\n" |
| 261 " restat = 1\n" | 246 " restat = 1\n" |
| 262 " rspfile = __foo_bar___rule.$unique_name.rsp\n" | 247 " rspfile = __foo_bar___rule.$unique_name.rsp\n" |
| 263 " rspfile_content = C$:/python/python.exe ../../foo/script.py -i " | 248 " rspfile_content = C$:/python/python.exe ../../foo/script.py -i " |
| 249 #if defined(OS_WIN) |
| 264 "${source} \"--out=foo$ bar${source_name_part}.o\"\n" | 250 "${source} \"--out=foo$ bar${source_name_part}.o\"\n" |
| 251 #else |
| 252 "${source} --out=foo\\$ bar${source_name_part}.o\n" |
| 253 #endif |
| 265 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " | 254 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " |
| 266 "../../foo/included.txt obj/foo/dep.stamp\n" | 255 "../../foo/included.txt obj/foo/dep.stamp\n" |
| 267 "\n" | 256 "\n" |
| 268 "build input1.out: __foo_bar___rule ../../foo/input1.txt | " | 257 "build input1.out: __foo_bar___rule ../../foo/input1.txt | " |
| 269 "obj/foo/bar.inputdeps.stamp\n" | 258 "obj/foo/bar.inputdeps.stamp\n" |
| 270 " unique_name = 0\n" | 259 " unique_name = 0\n" |
| 271 " source = ../../foo/input1.txt\n" | 260 " source = ../../foo/input1.txt\n" |
| 272 " source_name_part = input1\n" | 261 " source_name_part = input1\n" |
| 273 "build input2.out: __foo_bar___rule ../../foo/input2.txt | " | 262 "build input2.out: __foo_bar___rule ../../foo/input2.txt | " |
| 274 "obj/foo/bar.inputdeps.stamp\n" | 263 "obj/foo/bar.inputdeps.stamp\n" |
| 275 " unique_name = 1\n" | 264 " unique_name = 1\n" |
| 276 " source = ../../foo/input2.txt\n" | 265 " source = ../../foo/input2.txt\n" |
| 277 " source_name_part = input2\n" | 266 " source_name_part = input2\n" |
| 278 "\n" | 267 "\n" |
| 279 "build obj/foo/bar.stamp: " | 268 "build obj/foo/bar.stamp: " |
| 280 "stamp input1.out input2.out obj/foo/datadep.stamp\n"; | 269 "stamp input1.out input2.out obj/foo/datadep.stamp\n"; |
| 281 std::string out_str = out.str(); | 270 EXPECT_EQ(expected_win, out.str()); |
| 282 #if defined(OS_WIN) | |
| 283 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 284 #endif | |
| 285 EXPECT_EQ(expected_win, out_str); | |
| 286 } | 271 } |
| 287 } | 272 } |
| 288 | 273 |
| 289 TEST(NinjaActionTargetWriter, ForEachWithDepfile) { | 274 TEST(NinjaActionTargetWriter, ForEachWithDepfile) { |
| 290 TestWithScope setup; | 275 TestWithScope setup; |
| 291 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); | 276 setup.build_settings()->SetBuildDir(SourceDir("//out/Debug/")); |
| 292 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); | 277 Target target(setup.settings(), Label(SourceDir("//foo/"), "bar")); |
| 293 target.set_output_type(Target::ACTION_FOREACH); | 278 target.set_output_type(Target::ACTION_FOREACH); |
| 294 | 279 |
| 295 target.sources().push_back(SourceFile("//foo/input1.txt")); | 280 target.sources().push_back(SourceFile("//foo/input1.txt")); |
| (...skipping 19 matching lines...) Expand all Loading... |
| 315 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( | 300 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( |
| 316 "/usr/bin/python"))); | 301 "/usr/bin/python"))); |
| 317 | 302 |
| 318 std::ostringstream out; | 303 std::ostringstream out; |
| 319 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 304 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 320 writer.Run(); | 305 writer.Run(); |
| 321 | 306 |
| 322 const char expected_linux[] = | 307 const char expected_linux[] = |
| 323 "rule __foo_bar___rule\n" | 308 "rule __foo_bar___rule\n" |
| 324 " command = /usr/bin/python ../../foo/script.py -i ${source} " | 309 " command = /usr/bin/python ../../foo/script.py -i ${source} " |
| 310 #if defined(OS_WIN) |
| 325 "\"--out=foo$ bar${source_name_part}.o\"\n" | 311 "\"--out=foo$ bar${source_name_part}.o\"\n" |
| 312 #else |
| 313 "--out=foo\\$ bar${source_name_part}.o\n" |
| 314 #endif |
| 326 " description = ACTION //foo:bar()\n" | 315 " description = ACTION //foo:bar()\n" |
| 327 " restat = 1\n" | 316 " restat = 1\n" |
| 328 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " | 317 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " |
| 329 "../../foo/included.txt\n" | 318 "../../foo/included.txt\n" |
| 330 "\n" | 319 "\n" |
| 331 "build gen/input1.d input1.out: __foo_bar___rule ../../foo/input1.txt" | 320 "build gen/input1.d input1.out: __foo_bar___rule ../../foo/input1.txt" |
| 332 " | obj/foo/bar.inputdeps.stamp\n" | 321 " | obj/foo/bar.inputdeps.stamp\n" |
| 333 " source = ../../foo/input1.txt\n" | 322 " source = ../../foo/input1.txt\n" |
| 334 " source_name_part = input1\n" | 323 " source_name_part = input1\n" |
| 335 " depfile = gen/input1.d\n" | 324 " depfile = gen/input1.d\n" |
| 336 "build gen/input2.d input2.out: __foo_bar___rule ../../foo/input2.txt" | 325 "build gen/input2.d input2.out: __foo_bar___rule ../../foo/input2.txt" |
| 337 " | obj/foo/bar.inputdeps.stamp\n" | 326 " | obj/foo/bar.inputdeps.stamp\n" |
| 338 " source = ../../foo/input2.txt\n" | 327 " source = ../../foo/input2.txt\n" |
| 339 " source_name_part = input2\n" | 328 " source_name_part = input2\n" |
| 340 " depfile = gen/input2.d\n" | 329 " depfile = gen/input2.d\n" |
| 341 "\n" | 330 "\n" |
| 342 "build obj/foo/bar.stamp: stamp input1.out input2.out\n"; | 331 "build obj/foo/bar.stamp: stamp input1.out input2.out\n"; |
| 343 | 332 EXPECT_EQ(expected_linux, out.str()); |
| 344 std::string out_str = out.str(); | |
| 345 #if defined(OS_WIN) | |
| 346 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 347 #endif | |
| 348 EXPECT_EQ(expected_linux, out_str); | |
| 349 } | 333 } |
| 350 | 334 |
| 351 // Windows. | 335 // Windows. |
| 352 { | 336 { |
| 353 // Note: we use forward slashes here so that the output will be the same on | |
| 354 // Linux and Windows. | |
| 355 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( | 337 setup.build_settings()->set_python_path(base::FilePath(FILE_PATH_LITERAL( |
| 356 "C:/python/python.exe"))); | 338 "C:/python/python.exe"))); |
| 357 setup.settings()->set_target_os(Settings::WIN); | 339 setup.settings()->set_target_os(Settings::WIN); |
| 358 | 340 |
| 359 std::ostringstream out; | 341 std::ostringstream out; |
| 360 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); | 342 NinjaActionTargetWriter writer(&target, setup.toolchain(), out); |
| 361 writer.Run(); | 343 writer.Run(); |
| 362 | 344 |
| 363 // TODO(brettw) I think we'll need to worry about backslashes here | |
| 364 // depending if we're on actual Windows or Linux pretending to be Windows. | |
| 365 const char expected_win[] = | 345 const char expected_win[] = |
| 366 "rule __foo_bar___rule\n" | 346 "rule __foo_bar___rule\n" |
| 367 " command = C$:/python/python.exe gyp-win-tool action-wrapper " | 347 " command = C$:/python/python.exe gyp-win-tool action-wrapper " |
| 368 "environment.x86 __foo_bar___rule.$unique_name.rsp\n" | 348 "environment.x86 __foo_bar___rule.$unique_name.rsp\n" |
| 369 " description = ACTION //foo:bar()\n" | 349 " description = ACTION //foo:bar()\n" |
| 370 " restat = 1\n" | 350 " restat = 1\n" |
| 371 " rspfile = __foo_bar___rule.$unique_name.rsp\n" | 351 " rspfile = __foo_bar___rule.$unique_name.rsp\n" |
| 372 " rspfile_content = C$:/python/python.exe ../../foo/script.py -i " | 352 " rspfile_content = C$:/python/python.exe ../../foo/script.py -i " |
| 353 #if defined(OS_WIN) |
| 373 "${source} \"--out=foo$ bar${source_name_part}.o\"\n" | 354 "${source} \"--out=foo$ bar${source_name_part}.o\"\n" |
| 355 #else |
| 356 "${source} --out=foo\\$ bar${source_name_part}.o\n" |
| 357 #endif |
| 374 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " | 358 "build obj/foo/bar.inputdeps.stamp: stamp ../../foo/script.py " |
| 375 "../../foo/included.txt\n" | 359 "../../foo/included.txt\n" |
| 376 "\n" | 360 "\n" |
| 377 "build gen/input1.d input1.out: __foo_bar___rule ../../foo/input1.txt" | 361 "build gen/input1.d input1.out: __foo_bar___rule ../../foo/input1.txt" |
| 378 " | obj/foo/bar.inputdeps.stamp\n" | 362 " | obj/foo/bar.inputdeps.stamp\n" |
| 379 " unique_name = 0\n" | 363 " unique_name = 0\n" |
| 380 " source = ../../foo/input1.txt\n" | 364 " source = ../../foo/input1.txt\n" |
| 381 " source_name_part = input1\n" | 365 " source_name_part = input1\n" |
| 382 " depfile = gen/input1.d\n" | 366 " depfile = gen/input1.d\n" |
| 383 "build gen/input2.d input2.out: __foo_bar___rule ../../foo/input2.txt" | 367 "build gen/input2.d input2.out: __foo_bar___rule ../../foo/input2.txt" |
| 384 " | obj/foo/bar.inputdeps.stamp\n" | 368 " | obj/foo/bar.inputdeps.stamp\n" |
| 385 " unique_name = 1\n" | 369 " unique_name = 1\n" |
| 386 " source = ../../foo/input2.txt\n" | 370 " source = ../../foo/input2.txt\n" |
| 387 " source_name_part = input2\n" | 371 " source_name_part = input2\n" |
| 388 " depfile = gen/input2.d\n" | 372 " depfile = gen/input2.d\n" |
| 389 "\n" | 373 "\n" |
| 390 "build obj/foo/bar.stamp: stamp input1.out input2.out\n"; | 374 "build obj/foo/bar.stamp: stamp input1.out input2.out\n"; |
| 391 std::string out_str = out.str(); | 375 EXPECT_EQ(expected_win, out.str()); |
| 392 #if defined(OS_WIN) | |
| 393 std::replace(out_str.begin(), out_str.end(), '\\', '/'); | |
| 394 #endif | |
| 395 EXPECT_EQ(expected_win, out_str); | |
| 396 } | 376 } |
| 397 } | 377 } |
| OLD | NEW |