Mercurial > jhg
view src/org/tmatesoft/hg/util/FileInfo.java @ 626:5afc7eedb3dd v1.1rc1
@since, TODOs. Tests: add 1 sec to deal with fs timestamp granularity on linux
| author | Artem Tikhomirov <tikhomirov.artem@gmail.com> | 
|---|---|
| date | Tue, 21 May 2013 19:30:12 +0200 | 
| parents | 7f27122011c3 | 
| children | 
line wrap: on
 line source
/* * Copyright (c) 2011-2012 TMate Software Ltd * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License. * * This program 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 General Public License for more details. * * For information on how to redistribute this software under * the terms of a license other than GNU General Public License * contact TMate Software at support@hg4j.com */ package org.tmatesoft.hg.util; import java.nio.channels.ReadableByteChannel; /** * Subset of File-related functionality to support other than {@link java.io.File}-based {@link FileIterator} implementations * * @author Artem Tikhomirov * @author TMate Software Ltd. */ public interface FileInfo { /** * @return true if the filesystem object described by this instance exists, is a regular file and can be read */ boolean exists(); /** * File last modification time, in seconds since Jan 1, 1970. E.g. <code> {@link java.io.File#lastModified()} / 1000 </code> * @return int value representing time, in seconds, when file was last modified. */ int lastModified(); /** * @return file size */ long length(); /** * Access file contents. Caller is responsible to close the channel. * @return file reader object, never <code>null</code> */ ReadableByteChannel newInputChannel(); /** * This method is invoked only if source FileIterator tells <code>true</code> for {@link FileIterator#supportsExecFlag()} * @return <code>true</code> if this object describes an executable file */ boolean isExecutable(); /** * This method is be invoked only if source FileIterator tells <code>true</code> for {@link FileIterator#supportsLinkFlag()}. * @return <code>true</code> if this file object represents a symbolic link */ boolean isSymlink(); }
