001/**
002 *
003 * Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
004 *
005 * This library is free software; you can redistribute it and/or
006 * modify it under the terms of the GNU Lesser General Public
007 * License as published by the Free Software Foundation; either 
008 * version 2.1 of the License, or (at your option) any later version.
009 * 
010 * This library is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
013 * Lesser General Public License for more details.
014 * 
015 * You should have received a copy of the GNU Lesser General Public 
016 * License along with this library.  If not, see <http://www.gnu.org/licenses/>.
017 * 
018 **/
019package lucee.commons.io.res;
020
021public interface Resources {
022
023        /**
024         * adds a default factory, this factory is used, when shemecan't be mapped to a other factory
025         * @param provider
026         */
027        public void registerDefaultResourceProvider(ResourceProvider provider);
028        
029        /**
030         * adds a additional resource to System
031         * @param provider
032         */
033        public void registerResourceProvider(ResourceProvider provider);
034        
035        /**
036         * returns a resource that matching the given path
037         * @param path
038         * @return matching resource
039         */
040        public Resource getResource(String path);
041
042
043        /**
044         * @return the defaultResource
045         */
046        public ResourceProvider getDefaultResourceProvider();
047
048        public ResourceProvider[] getResourceProviders();
049
050        public ResourceLock createResourceLock(long timeout,boolean caseSensitive);
051
052        public void reset();
053}