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 * Exception thrown when a path/filename is not valid. Causes include:
20ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * <ul>
21ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * <li>The filename contains invalid characters</li>
22ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * <li>The path specifies a new filename, but its parent directory does not exist</li>
23ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * <li>The path is expected to be a file, but actually specifies an existing directory</li>
24ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair * </ul>
25ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair */
26ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismairpublic class InvalidFilenameException extends FileSystemException {
27ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair
28ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    private static final String MESSAGE_KEY = "filesystem.pathIsNotValid";
29ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair
30ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    /**
31ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair     * @param path - the path involved in the file system operation that caused the exception
32ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair     */
33ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    public InvalidFilenameException(String path) {
34ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair        super(path, MESSAGE_KEY);
35ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    }
36ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair
37ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    /**
38ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair     * @param path  - the path involved in the file system operation that caused the exception
39ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair     * @param cause - the exception cause, wrapped by this exception
40ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair     */
41ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    public InvalidFilenameException(String path, Throwable cause) {
42ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair        super(path, MESSAGE_KEY, cause);
43ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair    }
44ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair
45ad39334d4c363c6ada5863d0bb3184f5f4699d69chrismair}