/*
* JBoss, Home of Professional Open Source
* Copyright 2010, Red Hat Middleware LLC, and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* 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.shrinkwrap.api;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.concurrent.ExecutorService;
Encapsulates all configuration for a given Domain
. Each Archive
created by the domain's ArchiveFactory
will consult the configuration internally. An Archive
's configuration may not be changed after construction; if a new config is required it must be created under a new domain. The default configuration is defined by ConfigurationBuilder
, and new configurations are created via ConfigurationBuilder.build()
. Note that while the Configuration
is immutable, its properties may have internal state that may be changed. For true isolation, use separate Domain
s when creating Archive
s. Author: ALR, Ken Gullaksen Version: $Revision: $
/**
* Encapsulates all configuration for a given {@link Domain}. Each {@link Archive} created by the domain's
* {@link ArchiveFactory} will consult the configuration internally. An {@link Archive}'s configuration may not be
* changed after construction; if a new config is required it must be created under a new domain. The default
* configuration is defined by {@link ConfigurationBuilder}, and new configurations are created via
* {@link ConfigurationBuilder#build()}. Note that while the {@link Configuration} is immutable, its properties may have
* internal state that may be changed. For true isolation, use separate {@link Domain}s when creating {@link Archive}s.
*
* @author <a href="mailto:andrew.rubinger@jboss.org">ALR</a>
* @author <a href="mailto:ken@glxn.net">Ken Gullaksen</a>
* @version $Revision: $
*/
public class Configuration {
// -------------------------------------------------------------------------------------||
// Class Members ----------------------------------------------------------------------||
// -------------------------------------------------------------------------------------||
// -------------------------------------------------------------------------------------||
// Instance Members -------------------------------------------------------------------||
// -------------------------------------------------------------------------------------||
Loader mapping archive types to the appropriate underlying implementation
/**
* Loader mapping archive types to the appropriate underlying implementation
*/
private final ExtensionLoader extensionLoader;
ExecutorService
used for all asynchronous operations Deprecated: No longer used by the implementation, will be removed in SW 2.0
/**
* {@link ExecutorService} used for all asynchronous operations
* @deprecated No longer used by the implementation, will be removed in SW 2.0
*/
@Deprecated
private final ExecutorService executorService;
ClassLoader
s used for extension loading /**
* {@link ClassLoader}s used for extension loading
*/
private final Iterable<ClassLoader> classLoaders;
// -------------------------------------------------------------------------------------||
// Constructor ------------------------------------------------------------------------||
// -------------------------------------------------------------------------------------||
Creates a new configuration instance using properties contained in the specified ConfigurationBuilder
. Params: - builder –
Construction object encapsulating the properties to use in this configuration
Throws: - IllegalArgumentException –
If the builder was not specified
/**
* Creates a new configuration instance using properties contained in the specified {@link ConfigurationBuilder}.
*
* @param builder
* Construction object encapsulating the properties to use in this configuration
* @throws IllegalArgumentException
* If the builder was not specified
*/
Configuration(final ConfigurationBuilder builder) throws IllegalArgumentException {
// Precondition checks
if (builder == null) {
throw new IllegalArgumentException("builder must be specified");
}
// Let the builder set defaults
builder.setDefaults();
// Set
this.extensionLoader = builder.getExtensionLoader();
this.executorService = builder.getExecutorService();
// Defensive copy
Collection<ClassLoader> cls = new ArrayList<ClassLoader>();
if (builder.getClassLoaders() instanceof Collection) {
cls = (Collection<ClassLoader>) builder.getClassLoaders();
} else {
for (final ClassLoader cl : builder.getClassLoaders()) {
cls.add(cl);
}
}
this.classLoaders = Collections.unmodifiableCollection(cls);
}
// -------------------------------------------------------------------------------------||
// Accessors --------------------------------------------------------------------------||
// -------------------------------------------------------------------------------------||
Returns: the extensionLoader
/**
* @return the extensionLoader
*/
public ExtensionLoader getExtensionLoader() {
return extensionLoader;
}
Returns: the executorService Deprecated: No longer used by the implementation, will be removed in SW 2.0
/**
* @return the executorService
* @deprecated No longer used by the implementation, will be removed in SW 2.0
*/
@Deprecated
public ExecutorService getExecutorService() {
return executorService;
}
Returns: The ClassLoader
s to be used in this configuration; used in extension loading and adding CL resources to the archive, etc
/**
* @return The {@link ClassLoader}s to be used in this configuration; used in extension loading and adding CL
* resources to the archive, etc
*/
public Iterable<ClassLoader> getClassLoaders() {
return classLoaders;
}
}