fix windows compile, it's possible the linux build broke and will need misc tweaks. you need a new GtkR-1.6-deps.zip

git-svn-id: svn://svn.icculus.org/gtkradiant/GtkRadiant/branches/ZeroRadiant@227 8a3a26a2-13c4-0310-b231-cf6edde360e5
This commit is contained in:
TTimo 2008-03-18 17:47:38 +00:00
parent ceb4f7d969
commit 94199c49dc
9 changed files with 2403 additions and 695 deletions

View file

@ -34,40 +34,31 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// NOTE TTimo // NOTE TTimo
// this goes along with str.h and provides various utility classes // this goes along with str.h and provides various utility classes
// and portability defines // and portability defines
// the filename is a legecy issue, it would be better to clean that up // the file name (missing.h) is a legacy issue, it would be better to clean that up
// in a central 'portability' lib // in a central 'portability' lib
#include <glib.h> #include <glib.h>
#include <string.h> #include <string.h>
#ifdef _WIN32 #ifdef _WIN32
#include <windows.h>
#include <direct.h> #include <direct.h>
#include <io.h> #include <io.h>
#include <sys/types.h>
#include <sys/stat.h>
#define MyCopyFile(a,b) CopyFile(a,b,FALSE)
#define S_ISDIR(mode) (mode & _S_IFDIR)
#define R_OK 04 #define R_OK 04
#define mymkdir(a,b) _mkdir(a)
#else #else // !_WIN32
#define MyCopyFile CopyFile
#define mymkdir(a,b) mkdir(a,b)
#endif
#ifndef _WIN32
// LZ: very ugly hacks // LZ: very ugly hacks
inline int GetLastError () { return 0; }; inline int GetLastError() { return 0; };
// temp stuff // temp stuff
inline int GetPrivateProfileInt(char* a, char* b, int i, char* c) { return i; }; inline int GetPrivateProfileInt(char* a, char* b, int i, char* c) { return i; };
#define VERIFY(a) a; #define VERIFY(a) a;
int GetFullPathName(const char *lpFileName, int nBufferLength, char *lpBuffer, char **lpFilePart); int GetFullPathName(const char *lpFileName, int nBufferLength, char *lpBuffer, char **lpFilePart);
bool CopyFile(const char *lpExistingFileName, const char *lpNewFileName);
bool CopyTree( const char* source, const char* dest );
#ifndef APIENTRY #ifndef APIENTRY
#define APIENTRY #define APIENTRY
@ -210,4 +201,33 @@ protected:
}; };
}; };
class FindFiles {
public:
FindFiles( const char *directory );
~FindFiles();
const char* NextFile();
private:
#ifdef _WIN32
Str directory;
HANDLE findHandle;
WIN32_FIND_DATA findFileData;
#else
#endif
};
bool CopyTree( const char* source, const char* dest );
typedef enum {
PATH_FAIL, // stat call failed (does not exist is likely)
PATH_DIRECTORY,
PATH_FILE
} EPathCheck;
// check a path for existence, return directory / file
EPathCheck CheckFile( const char *path );
bool radCreateDirectory( const char *directory );
bool radCopyFile( const char *lpExistingFileName, const char *lpNewFileName );
#endif // _MISSING_H_ #endif // _MISSING_H_

View file

