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.util;
020
021import lucee.commons.io.SystemUtil;
022import lucee.commons.io.res.Resource;
023
024
025public class WildcardPatternFilter implements ResourceAndResourceNameFilter {
026
027        
028        private final WildcardPattern matcher;
029        
030        
031        public WildcardPatternFilter( String patt, boolean ignoreCase, String patternDelimiters ) {
032                
033                matcher = new WildcardPattern( patt, !ignoreCase, patternDelimiters );
034        }
035        
036        
037        public WildcardPatternFilter( String pattern, String patternDelimiters ) {
038                
039                this( pattern, SystemUtil.isWindows(), patternDelimiters );
040        }
041        
042        
043        @Override
044        public boolean accept( Resource res ) {
045                
046                return matcher.isMatch( res.getName() );
047        }
048
049        
050        @Override
051        public boolean accept( Resource res, String name ) {
052
053                return matcher.isMatch( name );
054        }
055        
056        
057        public boolean accept( String name ) {
058
059                return matcher.isMatch( name );
060        }
061
062        
063        @Override
064        public String toString() {
065                
066                return matcher.toString();
067        }
068        
069}