![]() |
Quadcap Embeddable Server |
00001 package com.quadcap.io; 00002 00003 /* Copyright 1997 - 2003 Quadcap Software. All rights reserved. 00004 * 00005 * This software is distributed under the Quadcap Free Software License. 00006 * This software may be used or modified for any purpose, personal or 00007 * commercial. Open Source redistributions are permitted. Commercial 00008 * redistribution of larger works derived from, or works which bundle 00009 * this software requires a "Commercial Redistribution License"; see 00010 * http://www.quadcap.com/purchase. 00011 * 00012 * Redistributions qualify as "Open Source" under one of the following terms: 00013 * 00014 * Redistributions are made at no charge beyond the reasonable cost of 00015 * materials and delivery. 00016 * 00017 * Redistributions are accompanied by a copy of the Source Code or by an 00018 * irrevocable offer to provide a copy of the Source Code for up to three 00019 * years at the cost of materials and delivery. Such redistributions 00020 * must allow further use, modification, and redistribution of the Source 00021 * Code under substantially the same terms as this license. 00022 * 00023 * Redistributions of source code must retain the copyright notices as they 00024 * appear in each source code file, these license terms, and the 00025 * disclaimer/limitation of liability set forth as paragraph 6 below. 00026 * 00027 * Redistributions in binary form must reproduce this Copyright Notice, 00028 * these license terms, and the disclaimer/limitation of liability set 00029 * forth as paragraph 6 below, in the documentation and/or other materials 00030 * provided with the distribution. 00031 * 00032 * The Software is provided on an "AS IS" basis. No warranty is 00033 * provided that the Software is free of defects, or fit for a 00034 * particular purpose. 00035 * 00036 * Limitation of Liability. Quadcap Software shall not be liable 00037 * for any damages suffered by the Licensee or any third party resulting 00038 * from use of the Software. 00039 */ 00040 00041 import java.io.File; 00042 import java.io.FileFilter; 00043 00044 import java.util.Iterator; 00045 import java.util.Stack; 00046 00047 /** 00048 * 00049 * 00050 * @author Stan Bailes 00051 */ 00052 public class RecursiveFileIterator implements Iterator { 00053 File root; 00054 FileFilter filter; 00055 Stack s = new Stack(); 00056 File nextFile = null; 00057 boolean done = false; 00058 00059 class IEntry { 00060 File f; 00061 File[] files; 00062 int pos; 00063 00064 public IEntry(File f) { 00065 this.f = f; 00066 this.files = f.listFiles(); 00067 if (files == null) files = new File[0]; 00068 this.pos = 0; 00069 } 00070 } 00071 00072 public RecursiveFileIterator(File root, FileFilter filter) { 00073 this.root = root; 00074 this.filter = filter; 00075 if (root.isDirectory()) s.push(new IEntry(root)); 00076 } 00077 00078 public boolean hasNext() { 00079 while (nextFile == null && !done) { 00080 if (s.size() == 0) { 00081 done = true; 00082 } else { 00083 IEntry ie = (IEntry)s.peek(); 00084 if (ie.pos >= ie.files.length) { 00085 s.pop(); 00086 } else { 00087 File f1 = ie.files[ie.pos++]; 00088 if (f1.isDirectory()) { 00089 s.push(new IEntry(f1)); 00090 } else { 00091 if (filter.accept(f1)) nextFile = f1; 00092 } 00093 } 00094 } 00095 } 00096 return !done; 00097 } 00098 00099 public Object next() { 00100 if (nextFile == null && !done) { 00101 hasNext(); 00102 } 00103 Object ret = nextFile; 00104 nextFile = null; 00105 return ret; 00106 } 00107 00108 public void remove() { 00109 throw new RuntimeException("not implemented"); 00110 } 00111 00112 }