@ -29,10 +29,9 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#define BMP_SIGNATURE_WORD 0x4d42 #define BMP_SIGNATURE_WORD 0x4d42
#pragma pack(push)
#pragma pack(1) #pragma pack(1)
typedef struct { typedef struct {
unsigned short bfType; // signature - 'BM' unsigned short bfType; // signature - 'BM'
unsigned long bfSize; // file size in bytes unsigned long bfSize; // file size in bytes
@ -96,6 +95,6 @@ void FreeBMP(bitmap_t *bitmap);
void WriteBMP(char *filename, bitmap_t *bit); void WriteBMP(char *filename, bitmap_t *bit);
void NewBMP(int width, int height, int bpp, bitmap_t *bit); void NewBMP(int width, int height, int bpp, bitmap_t *bit);
#pragma pack(pop)
#endif #endif

View file

@ -1,77 +1,243 @@
<?xml version="1.0" ?><VisualStudioProject Name="image" ProjectGUID="{1F9977F6-216F-4AE1-9928-59B72CF31C46}" ProjectType="Visual C++" RootNamespace="image" Version="8.00"> <?xml version="1.0" encoding="Windows-1252"?>
<VisualStudioProject
ProjectType="Visual C++"
Version="8.00"
Name="image"
ProjectGUID="{1F9977F6-216F-4AE1-9928-59B72CF31C46}"
RootNamespace="image"
>
<Platforms> <Platforms>
<Platform Name="Win32"/> <Platform
Name="Win32"
/>
</Platforms> </Platforms>
<ToolFiles> <ToolFiles>
</ToolFiles> </ToolFiles>
<Configurations> <Configurations>
<Configuration CharacterSet="2" ConfigurationType="2" IntermediateDirectory="$(SolutionDir)\build\intermediate\$(ConfigurationName)\$(ProjectName)" Name="Debug|Win32" OutputDirectory="$(SolutionDir)\build\$(ConfigurationName)\modules"> <Configuration
<Tool Name="VCPreBuildEventTool"/> Name="Debug|Win32"
<Tool Name="VCCustomBuildTool"/> OutputDirectory="$(SolutionDir)\build\$(ConfigurationName)\modules"
<Tool Name="VCXMLDataGeneratorTool"/> IntermediateDirectory="$(SolutionDir)\build\intermediate\$(ConfigurationName)\$(ProjectName)"
<Tool Name="VCWebServiceProxyGeneratorTool"/> ConfigurationType="2"
<Tool Name="VCMIDLTool"/> CharacterSet="2"
<Tool AdditionalIncludeDirectories="&quot;$(SolutionDir)\include&quot;;&quot;$(SolutionDir)\libs&quot;;&quot;$(SolutionDir)\..\STLPort\stlport&quot;;&quot;$(SolutionDir)\..\gtk2\include&quot;;&quot;$(SolutionDir)\..\gtk2\include\glib-2.0&quot;;&quot;$(SolutionDir)\..\gtk2\lib\glib-2.0\include&quot;;&quot;$(SolutionDir)\..\libxml2\include&quot;" BasicRuntimeChecks="3" DebugInformationFormat="4" Detect64BitPortabilityProblems="true" DisableSpecificWarnings="4996;4244;4267" MinimalRebuild="true" Name="VCCLCompilerTool" Optimization="0" PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS" RuntimeLibrary="3" WarningLevel="3"/> >
<Tool Name="VCManagedResourceCompilerTool"/> <Tool
<Tool Name="VCResourceCompilerTool"/> Name="VCPreBuildEventTool"
<Tool Name="VCPreLinkEventTool"/> />
<Tool AdditionalDependencies="jpeg6.lib synapse.lib libxml2.lib glib-2.0.lib gobject-2.0.lib" AdditionalLibraryDirectories="&quot;$(SolutionDir)\..\libxml2\lib&quot;;&quot;$(SolutionDir)\..\gtk2\lib&quot;;&quot;$(SolutionDir)\build\$(ConfigurationName)\libs&quot;" GenerateDebugInformation="true" ModuleDefinitionFile="image.def" Name="VCLinkerTool" TargetMachine="1"/> <Tool
<Tool Name="VCALinkTool"/> Name="VCCustomBuildTool"
<Tool Name="VCManifestTool"/> />
<Tool Name="VCXDCMakeTool"/> <Tool
<Tool Name="VCBscMakeTool"/> Name="VCXMLDataGeneratorTool"
<Tool Name="VCFxCopTool"/> />
<Tool Name="VCAppVerifierTool"/> <Tool
<Tool Name="VCWebDeploymentTool"/> Name="VCWebServiceProxyGeneratorTool"
<Tool Name="VCPostBuildEventTool"/> />
<Tool
Name="VCMIDLTool"
/>
<Tool
Name="VCCLCompilerTool"
Optimization="0"
AdditionalIncludeDirectories="&quot;$(SolutionDir)\include&quot;;&quot;$(SolutionDir)\libs&quot;;&quot;$(SolutionDir)\..\STLPort\stlport&quot;;&quot;$(SolutionDir)\..\gtk2\include&quot;;&quot;$(SolutionDir)\..\gtk2\include\glib-2.0&quot;;&quot;$(SolutionDir)\..\gtk2\lib\glib-2.0\include&quot;;&quot;$(SolutionDir)\..\libxml2\include&quot;"
PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS"
MinimalRebuild="true"
BasicRuntimeChecks="3"
RuntimeLibrary="3"
WarningLevel="3"
Detect64BitPortabilityProblems="true"
DebugInformationFormat="4"
DisableSpecificWarnings="4996;4244;4267"
/>
<Tool
Name="VCManagedResourceCompilerTool"
/>
<Tool
Name="VCResourceCompilerTool"
/>
<Tool
Name="VCPreLinkEventTool"
/>
<Tool
Name="VCLinkerTool"
AdditionalDependencies=" synapse.lib libxml2.lib glib-2.0.lib gobject-2.0.lib libjpeg.lib"
AdditionalLibraryDirectories="&quot;$(SolutionDir)\..\libxml2\lib&quot;;&quot;$(SolutionDir)\..\gtk2\lib&quot;;&quot;$(SolutionDir)\build\$(ConfigurationName)\libs&quot;;&quot;$(SolutionDir)\..\jpeg-6b&quot;"
ModuleDefinitionFile="image.def"
GenerateDebugInformation="true"
TargetMachine="1"
/>
<Tool
Name="VCALinkTool"
/>
<Tool
Name="VCManifestTool"
/>
<Tool
Name="VCXDCMakeTool"
/>
<Tool
Name="VCBscMakeTool"
/>
<Tool
Name="VCFxCopTool"
/>
<Tool
Name="VCAppVerifierTool"
/>
<Tool
Name="VCWebDeploymentTool"
/>
<Tool
Name="VCPostBuildEventTool"
/>
</Configuration> </Configuration>
<Configuration CharacterSet="2" ConfigurationType="2" IntermediateDirectory="$(SolutionDir)\build\intermediate\$(ConfigurationName)\$(ProjectName)" Name="Release|Win32" OutputDirectory="$(SolutionDir)\build\$(ConfigurationName)\modules" WholeProgramOptimization="1"> <Configuration
<Tool Name="VCPreBuildEventTool"/> Name="Release|Win32"
<Tool Name="VCCustomBuildTool"/> OutputDirectory="$(SolutionDir)\build\$(ConfigurationName)\modules"
<Tool Name="VCXMLDataGeneratorTool"/> IntermediateDirectory="$(SolutionDir)\build\intermediate\$(ConfigurationName)\$(ProjectName)"
<Tool Name="VCWebServiceProxyGeneratorTool"/> ConfigurationType="2"
<Tool Name="VCMIDLTool"/> CharacterSet="2"
<Tool AdditionalIncludeDirectories="&quot;$(SolutionDir)\include&quot;;&quot;$(SolutionDir)\libs&quot;;&quot;$(SolutionDir)\..\STLPort\stlport&quot;;&quot;$(SolutionDir)\..\gtk2\include&quot;;&quot;$(SolutionDir)\..\gtk2\include\glib-2.0&quot;;&quot;$(SolutionDir)\..\gtk2\lib\glib-2.0\include&quot;;&quot;$(SolutionDir)\..\libxml2\include&quot;" DebugInformationFormat="3" Detect64BitPortabilityProblems="true" DisableSpecificWarnings="4996;4244;4267" Name="VCCLCompilerTool" PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS" RuntimeLibrary="2" WarningLevel="3"/> WholeProgramOptimization="1"
<Tool Name="VCManagedResourceCompilerTool"/> >
<Tool Name="VCResourceCompilerTool"/> <Tool
<Tool Name="VCPreLinkEventTool"/> Name="VCPreBuildEventTool"
<Tool AdditionalDependencies="jpeg6.lib synapse.lib libxml2.lib glib-2.0.lib gobject-2.0.lib" AdditionalLibraryDirectories="&quot;$(SolutionDir)\..\libxml2\lib&quot;;&quot;$(SolutionDir)\..\gtk2\lib&quot;;&quot;$(SolutionDir)\build\$(ConfigurationName)\libs&quot;" EnableCOMDATFolding="2" GenerateDebugInformation="true" ModuleDefinitionFile="image.def" Name="VCLinkerTool" OptimizeReferences="2" TargetMachine="1"/> />
<Tool Name="VCALinkTool"/> <Tool
<Tool Name="VCManifestTool"/> Name="VCCustomBuildTool"
<Tool Name="VCXDCMakeTool"/> />
<Tool Name="VCBscMakeTool"/> <Tool
<Tool Name="VCFxCopTool"/> Name="VCXMLDataGeneratorTool"
<Tool Name="VCAppVerifierTool"/> />
<Tool Name="VCWebDeploymentTool"/> <Tool
<Tool Name="VCPostBuildEventTool"/> Name="VCWebServiceProxyGeneratorTool"
/>
<Tool
Name="VCMIDLTool"
/>
<Tool
Name="VCCLCompilerTool"
AdditionalIncludeDirectories="&quot;$(SolutionDir)\include&quot;;&quot;$(SolutionDir)\libs&quot;;&quot;$(SolutionDir)\..\STLPort\stlport&quot;;&quot;$(SolutionDir)\..\gtk2\include&quot;;&quot;$(SolutionDir)\..\gtk2\include\glib-2.0&quot;;&quot;$(SolutionDir)\..\gtk2\lib\glib-2.0\include&quot;;&quot;$(SolutionDir)\..\libxml2\include&quot;"
PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS"
RuntimeLibrary="2"
WarningLevel="3"
Detect64BitPortabilityProblems="true"
DebugInformationFormat="3"
DisableSpecificWarnings="4996;4244;4267"
/>
<Tool
Name="VCManagedResourceCompilerTool"
/>
<Tool
Name="VCResourceCompilerTool"
/>
<Tool
Name="VCPreLinkEventTool"
/>
<Tool
Name="VCLinkerTool"
AdditionalDependencies="synapse.lib libxml2.lib glib-2.0.lib gobject-2.0.lib libjpeg.lib"
AdditionalLibraryDirectories="&quot;$(SolutionDir)\..\libxml2\lib&quot;;&quot;$(SolutionDir)\..\gtk2\lib&quot;;&quot;$(SolutionDir)\build\$(ConfigurationName)\libs&quot;;&quot;$(SolutionDir)\..\jpeg-6b&quot;"
ModuleDefinitionFile="image.def"
GenerateDebugInformation="true"
OptimizeReferences="2"
EnableCOMDATFolding="2"
TargetMachine="1"
/>
<Tool
Name="VCALinkTool"
/>
<Tool
Name="VCManifestTool"
/>
<Tool
Name="VCXDCMakeTool"
/>
<Tool
Name="VCBscMakeTool"
/>
<Tool
Name="VCFxCopTool"
/>
<Tool
Name="VCAppVerifierTool"
/>
<Tool
Name="VCWebDeploymentTool"
/>
<Tool
Name="VCPostBuildEventTool"
/>
</Configuration> </Configuration>
</Configurations> </Configurations>
<References> <References>
</References> </References>
<Files> <Files>
<Filter Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat;f90;for;f;fpp" Name="Source Files"> <Filter
<File RelativePath=".\bmp.cpp"> Name="Source Files"
Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat;f90;for;f;fpp"
>
<File
RelativePath=".\bmp.cpp"
>
</File> </File>
<File RelativePath=".\image.cpp"> <File
RelativePath=".\image.cpp"
>
</File> </File>
<File RelativePath=".\image.def"> <File
RelativePath=".\image.def"
>
</File> </File>
<File RelativePath=".\jpeg.cpp"> <File
RelativePath=".\jpeg.cpp"
>
<FileConfiguration
Name="Debug|Win32"
>
<Tool
Name="VCCLCompilerTool"
AdditionalIncludeDirectories="&quot;$(SolutionDir)\..\jpeg-6b&quot;"
/>
</FileConfiguration>
<FileConfiguration
Name="Release|Win32"
>
<Tool
Name="VCCLCompilerTool"
AdditionalIncludeDirectories="&quot;$(SolutionDir)\..\jpeg-6b&quot;"
/>
</FileConfiguration>
</File> </File>
<File RelativePath=".\lbmlib.cpp"> <File
RelativePath=".\lbmlib.cpp"
>
</File> </File>
</Filter> </Filter>
<Filter Filter="h;hpp;hxx;hm;inl;fi;fd" Name="Header Files"> <Filter
<File RelativePath=".\bmp.h"> Name="Header Files"
Filter="h;hpp;hxx;hm;inl;fi;fd"
>
<File
RelativePath=".\bmp.h"
>
</File> </File>
<File RelativePath=".\image.h"> <File
RelativePath=".\image.h"
>
</File> </File>
<File RelativePath="..\..\libs\jpeglib.h"> <File
RelativePath="..\..\libs\jpeglib.h"
>
</File> </File>
<File RelativePath=".\lbmlib.h"> <File
RelativePath=".\lbmlib.h"
>
</File> </File>
</Filter> </Filter>
<Filter Filter="ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe" Name="Resource Files"> <Filter
Name="Resource Files"
Filter="ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe"
>
</Filter> </Filter>
</Files> </Files>
<Globals> <Globals>

View file

@ -34,14 +34,16 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Leonardo Zide (leo@lokigames.com) // Leonardo Zide (leo@lokigames.com)
// //
#include <stdio.h>
#include <setjmp.h> #include <setjmp.h>
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h>
#include <string.h> #include <string.h>
#include <glib.h> #include <glib.h>
extern "C" {
#include <jpeglib.h> #include <jpeglib.h>
#include <jerror.h> #include <jerror.h>
}
#include "image.h" #include "image.h"

View file

@ -34,7 +34,9 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Leonardo Zide (leo@lokigames.com) // Leonardo Zide (leo@lokigames.com)
// //
// FIXME: compile on Windows as well #include "missing.h"
#include "qsysprintf.h"
#if defined (__linux__) || defined (__APPLE__) #if defined (__linux__) || defined (__APPLE__)
#include <stdio.h> #include <stdio.h>
@ -44,10 +46,8 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <dirent.h> #include <dirent.h>
#include "missing.h"
#include "qsysprintf.h"
bool CopyFile(const char *lpExistingFileName, const char *lpNewFileName) bool radCopyFile(const char *lpExistingFileName, const char *lpNewFileName)
{ {
FILE *src, *dst; FILE *src, *dst;
void* buf; void* buf;
@ -85,7 +85,7 @@ bool CopyFile(const char *lpExistingFileName, const char *lpNewFileName)
return ret; return ret;
} }
bool CreateDirectory( const char *directory ) { bool radCreateDirectory( const char *directory ) {
if ( mkdir( directory, 0777 ) == -1 ) { if ( mkdir( directory, 0777 ) == -1 ) {
Sys_Printf( "mkdir %s failed\n", directory ); Sys_Printf( "mkdir %s failed\n", directory );
return false; return false;
@ -93,53 +93,6 @@ bool CreateDirectory( const char *directory ) {
return true; return true;
} }
bool CopyTree( const char *source, const char *dest ) {
DIR *dir;
struct dirent *dirlist;
struct stat sbuf;
Str srcEntry;
Str dstEntry;
dir = opendir( source );
if ( dir != NULL ) {
while ( ( dirlist = readdir( dir ) ) != NULL ) {
if ( strcmp( dirlist->d_name, "." ) == 0 || strcmp( dirlist->d_name, ".." ) == 0 ) {
continue;
}
if ( strcmp( dirlist->d_name, ".svn" ) == 0 ) {
continue;
}
srcEntry = source;
srcEntry += "/";
srcEntry += dirlist->d_name;
dstEntry = dest;
dstEntry += "/";
dstEntry += dirlist->d_name;
if ( stat( srcEntry.GetBuffer(), &sbuf ) == -1 ) {
Sys_Printf( "stat %s failed\n", srcEntry.GetBuffer() );
}
if ( S_ISDIR( sbuf.st_mode ) ) {
bool ret;
if ( stat( dstEntry.GetBuffer(), &sbuf ) == -1 ) {
ret = CreateDirectory( dstEntry.GetBuffer() );
}
ret = CopyTree( srcEntry.GetBuffer(), dstEntry.GetBuffer() );
if ( !ret ) {
return false;
}
} else {
Sys_Printf( "copy %s -> %s\n", srcEntry.GetBuffer(), dstEntry.GetBuffer() );
bool ret = CopyFile( srcEntry.GetBuffer(), dstEntry.GetBuffer() );
if ( !ret ) {
return false;
}
}
}
closedir( dir );
}
return true;
}
int GetFullPathName(const char *lpFileName, int nBufferLength, char *lpBuffer, char **lpFilePart) int GetFullPathName(const char *lpFileName, int nBufferLength, char *lpBuffer, char **lpFilePart)
{ {
if (lpFileName[0] == '/') if (lpFileName[0] == '/')
@ -178,4 +131,106 @@ int GetFullPathName(const char *lpFileName, int nBufferLength, char *lpBuffer, c
return strlen (lpBuffer); return strlen (lpBuffer);
} }
EPathCheck CheckFile( const char *path ) {
struct stat sbuf;
if ( stat( path, &sbuf ) == -1 ) {
return PATH_FAIL;
}
if ( S_ISDIR( sbuf.st_mode ) ) {
return PATH_DIRECTORY;
}
return PATH_FILE;
}
#else
FindFiles::FindFiles( const char *_directory ) {
directory = _directory;
findHandle = INVALID_HANDLE_VALUE;
}
FindFiles::~FindFiles() {
if ( findHandle != NULL ) {
FindClose( findHandle );
}
}
const char* FindFiles::NextFile() {
if ( findHandle == INVALID_HANDLE_VALUE ) {
findHandle = FindFirstFile( directory.GetBuffer(), &findFileData );
if ( findHandle == INVALID_HANDLE_VALUE ) {
return NULL;
}
return findFileData.cFileName;
}
if ( FindNextFile( findHandle, &findFileData ) == 0 ) {
FindClose( findHandle );
return NULL;
}
return findFileData.cFileName;
}
EPathCheck CheckFile( const char *path ) {
struct _stat sbuf;
if ( _stat( path, &sbuf ) == -1 ) {
return PATH_FAIL;
}
if ( ( sbuf.st_mode & _S_IFDIR ) != 0 ) {
return PATH_DIRECTORY;
}
return PATH_FILE;
}
bool radCreateDirectory( const char *directory ) {
return CreateDirectory( directory, NULL );
}
bool radCopyFile( const char *lpExistingFileName, const char *lpNewFileName ) {
return CopyFile( lpExistingFileName, lpNewFileName, FALSE );
}
#endif #endif
bool CopyTree( const char *source, const char *dest ) {
Str srcEntry;
Str dstEntry;
const char *dirname;
FindFiles fileScan( source );
while ( ( dirname = fileScan.NextFile() ) != NULL ) {
if ( strcmp( dirname, "." ) == 0 || strcmp( dirname, ".." ) == 0 ) {
continue;
}
if ( strcmp( dirname, ".svn" ) == 0 ) {
continue;
}
srcEntry = source;
srcEntry += "/";
srcEntry += dirname;
dstEntry = dest;
dstEntry += "/";
dstEntry += dirname;
switch ( CheckFile( srcEntry.GetBuffer() ) ) {
case PATH_DIRECTORY: {
if ( CheckFile( dstEntry.GetBuffer() ) == PATH_FAIL ) {
radCreateDirectory( dstEntry.GetBuffer() );
}
bool ret;
ret = CopyTree( srcEntry.GetBuffer(), dstEntry.GetBuffer() );
if ( !ret ) {
return false;
}
break;
}
case PATH_FILE: {
Sys_Printf( "copy %s -> %s\n", srcEntry.GetBuffer(), dstEntry.GetBuffer() );
bool ret = radCopyFile( srcEntry.GetBuffer(), dstEntry.GetBuffer() );
if ( !ret ) {
return false;
}
break;
}
}
}
return true;
}

View file

@ -3282,24 +3282,18 @@ scan for active games that can be installed, based on the presence
*/ */
void CGameInstall::ScanGames() { void CGameInstall::ScanGames() {
Str pakPaths = g_strAppPath.GetBuffer(); Str pakPaths = g_strAppPath.GetBuffer();
DIR *dir;
struct dirent *dirlist;
int iGame = 0; int iGame = 0;
const char *dirname;
pakPaths += "installs/"; pakPaths += "installs/";
dir = opendir( pakPaths.GetBuffer() ); FindFiles fileScan( pakPaths.GetBuffer() );
if ( dir != NULL ) { while ( ( dirname = fileScan.NextFile() ) != NULL ) {
while ( ( dirlist = readdir( dir ) ) != NULL ) { if ( stricmp( dirname, Q3_PACK ) == 0 ) {
if ( stricmp( dirlist->d_name, Q3_PACK ) == 0 ) {
m_availGames[ iGame++ ] = GAME_Q3; m_availGames[ iGame++ ] = GAME_Q3;
} }
if ( stricmp( dirlist->d_name, URT_PACK ) == 0 ) { if ( stricmp( dirname, URT_PACK ) == 0 ) {
m_availGames[ iGame++ ] = GAME_URT; m_availGames[ iGame++ ] = GAME_URT;
} }
if ( stricmp( dirlist->d_name, UFOAI_PACK ) == 0 ) {
m_availGames[ iGame++ ] = GAME_UFOAI;
}
}
closedir( dir );
} }
} }

File diff suppressed because it is too large Load diff

View file

@ -36,9 +36,9 @@ void Save256Image (const char *name, byte *pixels, byte *palette,
int width, int height); int width, int height);
void LoadTGA (const char *filename, byte **pixels, int *width, int *height); void LoadTGA( const char *filename, byte **pixels, int *width, int *height );
void LoadTGABuffer ( byte *buffer, byte **pic, int *width, int *height); void LoadTGABuffer( byte *buffer, byte **pic, int *width, int *height );
void WriteTGA (const char *filename, byte *data, int width, int height); void WriteTGA( const char *filename, byte *data, int width, int height );
int LoadJPGBuff( void *src_buffer, int src_size, unsigned char **pic, int *width, int *height );
void Load32BitImage (const char *name, unsigned **pixels, int *width, int *height);
void Load32BitImage( const char *name, unsigned **pixels, int *width, int *height );

View file

@ -19,6 +19,7 @@
OutputDirectory="$(SolutionDir)$(ConfigurationName)" OutputDirectory="$(SolutionDir)$(ConfigurationName)"
IntermediateDirectory="$(ConfigurationName)" IntermediateDirectory="$(ConfigurationName)"
ConfigurationType="1" ConfigurationType="1"
UseOfMFC="0"
CharacterSet="2" CharacterSet="2"
> >
<Tool <Tool
@ -62,6 +63,8 @@
Name="VCLinkerTool" Name="VCLinkerTool"
AdditionalDependencies="md5lib.lib ddslib.lib l_net.lib mathlib.lib picomodel.lib libxml2.lib libpng.lib glib-2.0.lib gobject-2.0.lib Wsock32.lib libjpeg.lib" AdditionalDependencies="md5lib.lib ddslib.lib l_net.lib mathlib.lib picomodel.lib libxml2.lib libpng.lib glib-2.0.lib gobject-2.0.lib Wsock32.lib libjpeg.lib"
AdditionalLibraryDirectories="&quot;$(SolutionDir)\..\libxml2\lib&quot;;&quot;$(SolutionDir)\..\gtk2\lib&quot;;&quot;$(SolutionDir)\build\$(ConfigurationName)\libs&quot;;&quot;$(SolutionDir)\..\jpeg-6b&quot;" AdditionalLibraryDirectories="&quot;$(SolutionDir)\..\libxml2\lib&quot;;&quot;$(SolutionDir)\..\gtk2\lib&quot;;&quot;$(SolutionDir)\build\$(ConfigurationName)\libs&quot;;&quot;$(SolutionDir)\..\jpeg-6b&quot;"
IgnoreAllDefaultLibraries="false"
IgnoreDefaultLibraryNames=""
GenerateDebugInformation="true" GenerateDebugInformation="true"
TargetMachine="1" TargetMachine="1"
/> />