/* * JBoss, Home of Professional Open Source. * Copyright 2014 Red Hat, Inc., and individual contributors * as indicated by the @author tags. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jboss.modules; import java.util.Set; import org.jboss.modules.filter.ClassFilter; import org.jboss.modules.filter.ClassFilters; import org.jboss.modules.filter.PathFilter; import org.jboss.modules.filter.PathFilters; /** * A dependency specification that represents a single dependency for a module. The dependency can be on a local loader * or another module, or on the target module's local loader. * * @apiviz.exclude * * @author <a href="mailto:david.lloyd@redhat.com">David M. Lloyd</a> * @author <a href="mailto:jbailey@redhat.com">John Bailey</a> * @author Jason T. Greene */ public abstract class DependencySpec { final PathFilter importFilter; final PathFilter exportFilter; final PathFilter resourceImportFilter; final PathFilter resourceExportFilter; final ClassFilter classImportFilter; final ClassFilter classExportFilter; /** * Get the dependency import filter. * * @return the import filter */ public PathFilter getImportFilter() { return importFilter; } /** * Get the dependency export filter. * * @return the export filter */ public PathFilter getExportFilter() { return exportFilter; } /** * Get the dependency resource import filter. * * @return the import filter */ public PathFilter getResourceImportFilter() { return resourceImportFilter; } /** * Get the dependency resource export filter. * * @return the export filter */ public PathFilter getResourceExportFilter() { return resourceExportFilter; } /** * Get the dependency class import filter. * * @return the class import filter */ public ClassFilter getClassImportFilter() { return classImportFilter; } /** * Get the dependency class export filter. * * @return the class export filter */ public ClassFilter getClassExportFilter() { return classExportFilter; } DependencySpec(final PathFilter importFilter, final PathFilter exportFilter) { this(importFilter, exportFilter, PathFilters.acceptAll(), PathFilters.acceptAll(), ClassFilters.acceptAll(), ClassFilters.acceptAll()); } DependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final PathFilter resourceImportFilter, final PathFilter resourceExportFilter, final ClassFilter classImportFilter, final ClassFilter classExportFilter) { this.importFilter = importFilter; this.exportFilter = exportFilter; this.resourceImportFilter = resourceImportFilter; this.resourceExportFilter = resourceExportFilter; this.classImportFilter = classImportFilter; this.classExportFilter = classExportFilter; } abstract Dependency getDependency(final Module module); /** * Create a dependency on the current module's local resources. You should have at least one such dependency * on any module which has its own resources. * * @return the dependency spec */ public static DependencySpec createLocalDependencySpec() { return createLocalDependencySpec(PathFilters.acceptAll(), PathFilters.acceptAll()); } /** * Create a dependency on the current module's local resources. You should have at least one such dependency * on any module which has its own resources. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @return the dependency spec */ public static DependencySpec createLocalDependencySpec(final PathFilter importFilter, final PathFilter exportFilter) { if (importFilter == null) { throw new IllegalArgumentException("importFilter is null"); } if (exportFilter == null) { throw new IllegalArgumentException("exportFilter is null"); } return new DependencySpec(importFilter, exportFilter) { Dependency getDependency(final Module module) { return new ModuleClassLoaderDependency(exportFilter, importFilter, module.getClassLoaderPrivate()); } public String toString() { return "dependency on local resources"; } }; } /** * Create a dependency on the current module's local resources. You should have at least one such dependency * on any module which has its own resources. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param resourceImportFilter the resource import filter to apply * @param resourceExportFilter the resource export filter to apply * @param classImportFilter the class import filter to apply * @param classExportFilter the class export filter to apply * @return the dependency spec */ public static DependencySpec createLocalDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final PathFilter resourceImportFilter, final PathFilter resourceExportFilter, final ClassFilter classImportFilter, final ClassFilter classExportFilter) { if (importFilter == null) { throw new IllegalArgumentException("importFilter is null"); } if (exportFilter == null) { throw new IllegalArgumentException("exportFilter is null"); } if (classImportFilter == null) { throw new IllegalArgumentException("classImportFilter is null"); } if (classExportFilter == null) { throw new IllegalArgumentException("classExportFilter is null"); } if (resourceImportFilter == null) { throw new IllegalArgumentException("resourceImportFilter is null"); } if (resourceExportFilter == null) { throw new IllegalArgumentException("resourceExportFilter is null"); } return new DependencySpec(importFilter, exportFilter, resourceImportFilter, resourceExportFilter, classImportFilter, classExportFilter) { Dependency getDependency(final Module module) { return new ModuleClassLoaderDependency(exportFilter, importFilter, resourceExportFilter, resourceImportFilter, classExportFilter, classImportFilter, module.getClassLoaderPrivate()); } public String toString() { return "dependency on filtered local resources"; } }; } /** * Create a system dependency. * * @param loaderPaths the set of paths to use from the system class loader * @return the dependency spec */ public static DependencySpec createSystemDependencySpec(final Set<String> loaderPaths) { return createLocalDependencySpec(ClassLoaderLocalLoader.SYSTEM, loaderPaths); } /** * Create a system dependency. * * @param loaderPaths the set of paths to use from the system class loader * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @return the dependency spec */ public static DependencySpec createSystemDependencySpec(final Set<String> loaderPaths, boolean export) { return createLocalDependencySpec(ClassLoaderLocalLoader.SYSTEM, loaderPaths, export); } /** * Create a system dependency. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param loaderPaths the set of paths to use from the system class loader * @return the dependency spec */ public static DependencySpec createSystemDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final Set<String> loaderPaths) { return createLocalDependencySpec(importFilter, exportFilter, ClassLoaderLocalLoader.SYSTEM, loaderPaths); } /** * Create a dependency on the given class loader. * * @param classLoader the class loader * @param loaderPaths the set of paths to use from this class loader * @return the dependency spec */ public static DependencySpec createClassLoaderDependencySpec(final ClassLoader classLoader, final Set<String> loaderPaths) { return createLocalDependencySpec(new ClassLoaderLocalLoader(classLoader), loaderPaths); } /** * Create a dependency on the given class loader. * * @param classLoader the class loader * @param loaderPaths the set of paths to use from this class loader * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @return the dependency spec */ public static DependencySpec createClassLoaderDependencySpec(final ClassLoader classLoader, final Set<String> loaderPaths, boolean export) { return createLocalDependencySpec(new ClassLoaderLocalLoader(classLoader), loaderPaths, export); } /** * Create a dependency on the given class loader. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param classLoader the class loader * @param loaderPaths the set of paths to use from this class loader * @return the dependency spec */ public static DependencySpec createClassLoaderDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final ClassLoader classLoader, final Set<String> loaderPaths) { return createLocalDependencySpec(importFilter, exportFilter, PathFilters.acceptAll(), PathFilters.acceptAll(), ClassFilters.acceptAll(), ClassFilters.acceptAll(), new ClassLoaderLocalLoader(classLoader), loaderPaths); } /** * Create a dependency on the given local loader. * * @param localLoader the local loader * @param loaderPaths the set of paths that is exposed by the local loader * @return the dependency spec */ public static DependencySpec createLocalDependencySpec(final LocalLoader localLoader, final Set<String> loaderPaths) { return createLocalDependencySpec(PathFilters.acceptAll(), PathFilters.rejectAll(), localLoader, loaderPaths); } /** * Create a dependency on the given local loader. * * @param localLoader the local loader * @param loaderPaths the set of paths that is exposed by the local loader * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @return the dependency spec */ public static DependencySpec createLocalDependencySpec(final LocalLoader localLoader, final Set<String> loaderPaths, boolean export) { return createLocalDependencySpec(PathFilters.acceptAll(), export ? PathFilters.getDefaultImportFilter() : PathFilters.rejectAll(), localLoader, loaderPaths); } /** * Create a dependency on the given local loader. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param localLoader the local loader * @param loaderPaths the set of paths that is exposed by the local loader * @return the dependency spec */ public static DependencySpec createLocalDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final LocalLoader localLoader, final Set<String> loaderPaths) { return createLocalDependencySpec(importFilter, exportFilter, PathFilters.acceptAll(), PathFilters.acceptAll(), ClassFilters.acceptAll(), ClassFilters.acceptAll(), localLoader, loaderPaths); } /** * Create a dependency on the given local loader. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param resourceImportFilter the resource import filter to apply * @param resourceExportFilter the resource export filter to apply * @param classImportFilter the class import filter to apply * @param classExportFilter the class export filter to apply * @param localLoader the local loader * @param loaderPaths the set of paths that is exposed by the local loader * @return the dependency spec */ public static DependencySpec createLocalDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final PathFilter resourceImportFilter, final PathFilter resourceExportFilter, final ClassFilter classImportFilter, final ClassFilter classExportFilter, final LocalLoader localLoader, final Set<String> loaderPaths) { if (importFilter == null) { throw new IllegalArgumentException("importFilter is null"); } if (exportFilter == null) { throw new IllegalArgumentException("exportFilter is null"); } if (localLoader == null) { throw new IllegalArgumentException("localLoader is null"); } if (loaderPaths == null) { throw new IllegalArgumentException("loaderPaths is null"); } if (classImportFilter == null) { throw new IllegalArgumentException("classImportFilter is null"); } if (classExportFilter == null) { throw new IllegalArgumentException("classExportFilter is null"); } if (resourceImportFilter == null) { throw new IllegalArgumentException("resourceImportFilter is null"); } if (resourceExportFilter == null) { throw new IllegalArgumentException("resourceExportFilter is null"); } return new DependencySpec(importFilter, exportFilter, resourceImportFilter, resourceExportFilter, classImportFilter, classExportFilter) { Dependency getDependency(final Module module) { return new LocalDependency(exportFilter, importFilter, resourceExportFilter, resourceImportFilter, classExportFilter, classImportFilter, localLoader, loaderPaths); } public String toString() { return "dependency on local loader " + localLoader; } }; } /** * Create a dependency on the given module. * * @param identifier the module identifier * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(String)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final ModuleIdentifier identifier) { return createModuleDependencySpec(identifier.toString()); } /** * Create a dependency on the given module. * * @param name the module name * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final String name) { return createModuleDependencySpec(name, false); } /** * Create a dependency on the given module. * * @param identifier the module identifier * @param export {@code true} if the dependency should be exported by default * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(String,boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final ModuleIdentifier identifier, final boolean export) { return createModuleDependencySpec(identifier.toString(), export); } /** * Create a dependency on the given module. * * @param name the module name * @param export {@code true} if the dependency should be exported by default * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final String name, final boolean export) { return createModuleDependencySpec(name, export, false); } /** * Create a dependency on the given module. * * @param identifier the module identifier * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(String,boolean,boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final ModuleIdentifier identifier, final boolean export, final boolean optional) { return createModuleDependencySpec(identifier.toString(), export, optional); } /** * Create a dependency on the given module. * * @param name the module name * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final String name, final boolean export, final boolean optional) { return createModuleDependencySpec(PathFilters.getDefaultImportFilter(), export ? PathFilters.acceptAll() : PathFilters.rejectAll(), null, name, optional); } /** * Create a dependency on the given module. * * @param moduleLoader the specific module loader from which the module should be acquired * @param identifier the module identifier * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(ModuleLoader, String, boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final ModuleLoader moduleLoader, final ModuleIdentifier identifier, final boolean export) { return createModuleDependencySpec(moduleLoader, identifier.toString(), export); } /** * Create a dependency on the given module. * * @param moduleLoader the specific module loader from which the module should be acquired * @param name the module name * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final ModuleLoader moduleLoader, final String name, final boolean export) { return createModuleDependencySpec(PathFilters.getDefaultImportFilter(), export ? PathFilters.acceptAll() : PathFilters.rejectAll(), moduleLoader, name, false); } /** * Create a dependency on the given module. * * @param moduleLoader the specific module loader from which the module should be acquired * @param identifier the module identifier * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(ModuleLoader,String,boolean,boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final ModuleLoader moduleLoader, final ModuleIdentifier identifier, final boolean export, final boolean optional) { return createModuleDependencySpec(moduleLoader, identifier.toString(), export, optional); } /** * Create a dependency on the given module. * * @param moduleLoader the specific module loader from which the module should be acquired * @param name the module name * @param export {@code true} if this is a fully re-exported dependency, {@code false} if it should not be exported * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final ModuleLoader moduleLoader, final String name, final boolean export, final boolean optional) { return createModuleDependencySpec(PathFilters.getDefaultImportFilter(), export ? PathFilters.acceptAll() : PathFilters.rejectAll(), moduleLoader, name, optional); } /** * Create a dependency on the given module. * * @param exportFilter the export filter to apply * @param identifier the module identifier * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(PathFilter,String,boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final PathFilter exportFilter, final ModuleIdentifier identifier, final boolean optional) { return createModuleDependencySpec(exportFilter, identifier.toString(), optional); } /** * Create a dependency on the given module. * * @param exportFilter the export filter to apply * @param name the module name * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final PathFilter exportFilter, final String name, final boolean optional) { return createModuleDependencySpec(PathFilters.getDefaultImportFilter(), exportFilter, null, name, optional); } /** * Create a dependency on the given module. * * @param exportFilter the export filter to apply * @param moduleLoader the specific module loader from which the module should be acquired * @param identifier the module identifier * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(PathFilter,ModuleLoader,String,boolean)} instead. */ public static DependencySpec createModuleDependencySpec(final PathFilter exportFilter, final ModuleLoader moduleLoader, final ModuleIdentifier identifier, final boolean optional) { return createModuleDependencySpec(exportFilter, moduleLoader, identifier.toString(), optional); } /** * Create a dependency on the given module. * * @param exportFilter the export filter to apply * @param moduleLoader the specific module loader from which the module should be acquired * @param name the module name * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final PathFilter exportFilter, final ModuleLoader moduleLoader, final String name, final boolean optional) { return createModuleDependencySpec(PathFilters.getDefaultImportFilter(), exportFilter, moduleLoader, name, optional); } /** * Create a dependency on the given module. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param moduleLoader the specific module loader from which the module should be acquired * @param identifier the module identifier * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(PathFilter, PathFilter, PathFilter, PathFilter, ClassFilter, ClassFilter, ModuleLoader, String, boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final ModuleLoader moduleLoader, final ModuleIdentifier identifier, final boolean optional) { return createModuleDependencySpec(importFilter, exportFilter, PathFilters.acceptAll(), PathFilters.acceptAll(), ClassFilters.acceptAll(), ClassFilters.acceptAll(), moduleLoader, identifier, optional); } /** * Create a dependency on the given module. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param moduleLoader the specific module loader from which the module should be acquired * @param name the module name * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final ModuleLoader moduleLoader, final String name, final boolean optional) { return createModuleDependencySpec(importFilter, exportFilter, PathFilters.acceptAll(), PathFilters.acceptAll(), ClassFilters.acceptAll(), ClassFilters.acceptAll(), moduleLoader, name, optional); } /** * Create a dependency on the given module. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param resourceImportFilter the resource import filter to apply * @param resourceExportFilter the resource export filter to apply * @param classImportFilter the class import filter to apply * @param classExportFilter the class export filter to apply * @param moduleLoader the specific module loader from which the module should be acquired * @param identifier the module identifier * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec * @deprecated Use {@link #createModuleDependencySpec(PathFilter,PathFilter,PathFilter,PathFilter,ClassFilter,ClassFilter,ModuleLoader,String,boolean)} instead. */ @Deprecated public static DependencySpec createModuleDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final PathFilter resourceImportFilter, final PathFilter resourceExportFilter, final ClassFilter classImportFilter, final ClassFilter classExportFilter, final ModuleLoader moduleLoader, final ModuleIdentifier identifier, final boolean optional) { return createModuleDependencySpec(importFilter, exportFilter, resourceImportFilter, resourceExportFilter, classImportFilter, classExportFilter, moduleLoader, identifier.toString(), optional); } /** * Create a dependency on the given module. * * @param importFilter the import filter to apply * @param exportFilter the export filter to apply * @param resourceImportFilter the resource import filter to apply * @param resourceExportFilter the resource export filter to apply * @param classImportFilter the class import filter to apply * @param classExportFilter the class export filter to apply * @param moduleLoader the specific module loader from which the module should be acquired * @param name the module name * @param optional {@code true} if the dependency is optional, {@code false} if it is mandatory * @return the dependency spec */ public static DependencySpec createModuleDependencySpec(final PathFilter importFilter, final PathFilter exportFilter, final PathFilter resourceImportFilter, final PathFilter resourceExportFilter, final ClassFilter classImportFilter, final ClassFilter classExportFilter, final ModuleLoader moduleLoader, final String name, final boolean optional) { if (importFilter == null) { throw new IllegalArgumentException("importFilter is null"); } if (exportFilter == null) { throw new IllegalArgumentException("exportFilter is null"); } if (name == null) { throw new IllegalArgumentException("name is null"); } if (classImportFilter == null) { throw new IllegalArgumentException("classImportFilter is null"); } if (classExportFilter == null) { throw new IllegalArgumentException("classExportFilter is null"); } if (resourceImportFilter == null) { throw new IllegalArgumentException("resourceImportFilter is null"); } if (resourceExportFilter == null) { throw new IllegalArgumentException("resourceExportFilter is null"); } return new ModuleDependencySpec(importFilter, exportFilter, resourceImportFilter, resourceExportFilter, classImportFilter, classExportFilter, moduleLoader, name, optional); } }