001package ball.util.ant.taskdefs;
002/*-
003 * ##########################################################################
004 * Utilities
005 * $Id: ClasspathDelegateAntTask.html 5431 2020-02-12 19:03:17Z ball $
006 * $HeadURL: svn+ssh://svn.hcf.dev/var/spool/scm/repository.svn/hcf-dev/blog/2019-07-08-fivethirtyeight-best-scrabble-string/src/main/resources/javadoc/src-html/ball/util/ant/taskdefs/ClasspathDelegateAntTask.html $
007 * %%
008 * Copyright (C) 2008 - 2020 Allen D. Ball
009 * %%
010 * Licensed under the Apache License, Version 2.0 (the "License");
011 * you may not use this file except in compliance with the License.
012 * You may obtain a copy of the License at
013 *
014 *      http://www.apache.org/licenses/LICENSE-2.0
015 *
016 * Unless required by applicable law or agreed to in writing, software
017 * distributed under the License is distributed on an "AS IS" BASIS,
018 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
019 * See the License for the specific language governing permissions and
020 * limitations under the License.
021 * ##########################################################################
022 */
023import org.apache.tools.ant.AntClassLoader;
024import org.apache.tools.ant.BuildException;
025import org.apache.tools.ant.ProjectComponent;
026import org.apache.tools.ant.types.Path;
027import org.apache.tools.ant.types.Reference;
028import org.apache.tools.ant.util.ClasspathUtils;
029
030/**
031 * Interface to provide common default methods for
032 * {@link org.apache.tools.ant.Task}s that implement the syntax described in
033 * {@link org.apache.tools.ant.util.ClasspathUtils.Delegate}.
034 *
035 * @author {@link.uri mailto:ball@hcf.dev Allen D. Ball}
036 * @version $Revision: 5431 $
037 */
038public interface ClasspathDelegateAntTask extends AntTaskMixIn {
039
040    /**
041     * Required state for implementing {@link org.apache.tools.ant.Task}s.
042     * Refer to the discussion in {@link ClasspathUtils}.
043     *
044     * @return  The {@link org.apache.tools.ant.util.ClasspathUtils.Delegate}
045     *          instance created in the
046     *          {@link org.apache.tools.ant.Task#init()} method.
047     */
048    ClasspathUtils.Delegate delegate();
049
050    /**
051     * Required state for implementing {@link org.apache.tools.ant.Task}s.
052     * Refer to the discussion in {@link ClasspathUtils}.
053     *
054     * @param   delegate        The
055     *                          {@link org.apache.tools.ant.util.ClasspathUtils.Delegate}.
056     *
057     * @return  The {@link.this}.
058     */
059    ClasspathDelegateAntTask delegate(ClasspathUtils.Delegate delegate);
060
061    /**
062     * Default implementation for {@link org.apache.tools.ant.Task}
063     * subclasses.
064     */
065    default void init() throws BuildException {
066        if (delegate() == null) {
067            delegate(ClasspathUtils.getDelegate((ProjectComponent) this));
068        }
069    }
070
071    /**
072     * See
073     * {@link org.apache.tools.ant.util.ClasspathUtils.Delegate#setClasspathref(Reference)}.
074     *
075     * @param   reference       The {@link Reference} to the classpath.
076     */
077    default void setClasspathref(Reference reference) {
078        delegate().setClasspathref(reference);
079    }
080
081    /**
082     * See
083     * {@link org.apache.tools.ant.util.ClasspathUtils.Delegate#createClasspath()}.
084     *
085     * @return  The created {@link Path}.
086     */
087    default Path createClasspath() { return delegate().createClasspath(); }
088
089    /**
090     * See
091     * {@link org.apache.tools.ant.util.ClasspathUtils.Delegate#setClassname(String)}.
092     *
093     * @param   name            The class name ({@link String}).
094     */
095    default void setClassname(String name) {
096        delegate().setClassname(name);
097    }
098
099    /**
100     * Method to get the {@link AntClassLoader} specified by {@link.this}
101     * {@link org.apache.tools.ant.Task}.
102     *
103     * @return  The {@link AntClassLoader}.
104     */
105    default AntClassLoader getClassLoader() {
106        if (delegate().getClasspath() == null) {
107            delegate().createClasspath();
108        }
109
110        AntClassLoader loader = (AntClassLoader) delegate().getClassLoader();
111
112        loader.setParent(getClass().getClassLoader());
113
114        return loader;
115    }
116
117    /**
118     * Method to get the {@link Class} associated with the argument name
119     * using the {@link ClassLoader} provided by {@link #getClassLoader()}.
120     *
121     * @param   name            The fully qualified name of the desired
122     *                          class.
123     *
124     * @return  The {@link Class} for the specified name.
125     *
126     * @throws  ClassNotFoundException
127     *                          If the {@link Class} is not found.
128     */
129    default Class<?> getClassForName(String name) throws ClassNotFoundException {
130        return Class.forName(name, false, getClassLoader());
131    }
132}