1 /* 2 * Copyright (C) 2003-2009 JNode.org 3 * 2009,2010 Matthias Treydte <mt@waldheinz.de> 4 * 5 * This library is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU Lesser General Public License as published 7 * by the Free Software Foundation; either version 2.1 of the License, or 8 * (at your option) any later version. 9 * 10 * This library is distributed in the hope that it will be useful, but 11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public 13 * License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with this library; If not, write to the Free Software Foundation, Inc., 17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. 18 */ 19 20 package de.waldheinz.fs; 21 22 import java.io.IOException; 23 24 /** 25 * The interface common to all file system implementations. 26 * 27 * @author Ewout Prangsma <epr at jnode.org> 28 * @author Matthias Treydte <waldheinz at gmail.com> 29 */ 30 public interface FileSystem { 31 32 /** 33 * Gets the root entry of this filesystem. This is usually a directory, but 34 * this is not required. 35 * 36 * @return the file system's root entry 37 * @throws IOException on read error 38 */ 39 public FsDirectory getRoot() throws IOException; 40 41 /** 42 * Returns if this {@code FileSystem} is in read-only mode. 43 * 44 * @return if this {@code FileSystem} is read-only 45 */ 46 public boolean isReadOnly(); 47 48 /** 49 * Close this file system. After a close, all invocations of methods of 50 * this file system or objects created by this file system will throw an 51 * {@link IllegalStateException}. 52 * 53 * @throws IOException on error closing the file system 54 */ 55 public void close() throws IOException; 56 57 /** 58 * Returns {@code true} if this file system is closed. If the file system 59 * is closed, no more operations may be performed on it. 60 * 61 * @return if this file system is closed 62 */ 63 public boolean isClosed(); 64 65 /** 66 * The total size of this file system. 67 * 68 * @return if -1 this feature is unsupported 69 * @throws IOException if an I/O error occurs 70 */ 71 public long getTotalSpace() throws IOException; 72 73 /** 74 * The free space of this file system. 75 * 76 * @return if -1 this feature is unsupported 77 * @throws IOException if an I/O error occurs 78 */ 79 public long getFreeSpace() throws IOException; 80 81 /** 82 * The usable space of this file system. 83 * 84 * @return if -1 this feature is unsupported 85 * @throws IOException if an I/O error occurs 86 */ 87 public long getUsableSpace() throws IOException; 88 89 /** 90 * Flushes any modified file system structures to the underlying storage. 91 * 92 * @throws IOException 93 */ 94 public void flush() throws IOException; 95 } 96