All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.stephenc.javaisotools.vfs.provider.iso.IsoFileSystem Maven / Gradle / Ivy

/*
 * Copyright (c) 2010. Stephen Connolly.
 * Copyright (c) 2006-2007. loopy project (http://loopy.sourceforge.net).
 *  
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *  
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *  
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */

package com.github.stephenc.javaisotools.vfs.provider.iso;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Enumeration;
import java.util.List;

import com.github.stephenc.javaisotools.loopfs.iso9660.Iso9660FileEntry;
import com.github.stephenc.javaisotools.loopfs.iso9660.Iso9660FileSystem;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.commons.vfs.FileName;
import org.apache.commons.vfs.FileObject;
import org.apache.commons.vfs.FileSystemException;
import org.apache.commons.vfs.FileSystemOptions;
import org.apache.commons.vfs.Selectors;
import org.apache.commons.vfs.VfsLog;
import org.apache.commons.vfs.provider.AbstractFileSystem;
import org.apache.commons.vfs.provider.UriParser;

/**
 * Implementation of {@link org.apache.commons.vfs.FileSystem} for ISO9660 (.iso) files.
 * 

* TODO: perf test with ISO files containing lots of entries; possibly optimize by creating FileObjects on-demand via * the createFile() method. */ public class IsoFileSystem extends AbstractFileSystem { private static final Log log = LogFactory.getLog(IsoFileSystem.class); private Iso9660FileSystem fileSystem; public IsoFileSystem(final FileName rootName, final FileObject parentLayer, final FileSystemOptions fileSystemOptions) throws FileSystemException { super(rootName, parentLayer, fileSystemOptions); } public void init() throws FileSystemException { super.init(); final File file = getParentLayer().getFileSystem(). replicateFile(getParentLayer(), Selectors.SELECT_SELF); try { this.fileSystem = new Iso9660FileSystem(file, true); } catch (IOException ex) { throw new FileSystemException("vfs.provider.iso/open-iso-file.error", file, ex); } // Build the index final List strongRef = new ArrayList(100); boolean skipRoot = false; for (Iso9660FileEntry entry: this.fileSystem) { String name = entry.getPath(); // skip entries without names (should only be one - the root entry) if ("".equals(name)) { if (!skipRoot) { skipRoot = true; } else { continue; } } final FileName filename = getFileSystemManager(). resolveName(getRootName(), UriParser.encode(name)); // Create the file IsoFileObject fileObj; if (entry.isDirectory() && getFileFromCache(filename) != null) { fileObj = (IsoFileObject) getFileFromCache(filename); fileObj.setIsoEntry(entry); continue; } fileObj = new IsoFileObject(filename, entry, this); putFileToCache(fileObj); strongRef.add(fileObj); fileObj.holdObject(strongRef); // Make sure all ancestors exist IsoFileObject parent; for (FileName parentName = filename.getParent(); parentName != null; fileObj = parent, parentName = parentName.getParent()) { // Locate the parent parent = (IsoFileObject) getFileFromCache(parentName); if (parent == null) { parent = new IsoFileObject(parentName, this); putFileToCache(parent); strongRef.add(parent); parent.holdObject(strongRef); } // Attach child to parent parent.attachChild(fileObj.getName()); } } } protected void addCapabilities(final Collection caps) { caps.addAll(IsoFileProvider.capabilities); } /** * Since this method is only called for files that don't actually exist in the .iso file, it always returns * IMAGINARY files. Any attempt to access their content results in an exception. */ protected FileObject createFile(final FileName name) throws Exception { return new IsoFileObject(name, this); } /** * Closes the underlying .iso file. */ protected void doCloseCommunicationLink() { if (null != this.fileSystem && !this.fileSystem.isClosed()) { try { this.fileSystem.close(); } catch (IOException ex) { VfsLog.warn(getLogger(), log, "vfs.provider.iso/close-iso-file.error :" + this.fileSystem, ex); } } } public void close() { super.close(); this.fileSystem = null; } /** * Returns an input stream for the specified Iso9660FileEntry. Called by {@link IsoFileObject#doGetInputStream()}. */ InputStream getInputStream(final Iso9660FileEntry entry) { return this.fileSystem.getInputStream(entry); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy