1 /* 2 * Licensed to the Apache Software Foundation (ASF) under one or more 3 * contributor license agreements. See the NOTICE file distributed with 4 * this work for additional information regarding copyright ownership. 5 * The ASF licenses this file to You under the Apache License, Version 2.0 6 * (the "License"); you may not use this file except in compliance with 7 * the License. You may obtain a copy of the License at 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 */ 17 package org.apache.commons.vfs2.impl; 18 19 import org.apache.commons.vfs2.FileName; 20 import org.apache.commons.vfs2.FileType; 21 import org.apache.commons.vfs2.provider.AbstractFileName; 22 23 /** 24 * A simple file name to hold the scheme for to be created virtual file system. 25 */ 26 public class VirtualFileName extends AbstractFileName { 27 28 /** 29 * Constructs a new instance. 30 * 31 * @param scheme The scheme. 32 * @param absolutePath the absolute path, maybe empty or null. 33 * @param type the file type. 34 */ 35 public VirtualFileName(final String scheme, final String absolutePath, final FileType type) { 36 super(scheme, absolutePath, type); 37 } 38 39 @Override 40 protected void appendRootUri(final StringBuilder buffer, final boolean addPassword) { 41 buffer.append(getScheme()); 42 } 43 44 @Override 45 public FileName createName(final String absolutePath, final FileType type) { 46 return new VirtualFileName(getScheme(), absolutePath, type); 47 } 48 }