Class GFileSystemBaseFactory
java.lang.Object
ghidra.formats.gfilesystem.factory.GFileSystemBaseFactory
- All Implemented Interfaces:
GFileSystemFactory<GFileSystemBase>,GFileSystemFactoryByteProvider<GFileSystemBase>,GFileSystemProbe,GFileSystemProbeByteProvider
public class GFileSystemBaseFactory
extends Object
implements GFileSystemFactoryByteProvider<GFileSystemBase>, GFileSystemProbeByteProvider
A
GFileSystemFactory implementation that probes and creates instances of
GFileSystemBase which use the legacy filesystem lifecycle pattern.
For each operation, this factory will mint a new instance of a GFileSystemBase-derived fs, using its 3 param constructor, and call its isValid() or open().
After an isValid() call, the newly minted filesystem instance is thrown away.
This class requires special support in the FileSystemFactoryMgr to push
the fsClass into each factory instance after it is constructed.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptioncreate(FSRLRoot targetFSRL, ByteProvider byteProvider, FileSystemService fsService, TaskMonitor monitor) Constructs a newGFileSysteminstance that handles the specified file.booleanprobe(ByteProvider byteProvider, FileSystemService fsService, TaskMonitor monitor) Probes the specifiedByteProviderto determine if this filesystem implementation can handle the file.voidsetFileSystemClass(Class<? extends GFileSystemBase> fsClass)
-
Constructor Details
-
GFileSystemBaseFactory
public GFileSystemBaseFactory()
-
-
Method Details
-
setFileSystemClass
-
probe
public boolean probe(ByteProvider byteProvider, FileSystemService fsService, TaskMonitor monitor) throws IOException, CancelledException Description copied from interface:GFileSystemProbeByteProviderProbes the specifiedByteProviderto determine if this filesystem implementation can handle the file.- Specified by:
probein interfaceGFileSystemProbeByteProvider- Parameters:
byteProvider- aByteProvidercontaining the contents of the file being probed. Implementors of this method should NOTclose()this object.fsService- a reference to theFileSystemServiceobjectmonitor- aTaskMonitorthat should be polled to see if the user has requested to cancel the operation, and updated with progress information.- Returns:
trueif the specified file is handled by this filesystem implementation,falseif not.- Throws:
IOException- if there is an error reading files.CancelledException- if the user cancels
-
create
public GFileSystemBase create(FSRLRoot targetFSRL, ByteProvider byteProvider, FileSystemService fsService, TaskMonitor monitor) throws IOException, CancelledException Description copied from interface:GFileSystemFactoryByteProviderConstructs a newGFileSysteminstance that handles the specified file.- Specified by:
createin interfaceGFileSystemFactoryByteProvider<GFileSystemBase>- Parameters:
targetFSRL- theFSRLRootof the filesystem being created.byteProvider- aByteProvidercontaining the contents of the file being probed. This method is responsible for closing this byte provider instance.fsService- a reference to theFileSystemServiceobjectmonitor- aTaskMonitorthat should be polled to see if the user has requested to cancel the operation, and updated with progress information.- Returns:
- a new
GFileSystemderived instance. - Throws:
IOException- if there is an error reading files.CancelledException- if the user cancels
-