1. /*
  2. * Copyright 2001-2004 The Apache Software Foundation
  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. */
  17. package org.apache.tools.ant.taskdefs.compilers;
  18. import org.apache.tools.ant.BuildException;
  19. import org.apache.tools.ant.taskdefs.Javac;
  20. /**
  21. * The interface that all compiler adapters must adhere to.
  22. *
  23. * <p>A compiler adapter is an adapter that interprets the javac's
  24. * parameters in preparation to be passed off to the compiler this
  25. * adapter represents. As all the necessary values are stored in the
  26. * Javac task itself, the only thing all adapters need is the javac
  27. * task, the execute command and a parameterless constructor (for
  28. * reflection).</p>
  29. *
  30. * @since Ant 1.3
  31. */
  32. public interface CompilerAdapter {
  33. /**
  34. * Sets the compiler attributes, which are stored in the Javac task.
  35. */
  36. void setJavac(Javac attributes);
  37. /**
  38. * Executes the task.
  39. *
  40. * @return has the compilation been successful
  41. */
  42. boolean execute() throws BuildException;
  43. }