Paul Holmes-Higgin cefda8c965 Updated header to LGPL
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2010-03-01 22:48:39 +00:00

75 lines
2.5 KiB
Java

/*
* Copyright (C) 2005-2010 Alfresco Software Limited.
*
* This file is part of Alfresco
*
* Alfresco 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 3 of the License, or
* (at your option) any later version.
*
* Alfresco 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 Alfresco. If not, see <http://www.gnu.org/licenses/>.
*/
package org.alfresco.util;
import java.io.IOException;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import org.springframework.core.io.DefaultResourceLoader;
import org.springframework.core.io.Resource;
import org.springframework.core.io.ResourceLoader;
import org.springframework.web.context.support.ServletContextResourcePatternResolver;
/**
* Can be used in Spring configuration to search for all resources matching an array of patterns.
*
* @author dward
*/
public class ResourceFinder extends ServletContextResourcePatternResolver
{
public ResourceFinder()
{
super(new DefaultResourceLoader());
}
/**
* The Constructor.
*
* @param resourceLoader
* the resource loader
*/
public ResourceFinder(ResourceLoader resourceLoader)
{
super(resourceLoader);
}
/**
* Gets an array of resources matching the given location patterns.
*
* @param locationPatterns
* the location patterns
* @return the matching resources, ordered by locationPattern index and location in the classpath
* @throws IOException
* Signals that an I/O exception has occurred.
*/
public Resource[] getResources(String... locationPatterns) throws IOException
{
List<Resource> resources = new LinkedList<Resource>();
for (String locationPattern : locationPatterns)
{
resources.addAll(Arrays.asList(getResources(locationPattern)));
}
Resource[] resourceArray = new Resource[resources.size()];
resources.toArray(resourceArray);
return resourceArray;
}
}