12ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair/*
22ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * Copyright 2008 the original author or authors.
32ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair *
42ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * Licensed under the Apache License, Version 2.0 (the "License");
52ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * you may not use this file except in compliance with the License.
62ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * You may obtain a copy of the License at
72ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair *
82ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair *      http://www.apache.org/licenses/LICENSE-2.0
92ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair *
102ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * Unless required by applicable law or agreed to in writing, software
112ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * distributed under the License is distributed on an "AS IS" BASIS,
122ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
132ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * See the License for the specific language governing permissions and
142ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * limitations under the License.
152ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair */
162ab05e83458f35931075adca0d7b0fce4ea7cccbchrismairpackage org.mockftpserver.fake.filesystem;
172ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
182ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair/**
192ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * File system entry representing a directory
202ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair *
212ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * @author Chris Mair
222ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair * @version $Revision$ - $Date$
232ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair */
242ab05e83458f35931075adca0d7b0fce4ea7cccbchrismairpublic class DirectoryEntry extends AbstractFileSystemEntry {
252ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
262ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    /**
272ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * Construct a new instance without setting its path
282ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     */
292ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    public DirectoryEntry() {
302ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    }
312ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
322ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    /**
332ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * Construct a new instance with the specified value for its path
342ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     *
352ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * @param path - the value for path
362ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     */
372ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    public DirectoryEntry(String path) {
382ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        super(path);
392ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    }
402ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
412ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    /**
422ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * Return true to indicate that this entry represents a directory
432ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     *
442ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * @return true
452ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     */
462ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    public boolean isDirectory() {
472ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        return true;
482ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    }
492ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
502ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    /**
512ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * Return the size of this directory. This method returns zero.
522ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     *
532ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * @return the file size in bytes
542ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     */
552ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    public long getSize() {
562ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        return 0;
572ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    }
582ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
592ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    /**
602ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * @see java.lang.Object#toString()
612ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     */
622ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    public String toString() {
632ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        return "Directory['" + getPath() + "' lastModified=" + getLastModified() + "  owner=" + getOwner() +
642ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair                "  group=" + getGroup() + "  permissions=" + getPermissions() + "]";
652ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    }
662ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
672ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    /**
682ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * Return a new FileSystemEntry that is a clone of this object, except having the specified path
692ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     *
702ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * @param path - the new path value for the cloned file system entry
712ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     * @return a new FileSystemEntry that has all the same values as this object except for its path
722ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair     */
732ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    public FileSystemEntry cloneWithNewPath(String path) {
742ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        DirectoryEntry clone = new DirectoryEntry(path);
752ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        clone.setLastModified(getLastModified());
762ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        clone.setOwner(getOwner());
772ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        clone.setGroup(getGroup());
782ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        clone.setPermissions(getPermissions());
792ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair        return clone;
802ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair    }
812ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair
822ab05e83458f35931075adca0d7b0fce4ea7cccbchrismair}
83