You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

Jikes.java 6.4 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. /*
  2. * The Apache Software License, Version 1.1
  3. *
  4. * Copyright (c) 2000,2002 The Apache Software Foundation. All rights
  5. * reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. *
  11. * 1. Redistributions of source code must retain the above copyright
  12. * notice, this list of conditions and the following disclaimer.
  13. *
  14. * 2. Redistributions in binary form must reproduce the above copyright
  15. * notice, this list of conditions and the following disclaimer in
  16. * the documentation and/or other materials provided with the
  17. * distribution.
  18. *
  19. * 3. The end-user documentation included with the redistribution, if
  20. * any, must include the following acknowlegement:
  21. * "This product includes software developed by the
  22. * Apache Software Foundation (http://www.apache.org/)."
  23. * Alternately, this acknowlegement may appear in the software itself,
  24. * if and wherever such third-party acknowlegements normally appear.
  25. *
  26. * 4. The names "The Jakarta Project", "Ant", and "Apache Software
  27. * Foundation" must not be used to endorse or promote products derived
  28. * from this software without prior written permission. For written
  29. * permission, please contact apache@apache.org.
  30. *
  31. * 5. Products derived from this software may not be called "Apache"
  32. * nor may "Apache" appear in their names without prior written
  33. * permission of the Apache Group.
  34. *
  35. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  36. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  37. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38. * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  39. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  41. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  42. * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  43. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  44. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  45. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  46. * SUCH DAMAGE.
  47. * ====================================================================
  48. *
  49. * This software consists of voluntary contributions made by many
  50. * individuals on behalf of the Apache Software Foundation. For more
  51. * information on the Apache Software Foundation, please see
  52. * <http://www.apache.org/>.
  53. */
  54. package org.apache.tools.ant.taskdefs;
  55. import java.io.File;
  56. import java.io.FileWriter;
  57. import java.io.IOException;
  58. import java.io.PrintWriter;
  59. import java.util.Random;
  60. import org.apache.tools.ant.BuildException;
  61. import org.apache.tools.ant.Project;
  62. /**
  63. * Encapsulates a Jikes compiler, by directly executing an external
  64. * process.
  65. *
  66. * <p><strong>As of Ant 1.2, this class is considered to be dead code
  67. * by the Ant developers and is unmaintained. Don't use
  68. * it.</strong></p>
  69. *
  70. * @author skanthak@muehlheim.de
  71. * @deprecated merged into the class Javac.
  72. */
  73. public class Jikes {
  74. protected JikesOutputParser jop;
  75. protected String command;
  76. protected Project project;
  77. /**
  78. * Constructs a new Jikes obect.
  79. * @param jop - Parser to send jike's output to
  80. * @param command - name of jikes executeable
  81. */
  82. protected Jikes(JikesOutputParser jop, String command, Project project) {
  83. super();
  84. System.err.println("As of Ant 1.2 released in October 2000, "
  85. + "the Jikes class");
  86. System.err.println("is considered to be dead code by the Ant "
  87. + "developers and is unmaintained.");
  88. System.err.println("Don\'t use it!");
  89. this.jop = jop;
  90. this.command = command;
  91. this.project = project;
  92. }
  93. /**
  94. * Do the compile with the specified arguments.
  95. * @param args - arguments to pass to process on command line
  96. */
  97. protected void compile(String[] args) {
  98. String[] commandArray = null;
  99. File tmpFile = null;
  100. try {
  101. String myos = System.getProperty("os.name");
  102. // Windows has a 32k limit on total arg size, so
  103. // create a temporary file to store all the arguments
  104. // There have been reports that 300 files could be compiled
  105. // so 250 is a conservative approach
  106. if (myos.toLowerCase().indexOf("windows") >= 0
  107. && args.length > 250) {
  108. PrintWriter out = null;
  109. try {
  110. tmpFile = new File("jikes" + (new Random(System.currentTimeMillis())).nextLong());
  111. out = new PrintWriter(new FileWriter(tmpFile));
  112. for (int i = 0; i < args.length; i++) {
  113. out.println(args[i]);
  114. }
  115. out.flush();
  116. commandArray = new String[] { command,
  117. "@" + tmpFile.getAbsolutePath()};
  118. } catch (IOException e) {
  119. throw new BuildException("Error creating temporary file",
  120. e);
  121. } finally {
  122. if (out != null) {
  123. try {out.close();} catch (Throwable t) {}
  124. }
  125. }
  126. } else {
  127. commandArray = new String[args.length + 1];
  128. commandArray[0] = command;
  129. System.arraycopy(args, 0, commandArray, 1, args.length);
  130. }
  131. // We assume, that everything jikes writes goes to
  132. // standard output, not to standard error. The option
  133. // -Xstdout that is given to Jikes in Javac.doJikesCompile()
  134. // should guarantee this. At least I hope so. :)
  135. try {
  136. Execute exe = new Execute(jop);
  137. exe.setAntRun(project);
  138. exe.setWorkingDirectory(project.getBaseDir());
  139. exe.setCommandline(commandArray);
  140. exe.execute();
  141. } catch (IOException e) {
  142. throw new BuildException("Error running Jikes compiler", e);
  143. }
  144. } finally {
  145. if (tmpFile != null) {
  146. tmpFile.delete();
  147. }
  148. }
  149. }
  150. }