/* Copyright (c) 2009-2011 Olivier Chafik, All Rights Reserved This file is part of JNAerator (http://jnaerator.googlecode.com/). JNAerator 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. JNAerator 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 JNAerator. If not, see <http://www.gnu.org/licenses/>. */ package com.ochafik.io; import java.io.File; import java.util.Collection; import java.util.HashSet; public class FileListUtils { public static Collection<String> resolveShellLikeFileList(String d) { HashSet<String> v=new HashSet<String>(); File f=new File(d); String name=f.getName(); File par=f.getParentFile(); if (par==null) { par=new File("."); } String fs[]=par.list(); if (fs==null) return v; for (int i=0; i<fs.length;i++) { String fsi=fs[i]; if (complies(fsi,name)) v.add((new File(par,fsi)).toString()); } return v; } public static boolean complies(String s, String model) { int len=model.length(),slen=s.length(); if (len==0) { return slen==0; } else if (slen==0) { return model.equals("") || model.equals("*"); } else { char c=model.charAt(0); if (c=='*') { String smod=model.substring(1); for (int i=0;i<slen;i++) { if (complies(s.substring(i),smod)) return true; } } else if (c=='?') { String smod=model.substring(1); if (complies(s.substring(1),smod)) return true; } else { return s.charAt(0)==c && complies(s.substring(1),model.substring(1)); } } return false; } }