1ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair/* 2ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Copyright 2008 the original author or authors. 3ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 4ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Licensed under the Apache License, Version 2.0 (the "License"); 5ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * you may not use this file except in compliance with the License. 6ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * You may obtain a copy of the License at 7ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 8ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * http://www.apache.org/licenses/LICENSE-2.0 9ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 10ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Unless required by applicable law or agreed to in writing, software 11ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * distributed under the License is distributed on an "AS IS" BASIS, 12ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * See the License for the specific language governing permissions and 14ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * limitations under the License. 15ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 16ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismairpackage org.mockftpserver.fake.filesystem; 17ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 18ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair/** 19ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * File system entry representing a directory 20ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 21ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @author Chris Mair 22ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @version $Revision: 123 $ - $Date: 2008-09-24 22:23:19 -0400 (Wed, 24 Sep 2008) $ 23ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 24ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismairpublic class DirectoryEntry extends AbstractFileSystemEntry { 25ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 26ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair /** 27ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Construct a new instance without setting its path 28ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 29ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair public DirectoryEntry() { 30ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair } 31ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 32ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair /** 33ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Construct a new instance with the specified value for its path 34ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 35ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @param path - the value for path 36ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 37ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair public DirectoryEntry(String path) { 38ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair super(path); 39ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair } 40ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 41ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair /** 42ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Abstract method -- must be implemented within concrete subclasses 43ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 44ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @return true if this file system entry represents a directory 45ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 46ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair public boolean isDirectory() { 47ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair return true; 48ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair } 49ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 50ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair /** 51ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Return the size of this directory. This method returns zero. 52ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 53ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @return the file size in bytes 54ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 55ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair public long getSize() { 56ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair return 0; 57ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair } 58ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 59ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair /** 60ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @see java.lang.Object#toString() 61ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 62ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair public String toString() { 63ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair return "Directory['" + getPath() + "' lastModified=" + getLastModified() + " owner=" + getOwner() + 64ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair " group=" + getGroup() + " permissions=" + getPermissions() + "]"; 65ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair } 66ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 67ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair /** 68ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * Return a new FileSystemEntry that is a clone of this object, except having the specified path 69ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * 70ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @param path - the new path value for the cloned file system entry 71ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * @return a new FileSystemEntry that has all the same values as this object except for its path 72ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */ 73ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair public FileSystemEntry cloneWithNewPath(String path) { 74ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair DirectoryEntry clone = new DirectoryEntry(path); 75ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair clone.setLastModified(getLastModified()); 76ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair clone.setOwner(getOwner()); 77ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair clone.setGroup(getGroup()); 78ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair clone.setPermissions(getPermissions()); 79ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair return clone; 80ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair } 81ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair 82ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair} 83