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