/* * JBoss, Home of Professional Open Source. * Copyright 2012, Red Hat, Inc., and individual contributors * as indicated by the @author tags. See the copyright.txt file in the * distribution for a full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.as.server.deployment.annotation; import java.io.InputStream; import java.util.HashSet; import java.util.List; import java.util.Set; import org.jboss.as.server.logging.ServerLogger; import org.jboss.as.server.deployment.Attachments; import org.jboss.as.server.deployment.DeploymentUnitProcessingException; import org.jboss.as.server.deployment.module.ResourceRoot; import org.jboss.as.server.moduleservice.ModuleIndexBuilder; import org.jboss.jandex.Index; import org.jboss.jandex.IndexReader; import org.jboss.jandex.Indexer; import org.jboss.vfs.VFSUtils; import org.jboss.vfs.VirtualFile; import org.jboss.vfs.VirtualFileFilter; import org.jboss.vfs.VisitorAttributes; import org.jboss.vfs.util.SuffixMatchFilter; /** * Utility class for indexing a resource root */ public class ResourceRootIndexer { /** * Creates and attaches the annotation index to a resource root, if it has not already been attached */ public static void indexResourceRoot(final ResourceRoot resourceRoot) throws DeploymentUnitProcessingException { if (resourceRoot.getAttachment(Attachments.ANNOTATION_INDEX) != null) { return; } VirtualFile indexFile = resourceRoot.getRoot().getChild(ModuleIndexBuilder.INDEX_LOCATION); if (indexFile.exists()) { try { IndexReader reader = new IndexReader(indexFile.openStream()); resourceRoot.putAttachment(Attachments.ANNOTATION_INDEX, reader.read()); ServerLogger.DEPLOYMENT_LOGGER.tracef("Found and read index at: %s", indexFile); return; } catch (Exception e) { ServerLogger.DEPLOYMENT_LOGGER.cannotLoadAnnotationIndex(indexFile.getPathName()); } } // if this flag is present and set to false then do not index the resource Boolean shouldIndexResource = resourceRoot.getAttachment(Attachments.INDEX_RESOURCE_ROOT); if (shouldIndexResource != null && !shouldIndexResource) { return; } final List<String> indexIgnorePathList = resourceRoot.getAttachment(Attachments.INDEX_IGNORE_PATHS); final Set<String> indexIgnorePaths; if (indexIgnorePathList != null && !indexIgnorePathList.isEmpty()) { indexIgnorePaths = new HashSet<String>(indexIgnorePathList); } else { indexIgnorePaths = null; } final VirtualFile virtualFile = resourceRoot.getRoot(); final Indexer indexer = new Indexer(); try { final VisitorAttributes visitorAttributes = new VisitorAttributes(); visitorAttributes.setLeavesOnly(true); visitorAttributes.setRecurseFilter(new VirtualFileFilter() { public boolean accepts(VirtualFile file) { return indexIgnorePaths == null || !indexIgnorePaths.contains(file.getPathNameRelativeTo(virtualFile)); } }); final List<VirtualFile> classChildren = virtualFile.getChildren(new SuffixMatchFilter(".class", visitorAttributes)); for (VirtualFile classFile : classChildren) { InputStream inputStream = null; try { inputStream = classFile.openStream(); indexer.index(inputStream); } catch (Exception e) { ServerLogger.DEPLOYMENT_LOGGER.cannotIndexClass(classFile.getPathNameRelativeTo(virtualFile), virtualFile.getPathName(), e); } finally { VFSUtils.safeClose(inputStream); } } final Index index = indexer.complete(); resourceRoot.putAttachment(Attachments.ANNOTATION_INDEX, index); ServerLogger.DEPLOYMENT_LOGGER.tracef("Generated index for archive %s", virtualFile); } catch (Throwable t) { throw ServerLogger.ROOT_LOGGER.deploymentIndexingFailed(t); } } }