/*
 * JBoss, Home of Professional Open Source
 * Copyright 2009, 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.impl.base.spec;

import java.util.logging.Logger;

import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.ArchivePath;
import org.jboss.shrinkwrap.api.spec.JavaArchive;
import org.jboss.shrinkwrap.impl.base.container.ContainerBase;
import org.jboss.shrinkwrap.impl.base.path.BasicPath;

Implementation of an archive with JAR-specific support.
Author:ALR, Aslak Knutsen
Version:$Revision: $
/** * Implementation of an archive with JAR-specific support. * * @author <a href="mailto:andrew.rubinger@jboss.org">ALR</a> * @author <a href="mailto:aslak@conduct.no">Aslak Knutsen</a> * @version $Revision: $ */
public class JavaArchiveImpl extends ContainerBase<JavaArchive> implements JavaArchive { // -------------------------------------------------------------------------------------|| // Class Members ----------------------------------------------------------------------|| // -------------------------------------------------------------------------------------|| @SuppressWarnings("unused") private static final Logger log = Logger.getLogger(JavaArchiveImpl.class.getName());
Path to the manifests inside of the Archive.
/** * Path to the manifests inside of the Archive. */
private static final ArchivePath PATH_MANIFEST = new BasicPath("META-INF");
Path to the resources inside of the Archive.
/** * Path to the resources inside of the Archive. */
private static final ArchivePath PATH_RESOURCE = new BasicPath("/");
Path to the classes inside of the Archive.
/** * Path to the classes inside of the Archive. */
private static final ArchivePath PATH_CLASSES = new BasicPath("/"); // -------------------------------------------------------------------------------------|| // Instance Members -------------------------------------------------------------------|| // -------------------------------------------------------------------------------------|| // -------------------------------------------------------------------------------------|| // Constructor ------------------------------------------------------------------------|| // -------------------------------------------------------------------------------------||
Create a new JavaArchive with any type storage engine as backing.
Params:
  • delegate – The storage backing.
/** * Create a new JavaArchive with any type storage engine as backing. * * @param delegate * The storage backing. */
public JavaArchiveImpl(final Archive<?> delegate) { super(JavaArchive.class, delegate); } // -------------------------------------------------------------------------------------|| // Required Implementations -----------------------------------------------------------|| // -------------------------------------------------------------------------------------|| /* * (non-Javadoc) * * @see org.jboss.declarchive.impl.base.ContainerBase#getManifestPath() */ @Override protected ArchivePath getManifestPath() { return PATH_MANIFEST; } /* * (non-Javadoc) * * @see org.jboss.shrinkwrap.impl.base.container.ContainerBase#getClassesPath() */ @Override protected ArchivePath getClassesPath() { return PATH_CLASSES; } /* * (non-Javadoc) * * @see org.jboss.declarchive.impl.base.ContainerBase#getResourcePath() */ @Override protected ArchivePath getResourcePath() { return PATH_RESOURCE; }
Libraries are not supported by JavaArchive.
Throws:
  • UnsupportedOperationException – Libraries are not supported by JavaArchive
/** * Libraries are not supported by JavaArchive. * * @throws UnsupportedOperationException * Libraries are not supported by JavaArchive */
@Override public ArchivePath getLibraryPath() { throw new UnsupportedOperationException("JavaArchive spec does not support Libraries"); } }