207 lines
8.6 KiB
C
Raw Normal View History

2017-10-12 21:50:56 +07:00
/*
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at
* your option) any later version.
*
* This program 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
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* In addition, as a special exception, the author gives permission to
* link the code of this program with the Half-Life Game Engine ("HL
* Engine") and Modified Game Libraries ("MODs") developed by Valve,
* L.L.C ("Valve"). You must obey the GNU General Public License in all
* respects for all of the code used other than the HL Engine and MODs
* from Valve. If you modify this file, you may extend this exception
* to your version of the file, but you are not obligated to do so. If
* you do not wish to do so, delete this exception statement from your
* version.
*
*/
2015-06-30 15:46:07 +06:00
#pragma once
#include "interface.h"
#include <stdio.h>
#include <stdlib.h>
2017-10-12 21:50:56 +07:00
// There is only one instance of the IFileSystem interface,
// located in the filesystem_stdio library (filesystem_steam is obsolete).
#ifdef _WIN32
#define STDIO_FILESYSTEM_LIB "filesystem_stdio.dll"
#define STEAM_FILESYSTEM_LIB "filesystem_steam.dll"
#else
#define STDIO_FILESYSTEM_LIB "filesystem_stdio.so"
#define STEAM_FILESYSTEM_LIB "filesystem_steam.so"
#endif // _WIN32
2015-06-30 15:46:07 +06:00
// Forward declarations
2017-10-12 21:50:56 +07:00
typedef FILE *FileHandle_t;
2015-06-30 15:46:07 +06:00
typedef int FileFindHandle_t;
typedef int WaitForResourcesHandle_t;
2017-10-12 21:50:56 +07:00
typedef void (*WarningFunc_t)(const char *fmt, ...);
2015-06-30 15:46:07 +06:00
// Enums used by the interface
#ifndef FILESYSTEM_INTERNAL_H
typedef enum
{
FILESYSTEM_SEEK_HEAD = 0,
FILESYSTEM_SEEK_CURRENT,
FILESYSTEM_SEEK_TAIL,
} FileSystemSeek_t;
enum
{
FILESYSTEM_INVALID_FIND_HANDLE = -1
};
typedef enum
{
2017-10-12 21:50:56 +07:00
FILESYSTEM_WARNING_QUIET = 0, // Don't print anything
FILESYSTEM_WARNING_REPORTUNCLOSED, // On shutdown, report names of files left unclosed
FILESYSTEM_WARNING_REPORTUSAGE, // Report number of times a file was opened, closed
FILESYSTEM_WARNING_REPORTALLACCESSES // Report all open/close events to console (!slow!)
2015-06-30 15:46:07 +06:00
} FileWarningLevel_t;
2017-10-12 21:50:56 +07:00
#define FILESYSTEM_INVALID_HANDLE (FileHandle_t)0
#endif // FILESYSTEM_INTERNAL_H
2015-06-30 15:46:07 +06:00
// turn off any windows defines
#undef GetCurrentDirectory
// Purpose: Main file system interface
class IFileSystem : public IBaseInterface
{
public:
// Mount and unmount the filesystem
2017-10-12 21:50:56 +07:00
virtual void Mount() = 0;
virtual void Unmount() = 0;
2015-06-30 15:46:07 +06:00
// Remove all search paths (including write path?)
2017-10-12 21:50:56 +07:00
virtual void RemoveAllSearchPaths() = 0;
2015-06-30 15:46:07 +06:00
// Add paths in priority order (mod dir, game dir, ....)
// If one or more .pak files are in the specified directory, then they are
// added after the file system path
2017-10-12 21:50:56 +07:00
// If the path is the relative path to a .bsp file, then any previous .bsp file
2015-06-30 15:46:07 +06:00
// override is cleared and the current .bsp is searched for an embedded PAK file
2017-10-12 21:50:56 +07:00
// and this file becomes the highest priority search path (i.e., it's looked at first
// even before the mod's file system path).
virtual void AddSearchPath(const char *pPath, const char *pathID) = 0;
virtual bool RemoveSearchPath(const char *pPath) = 0;
2015-06-30 15:46:07 +06:00
// Deletes a file
2017-10-12 21:50:56 +07:00
virtual void RemoveFile(const char *pRelativePath, const char *pathID) = 0;
2015-06-30 15:46:07 +06:00
// this isn't implementable on STEAM as is.
2017-10-12 21:50:56 +07:00
virtual void CreateDirHierarchy(const char *path, const char *pathID) = 0;
2015-06-30 15:46:07 +06:00
// File I/O and info
2017-10-12 21:50:56 +07:00
virtual bool FileExists(const char *pFileName) = 0;
virtual bool IsDirectory(const char *pFileName) = 0;
2015-06-30 15:46:07 +06:00
// opens a file
// if pathID is NULL, all paths will be searched for the file
2017-10-12 21:50:56 +07:00
virtual FileHandle_t Open(const char *pFileName, const char *pOptions, const char *pathID = 0L) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual void Close(FileHandle_t file) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual void Seek(FileHandle_t file, int pos, FileSystemSeek_t seekType) = 0;
virtual unsigned int Tell(FileHandle_t file) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual unsigned int Size(FileHandle_t file) = 0;
virtual unsigned int Size(const char *pFileName) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual long GetFileTime(const char *pFileName) = 0;
virtual void FileTimeToString(char *pStrip, int maxCharsIncludingTerminator, long fileTime) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual bool IsOk(FileHandle_t file) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual void Flush(FileHandle_t file) = 0;
virtual bool EndOfFile(FileHandle_t file) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual int Read(void *pOutput, int size, FileHandle_t file) = 0;
virtual int Write(void const *pInput, int size, FileHandle_t file) = 0;
virtual char *ReadLine(char *pOutput, int maxChars, FileHandle_t file) = 0;
virtual int FPrintf(FileHandle_t file, char *pFormat, ...) = 0;
2015-06-30 15:46:07 +06:00
// direct filesystem buffer access
// returns a handle to a buffer containing the file data
2017-10-12 21:50:56 +07:00
// this is the optimal way to access the complete data for a file,
2015-06-30 15:46:07 +06:00
// since the file preloader has probably already got it in memory
2017-10-12 21:50:56 +07:00
virtual void *GetReadBuffer(FileHandle_t file, int *outBufferSize, bool failIfNotInCache) = 0;
virtual void ReleaseReadBuffer(FileHandle_t file, void *readBuffer) = 0;
2015-06-30 15:46:07 +06:00
// FindFirst/FindNext
2017-10-12 21:50:56 +07:00
virtual const char *FindFirst(const char *pWildCard, FileFindHandle_t *pHandle, const char *pathID = 0L) = 0;
virtual const char *FindNext(FileFindHandle_t handle) = 0;
virtual bool FindIsDirectory(FileFindHandle_t handle) = 0;
virtual void FindClose(FileFindHandle_t handle) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual void GetLocalCopy(const char *pFileName) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
virtual const char *GetLocalPath(const char *pFileName, char *pLocalPath, int localPathBufferSize) = 0;
2015-06-30 15:46:07 +06:00
// Note: This is sort of a secondary feature; but it's really useful to have it here
2017-10-12 21:50:56 +07:00
virtual char *ParseFile(char *pFileBytes, char *pToken, bool *pWasQuoted) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
// Returns true on success (based on current list of search paths, otherwise false if it can't be resolved)
virtual bool FullPathToRelativePath(const char *pFullpath, char *pRelative) = 0;
2015-06-30 15:46:07 +06:00
// Gets the current working directory
2017-10-12 21:50:56 +07:00
virtual bool GetCurrentDirectory(char *pDirectory, int maxlen) = 0;
2015-06-30 15:46:07 +06:00
// Dump to printf/OutputDebugString the list of files that have not been closed
2017-10-12 21:50:56 +07:00
virtual void PrintOpenedFiles() = 0;
virtual void SetWarningFunc(WarningFunc_t pfnWarning) = 0;
virtual void SetWarningLevel(FileWarningLevel_t level) = 0;
virtual void LogLevelLoadStarted(const char *name) = 0;
virtual void LogLevelLoadFinished(const char *name) = 0;
virtual int HintResourceNeed(const char *hintlist, int forgetEverything) = 0;
virtual int PauseResourcePreloading() = 0;
virtual int ResumeResourcePreloading() = 0;
virtual int SetVBuf(FileHandle_t stream, char *buffer, int mode, long size) = 0;
virtual void GetInterfaceVersion(char *p, int maxlen) = 0;
2015-06-30 15:46:07 +06:00
virtual bool IsFileImmediatelyAvailable(const char *pFileName) = 0;
// starts waiting for resources to be available
// returns FILESYSTEM_INVALID_HANDLE if there is nothing to wait on
2017-10-12 21:50:56 +07:00
virtual WaitForResourcesHandle_t WaitForResources(const char *resourcelist) = 0;
2015-06-30 15:46:07 +06:00
// get progress on waiting for resources; progress is a float [0, 1], complete is true on the waiting being done
// returns false if no progress is available
// any calls after complete is true or on an invalid handle will return false, 0.0f, true
2017-10-12 21:50:56 +07:00
virtual bool GetWaitForResourcesProgress(WaitForResourcesHandle_t handle, float *progress /* out */ , bool *complete /* out */) = 0;
2015-06-30 15:46:07 +06:00
// cancels a progress call
2017-10-12 21:50:56 +07:00
virtual void CancelWaitForResources(WaitForResourcesHandle_t handle) = 0;
2015-06-30 15:46:07 +06:00
// returns true if the appID has all its caches fully preloaded
2017-10-12 21:50:56 +07:00
virtual bool IsAppReadyForOfflinePlay(int appID) = 0;
2015-06-30 15:46:07 +06:00
// interface for custom pack files > 4Gb
2017-10-12 21:50:56 +07:00
virtual bool AddPackFile(const char *fullpath, const char *pathID) = 0;
2015-06-30 15:46:07 +06:00
2017-10-12 21:50:56 +07:00
// open a file but force the data to come from the steam cache, NOT from disk
virtual FileHandle_t OpenFromCacheForRead(const char *pFileName, const char *pOptions, const char *pathID = 0L) = 0;
virtual void AddSearchPathNoWrite(const char *pPath, const char *pathID) = 0;
2015-06-30 15:46:07 +06:00
};
// Steam3/Src compat
#define IBaseFileSystem IFileSystem
#define FILESYSTEM_INTERFACE_VERSION "VFileSystem009"
bool FileSystem_Init();
void FileSystem_Shutdown();
extern IBaseFileSystem *g_pFileSystem;