fileio_func.h File Reference

Functions for Standard In/Out file operations. More...

#include "fileio_type.h"
#include <sys/types.h>
#include <dirent.h>

Go to the source code of this file.

Data Structures

class  FileScanner
 Helper for scanning for files with a given name. More...

Defines

#define FOR_ALL_SEARCHPATHS(sp)   for (sp = SP_FIRST_DIR; sp < NUM_SEARCHPATHS; sp++) if (IsValidSearchPath(sp))
 Iterator for all the search paths.

Functions

void FioSeekTo (size_t pos, int mode)
void FioSeekToFile (uint8 slot, size_t pos)
size_t FioGetPos ()
const char * FioGetFilename (uint8 slot)
byte FioReadByte ()
uint16 FioReadWord ()
uint32 FioReadDword ()
void FioCloseAll ()
void FioOpenFile (int slot, const char *filename)
void FioReadBlock (void *ptr, size_t size)
void FioSkipBytes (int n)
void FioCreateDirectory (const char *filename)
 Create a directory with the given name.
static bool IsValidSearchPath (Searchpath sp)
 Checks whether the given search path is a valid search path.
void FioFCloseFile (FILE *f)
 Close a file in a safe way.
FILE * FioFOpenFile (const char *filename, const char *mode="rb", Subdirectory subdir=DATA_DIR, size_t *filesize=NULL)
 Opens OpenTTD files somewhere in a personal or global directory.
bool FioCheckFileExists (const char *filename, Subdirectory subdir=DATA_DIR)
 Check whether the given file exists.
char * FioGetFullPath (char *buf, size_t buflen, Searchpath sp, Subdirectory subdir, const char *filename)
char * FioFindFullPath (char *buf, size_t buflen, Subdirectory subdir, const char *filename)
char * FioAppendDirectory (char *buf, size_t buflen, Searchpath sp, Subdirectory subdir)
char * FioGetDirectory (char *buf, size_t buflen, Subdirectory subdir)
static const char * FioGetSubdirectory (Subdirectory subdir)
void SanitizeFilename (char *filename)
 Sanitizes a filename, i.e.
void AppendPathSeparator (char *buf, size_t buflen)
 Appends, if necessary, the path separator character to the end of the string.
void DeterminePaths (const char *exe)
 Acquire the base paths (personal dir and game data dir), fill all other paths (save dir, autosave dir etc) and make the save and scenario directories.
void * ReadFileToMem (const char *filename, size_t *lenp, size_t maxsize)
bool FileExists (const char *filename)
const char * FioTarFirstDir (const char *tarname)
void FioTarAddLink (const char *src, const char *dest)
static DIR * ttd_opendir (const char *path)
 A wrapper around opendir() which will convert the string from OPENTTD encoding to that of the filesystem.

Variables

const char * _searchpaths [NUM_SEARCHPATHS]
 The searchpaths OpenTTD could search through.
char * _personal_dir
 custom directory for personal settings, saves, newgrf, etc.


Detailed Description

Functions for Standard In/Out file operations.

Definition in file fileio_func.h.


Function Documentation

void AppendPathSeparator ( char *  buf,
size_t  buflen 
)

Appends, if necessary, the path separator character to the end of the string.

It does not add the path separator to zero-sized strings.

Parameters:
buf string to append the separator to
buflen the length of the buf

Definition at line 432 of file fileio.cpp.

Referenced by BuildWithFullPath(), DetermineBasePaths(), FileScanner::Scan(), and ScanPath().

void DeterminePaths ( const char *  exe  ) 

Acquire the base paths (personal dir and game data dir), fill all other paths (save dir, autosave dir etc) and make the save and scenario directories.

Parameters:
exe the path from the current path to the executable

Definition at line 894 of file fileio.cpp.

References AI_DIR, AI_LIBRARY_DIR, AUTOSAVE_DIR, BASE_DIR, DATA_DIR, DetermineBasePaths(), FioCreateDirectory(), FOR_ALL_SEARCHPATHS, HEIGHTMAP_DIR, IsValidSearchPath(), lengthof, SAVE_DIR, SCENARIO_DIR, SP_AUTODOWNLOAD_DIR, SP_BINARY_DIR, SP_INSTALLATION_DIR, SP_PERSONAL_DIR, SP_SHARED_DIR, and SP_WORKING_DIR.

bool FioCheckFileExists ( const char *  filename,
Subdirectory  subdir 
)

Check whether the given file exists.

Parameters:
filename the file to try for existance
subdir the subdirectory to look in
Returns:
true if and only if the file can be opened

Definition at line 234 of file fileio.cpp.

References FioFCloseFile(), and FioFOpenFile().

void FioCreateDirectory ( const char *  name  ) 

Create a directory with the given name.

Parameters:
name the new name of the directory

Definition at line 405 of file fileio.cpp.

References OTTD2FS(), and ttd_strlcpy().

Referenced by DeterminePaths().

static bool IsValidSearchPath ( Searchpath  sp  )  [inline, static]

Checks whether the given search path is a valid search path.

Parameters:
sp the search path to check
Returns:
true if the search path is valid

Definition at line 36 of file fileio_func.h.

References _searchpaths.

Referenced by DeterminePaths().

void SanitizeFilename ( char *  filename  ) 

Sanitizes a filename, i.e.

removes all illegal characters from it.

Parameters:
filename the "\0" terminated filename

Definition at line 981 of file fileio.cpp.

Referenced by GenerateDefaultSaveName().

static DIR* ttd_opendir ( const char *  path  )  [inline, static]

A wrapper around opendir() which will convert the string from OPENTTD encoding to that of the filesystem.

For all purposes this function behaves the same as the original opendir function

Parameters:
path string to open directory of
Returns:
DIR pointer

Definition at line 132 of file fileio_func.h.

References OTTD2FS().

Referenced by FiosGetFileList(), GetLanguageList(), and ScanPath().


Variable Documentation

const char* _searchpaths[NUM_SEARCHPATHS]

The searchpaths OpenTTD could search through.

At least one of the slots has to be filled with a path. NULL paths tell that there is no such path for the current operating system.

Definition at line 221 of file fileio.cpp.

Referenced by IsValidSearchPath().


Generated on Thu Oct 1 11:03:21 2009 for OpenTTD by  doxygen 1.5.6