You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.9 KiB
53 lines
1.9 KiB
//========= Copyright Valve Corporation, All rights reserved. ============//
|
|
//
|
|
// Purpose:
|
|
//
|
|
// $NoKeywords: $
|
|
//=============================================================================//
|
|
|
|
#ifndef VMPI_FILESYSTEM_H
|
|
#define VMPI_FILESYSTEM_H
|
|
#ifdef _WIN32
|
|
#pragma once
|
|
#endif
|
|
|
|
|
|
#include "interface.h"
|
|
|
|
|
|
class IFileSystem;
|
|
class MessageBuffer;
|
|
|
|
|
|
// Use this to read virtual files.
|
|
#define VMPI_VIRTUAL_FILES_PATH_ID "VMPI_VIRTUAL_FILES_PATH_ID"
|
|
|
|
|
|
// When you hook the file system with VMPI and are a worker, it blocks on file reads
|
|
// and uses MPI to communicate with the master to transfer files it needs over.
|
|
//
|
|
// The filesystem, by default (and it maxFileSystemMemoryUsage is left at zero),
|
|
// keeps the contents of the files that get opened in memory. You can pass in a
|
|
// value here to put a cap on it, in which case it'll unload the least-recently-used
|
|
// files when it hits the limit.
|
|
IFileSystem* VMPI_FileSystem_Init( int maxFileSystemMemoryUsage, IFileSystem *pPassThru );
|
|
|
|
// On the master machine, this really should be called before the app shuts down and
|
|
// global destructors are called. If it isn't, it might lock up waiting for a thread to exit.
|
|
//
|
|
// This returns the original filesystem you passed into VMPI_FileSystem_Init so you can uninitialize it.
|
|
IFileSystem* VMPI_FileSystem_Term();
|
|
|
|
// Causes it to error out on any Open() calls.
|
|
void VMPI_FileSystem_DisableFileAccess();
|
|
|
|
// Returns a factory that will hand out BASEFILESYSTEM_INTERFACE_VERSION when asked for it.
|
|
CreateInterfaceFn VMPI_FileSystem_GetFactory();
|
|
|
|
// This function creates a virtual file that workers can then open and read out of.
|
|
// NOTE: when reading from the file, you must use VMPI_VIRTUAL_FILES_PATH_ID as the path ID
|
|
// or else it won't find the file.
|
|
void VMPI_FileSystem_CreateVirtualFile( const char *pFilename, const void *pData, unsigned long fileLength );
|
|
|
|
|
|
#endif // VMPI_FILESYSTEM_H
|