/subprojects/plugins/src/main/groovy/org/gradle/api/internal/tasks/compile/CommandLineJavaCompilerArgumentsGenerator.java

https://github.com/xinthink/gradle · Java · 84 lines · 55 code · 9 blank · 20 comment · 5 complexity · 0637a1c0cfdc685d0f1b6bd1bead7925 MD5 · raw file

  1. /*
  2. * Copyright 2012 the original author or authors.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package org.gradle.api.internal.tasks.compile;
  17. import com.google.common.collect.Iterables;
  18. import org.gradle.api.UncheckedIOException;
  19. import org.gradle.api.internal.file.TemporaryFileProvider;
  20. import java.io.File;
  21. import java.io.FileWriter;
  22. import java.io.IOException;
  23. import java.io.PrintWriter;
  24. import java.util.Collections;
  25. import java.util.List;
  26. public class CommandLineJavaCompilerArgumentsGenerator implements CompileSpecToArguments<JavaCompileSpec> {
  27. private final TemporaryFileProvider tempFileProvider;
  28. public CommandLineJavaCompilerArgumentsGenerator(TemporaryFileProvider tempFileProvider) {
  29. this.tempFileProvider = tempFileProvider;
  30. }
  31. public void collectArguments(JavaCompileSpec spec, ArgCollector collector) {
  32. for (String arg : generate(spec)) {
  33. collector.args(arg);
  34. }
  35. }
  36. public Iterable<String> generate(JavaCompileSpec spec) {
  37. List<String> launcherOptions = new JavaCompilerArgumentsBuilder(spec).includeLauncherOptions(true).includeMainOptions(false).includeClasspath(false).build();
  38. List<String> remainingArgs = new JavaCompilerArgumentsBuilder(spec).includeSourceFiles(true).build();
  39. Iterable<String> allArgs = Iterables.concat(launcherOptions, remainingArgs);
  40. if (exceedsWindowsCommandLineLengthLimit(allArgs)) {
  41. return Iterables.concat(launcherOptions, shortenArgs(remainingArgs));
  42. }
  43. return allArgs;
  44. }
  45. private boolean exceedsWindowsCommandLineLengthLimit(Iterable<String> args) {
  46. int length = 0;
  47. for (String arg : args) {
  48. length += arg.length() + 1;
  49. // limit is 2047 on older Windows systems, and 8191 on newer ones
  50. // http://support.microsoft.com/kb/830473
  51. // let's play it safe, no need to optimize
  52. if (length > 1500) { return true; }
  53. }
  54. return false;
  55. }
  56. private Iterable<String> shortenArgs(List<String> args) {
  57. File file = tempFileProvider.createTemporaryFile("compile-args", null, "java-compiler");
  58. // for command file format, see http://docs.oracle.com/javase/6/docs/technotes/tools/windows/javac.html#commandlineargfile
  59. // use platform character and line encoding
  60. try {
  61. PrintWriter writer = new PrintWriter(new FileWriter(file));
  62. try {
  63. ArgWriter argWriter = ArgWriter.unixStyle(writer);
  64. for (String arg : args) {
  65. argWriter.args(arg);
  66. }
  67. } finally {
  68. writer.close();
  69. }
  70. } catch (IOException e) {
  71. throw new UncheckedIOException(e);
  72. }
  73. return Collections.singleton("@" + file.getPath());
  74. }
  75. }