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.

Sleep.java 5.9 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. /*
  2. * The Apache Software License, Version 1.1
  3. *
  4. * Copyright (c) 2001-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 org.apache.tools.ant.Project;
  56. import org.apache.tools.ant.Task;
  57. import org.apache.tools.ant.BuildException;
  58. /**
  59. * A task to sleep for a period of time
  60. *
  61. * @author steve_l@iseran.com steve loughran
  62. *
  63. * @ant:task category="utility"
  64. */
  65. public class Sleep extends Task {
  66. /**
  67. * failure flag
  68. */
  69. private boolean failOnError = true;
  70. /**
  71. * Description of the Field
  72. */
  73. private int seconds = 0;
  74. /**
  75. * Description of the Field
  76. */
  77. private int hours = 0;
  78. /**
  79. * Description of the Field
  80. */
  81. private int minutes = 0;
  82. /**
  83. * Description of the Field
  84. */
  85. private int milliseconds = 0;
  86. /**
  87. * Creates new instance
  88. */
  89. public Sleep() {
  90. }
  91. /**
  92. * Sets the Seconds attribute of the Sleep object
  93. *
  94. * @param seconds The new Seconds value
  95. */
  96. public void setSeconds(int seconds) {
  97. this.seconds = seconds;
  98. }
  99. /**
  100. * Sets the Hours attribute of the Sleep object
  101. *
  102. * @param hours The new Hours value
  103. */
  104. public void setHours(int hours) {
  105. this.hours = hours;
  106. }
  107. /**
  108. * Sets the Minutes attribute of the Sleep object
  109. *
  110. * @param minutes The new Minutes value
  111. */
  112. public void setMinutes(int minutes) {
  113. this.minutes = minutes;
  114. }
  115. /**
  116. * Sets the Milliseconds attribute of the Sleep object
  117. *
  118. * @param milliseconds The new Milliseconds value
  119. */
  120. public void setMilliseconds(int milliseconds) {
  121. this.milliseconds = milliseconds;
  122. }
  123. /**
  124. * sleep for a period of time
  125. *
  126. * @param millis time to sleep
  127. */
  128. public void doSleep(long millis) {
  129. try {
  130. Thread.sleep(millis);
  131. }
  132. catch (InterruptedException ie) {
  133. }
  134. }
  135. /**
  136. * Sets the FailOnError attribute of the MimeMail object
  137. *
  138. * @param failOnError The new FailOnError value
  139. */
  140. public void setFailOnError(boolean failOnError) {
  141. this.failOnError = failOnError;
  142. }
  143. /**
  144. * return time to sleep
  145. *
  146. * @return sleep time. if below 0 then there is an error
  147. */
  148. private long getSleepTime() {
  149. return ((((long) hours * 60) + minutes) * 60 + seconds) * 1000 + milliseconds;
  150. }
  151. /**
  152. * verify parameters
  153. *
  154. * @throws BuildException if something is invalid
  155. */
  156. public void validate()
  157. throws BuildException {
  158. if (getSleepTime() < 0) {
  159. throw new BuildException("Negative sleep periods are not supported");
  160. }
  161. }
  162. /**
  163. * Executes this build task. Throws org.apache.tools.ant.BuildException
  164. * if there is an error during task execution.
  165. *
  166. * @exception BuildException Description of Exception
  167. */
  168. public void execute()
  169. throws BuildException {
  170. try {
  171. validate();
  172. long sleepTime=getSleepTime();
  173. log("sleeping for "+sleepTime+" milliseconds",
  174. Project.MSG_VERBOSE);
  175. doSleep(sleepTime);
  176. }
  177. catch (Exception e) {
  178. if (failOnError) {
  179. throw new BuildException(e);
  180. }
  181. else {
  182. String text = e.toString();
  183. log(text, Project.MSG_ERR);
  184. }
  185. }
  186. }
  187. }