All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.refcodes.filesystem.FileHandle Maven / Gradle / Ivy

// /////////////////////////////////////////////////////////////////////////////
// REFCODES.ORG
// =============================================================================
// This code is copyright (c) by Siegfried Steiner, Munich, Germany and licensed
// under the following (see "http://en.wikipedia.org/wiki/Multi-licensing")
// licenses:
// =============================================================================
// GNU General Public License, v3.0 ("http://www.gnu.org/licenses/gpl-3.0.html")
// together with the GPL linking exception applied; as being applied by the GNU
// Classpath ("http://www.gnu.org/software/classpath/license.html")
// =============================================================================
// Apache License, v2.0 ("http://www.apache.org/licenses/LICENSE-2.0")
// =============================================================================
// Please contact the copyright holding author(s) of the software artifacts in
// question for licensing issues not being covered by the above listed licenses,
// also regarding commercial licensing models or regarding the compatibility
// with other open source licenses.
// /////////////////////////////////////////////////////////////////////////////

package org.refcodes.filesystem;

import java.util.Date;

import org.refcodes.mixin.CreatedDateAccessor;
import org.refcodes.mixin.ModifiedDateAccessor;
import org.refcodes.mixin.NameAccessor;
import org.refcodes.mixin.PathAccessor;
import org.refcodes.mixin.SizeAccessor;

/**
 * A file (handle) (descriptor) describes a file in a file system.
 */
public interface FileHandle extends PathAccessor, NameAccessor, SizeAccessor, CreatedDateAccessor, ModifiedDateAccessor {

	/**
	 * The path is the part of the key without the name. The path separator is
	 * not implementation specific and should be retrieved from the file
	 * system's {@link FileSystem#PATH_DELIMITER} attribute.
	 * 
	 * @return The path of the file's key without the name.
	 */
	@Override
	String getPath();

	/**
	 * The name is the part of the key without the path. The path separator is
	 * not implementation specific and should be retrieved from the file
	 * system's {@link FileSystem#PATH_DELIMITER} attribute.
	 * 
	 * @return The name of the file's key without the path.
	 */
	@Override
	String getName();

	/**
	 * The key is the fully qualified name to identify the file. The key usually
	 * is physically (directory path and filename) or virtually composed of the
	 * path and the name.
	 * 
	 * @return The fully qualified key of the file.
	 */
	String toKey();

	/**
	 * The size of the content of the file.
	 * 
	 * @return The content size of the file.
	 */
	@Override
	long getSize();

	/**
	 * The date when the file was created.
	 * 
	 * @return The creation date.
	 */
	@Override
	public Date getCreatedDate();

	/**
	 * The date when the file was modified.
	 * 
	 * @return The modification date.
	 */
	@Override
	public Date getModifiedDate();

	/**
	 * Converts the give {@link FileHandle} to a {@link MutableFileHandle}. The
	 * mutable {@link FileHandle} allows the modification of (fiddling around
	 * with) attributes.
	 * -------------------------------------------------------------------------
	 * ATTENTION: Usually fiddling around with attributes is not necessary, as
	 * the {@link FileSystem} itself provides the sufficient functionality to
	 * work with files. In some cases though this might be necessary: This
	 * method is being provided to allow modification of file attributes while
	 * making sure that the {@link FileHandle} itself creates a copy so that any
	 * additional attributes provided by extensions of this interface of whom
	 * the developer does not know (yet) are preserved. So extensions of the
	 * {@link FileHandle} know how to create a {@link MutableFileHandle} without
	 * information loss, the business logic does not require to take care of any
	 * yet unknown extensions.
	 * -------------------------------------------------------------------------
	 * CAUTION: Working with modified {@link FileHandle}s on the
	 * {@link FileSystem} can cause unexpected (severe) behavior (data loss), so
	 * we assume that you know what you do when using the
	 * {@link MutableFileHandle}!
	 * -------------------------------------------------------------------------
	 * Use {@link MutableFileHandle#toFileHandle()} to get back to a
	 * {@link FileHandle} to avoid hassle with collections, the
	 * {@link #hashCode()} and the {@link #equals(Object)} operations.
	 * 
	 * @return
	 */
	public MutableFileHandle toMutableFileHandle();

	/**
	 * The mutable {@link FileHandle} allows the modification of (fiddling
	 * around with) attributes.
	 * -------------------------------------------------------------------------
	 * ATTENTION: Usually fiddling around with attributes is not necessary, as
	 * the {@link FileSystem} itself provides the sufficient functionality to
	 * work with files. In some cases though this might be necessary: This class
	 * is being provided to allow modification of file attributes while making
	 * sure that the {@link FileHandle} itself creates a copy so that any
	 * additional attributes provided by extensions of this interface of whom
	 * the developer does not know (yet) are preserved. So extensions of the
	 * {@link FileHandle} know how to create a {@link MutableFileHandle} without
	 * information loss, the business logic does not require to take care of any
	 * yet unknown extensions.
	 * -------------------------------------------------------------------------
	 * CAUTION: Working with modified {@link FileHandle}s on the
	 * {@link FileSystem} can cause unexpected (severe) behavior (data loss), so
	 * we assume that you know what you do when using the
	 * {@link MutableFileHandle}!
	 */
	public interface MutableFileHandle extends FileHandle, PathProperty, NameProperty, SizeProperty, CreatedDateProperty, ModifiedDateProperty {

		/**
		 * Converts the {@link MutableFileHandle} back to a {@link FileHandle}
		 * to avoid hassle with collections, the {@link #hashCode()} and the
		 * {@link #equals(Object)} operations.
		 * 
		 * @return An immutable {@link FileHandle} from this
		 *         {@link MutableFileHandle}.
		 */
		public FileHandle toFileHandle();

	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy