Mercurial > jhg
view src/org/tmatesoft/hg/util/FileInfo.java @ 576:3c4db86e8c1f
Issue 43: poor performance with InflaterDataAccess. Phase 2: inflate into buffer, effective skip and readByte/readBytes()
author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
---|---|
date | Tue, 16 Apr 2013 19:31:57 +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(); }