mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-05 06:56:41 +00:00
197 lines
5.4 KiB
C++
197 lines
5.4 KiB
C++
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||
|
//
|
||
|
// Purpose:
|
||
|
//
|
||
|
//=============================================================================//
|
||
|
|
||
|
#include "quakedef.h"
|
||
|
#include "logofile_shared.h"
|
||
|
#include "filesystem_engine.h"
|
||
|
#include "vtf/vtf.h"
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// CLogoFilename implementation.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
CLogoFilename::CLogoFilename( CRC32_t value, bool bInDownloadsDirectory )
|
||
|
{
|
||
|
char hex[16];
|
||
|
Q_binarytohex( (byte *)&value, sizeof( value ), hex, sizeof( hex ) );
|
||
|
|
||
|
if ( bInDownloadsDirectory )
|
||
|
{
|
||
|
Q_snprintf( m_Filename, sizeof( m_Filename ), "materials/decals/downloads/%s.vtf", hex );
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
Q_strncpy( m_Filename, hex, sizeof( m_Filename ) );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// SVC_LogoFileData.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
bool SVC_LogoFileData::ReadFromBuffer( bf_read &buffer )
|
||
|
{
|
||
|
m_Data.SetSize( buffer.ReadShort() );
|
||
|
buffer.ReadBytes( m_Data.Base(), m_Data.Count() );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
bool SVC_LogoFileData::WriteToBuffer( bf_write &buffer )
|
||
|
{
|
||
|
buffer.WriteUBitLong( GetType(), NETMSG_TYPE_BITS );
|
||
|
buffer.WriteShort( m_Data.Count() );
|
||
|
buffer.WriteBytes( m_Data.Base(), m_Data.Count() );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
const char* SVC_LogoFileData::ToString() const
|
||
|
{
|
||
|
return "SVC_LogoFileData";
|
||
|
}
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// CLC_LogoFileData.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
bool CLC_LogoFileData::ReadFromBuffer( bf_read &buffer )
|
||
|
{
|
||
|
m_Data.SetSize( buffer.ReadShort() );
|
||
|
buffer.ReadBytes( m_Data.Base(), m_Data.Count() );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
bool CLC_LogoFileData::WriteToBuffer( bf_write &buffer )
|
||
|
{
|
||
|
buffer.WriteUBitLong( GetType(), NETMSG_TYPE_BITS );
|
||
|
buffer.WriteShort( m_Data.Count() );
|
||
|
buffer.WriteBytes( m_Data.Base(), m_Data.Count() );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
const char* CLC_LogoFileData::ToString() const
|
||
|
{
|
||
|
return "CLC_LogoFileData";
|
||
|
}
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// SVC_LogoFileCRC.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
bool SVC_LogoFileCRC::ReadFromBuffer( bf_read &buffer )
|
||
|
{
|
||
|
m_nLogoFileCRC = buffer.ReadLong();
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
bool SVC_LogoFileCRC::WriteToBuffer( bf_write &buffer )
|
||
|
{
|
||
|
buffer.WriteUBitLong( GetType(), NETMSG_TYPE_BITS );
|
||
|
buffer.WriteLong( m_nLogoFileCRC );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
const char* SVC_LogoFileCRC::ToString() const
|
||
|
{
|
||
|
return "LogoFileCRC";
|
||
|
}
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// CLC_LogoFileRequest.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
bool CLC_LogoFileRequest::ReadFromBuffer( bf_read &buffer )
|
||
|
{
|
||
|
m_nLogoFileCRC = buffer.ReadLong();
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
bool CLC_LogoFileRequest::WriteToBuffer( bf_write &buffer )
|
||
|
{
|
||
|
buffer.WriteUBitLong( GetType(), NETMSG_TYPE_BITS );
|
||
|
buffer.WriteLong( m_nLogoFileCRC );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
const char* CLC_LogoFileRequest::ToString() const
|
||
|
{
|
||
|
return "LogoFileRequest";
|
||
|
}
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// CLC_LogoFileRequest.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
bool SVC_LogoFileRequest::ReadFromBuffer( bf_read &buffer )
|
||
|
{
|
||
|
m_nLogoFileCRC = buffer.ReadLong();
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
bool SVC_LogoFileRequest::WriteToBuffer( bf_write &buffer )
|
||
|
{
|
||
|
buffer.WriteUBitLong( GetType(), NETMSG_TYPE_BITS );
|
||
|
buffer.WriteLong( m_nLogoFileCRC );
|
||
|
return !buffer.IsOverflowed();
|
||
|
}
|
||
|
|
||
|
const char* SVC_LogoFileRequest::ToString() const
|
||
|
{
|
||
|
return "LogoFileRequest";
|
||
|
}
|
||
|
|
||
|
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
// Other functions.
|
||
|
// ------------------------------------------------------------------------------------ //
|
||
|
|
||
|
bool LogoFile_IsValidVTFFile( const void *pData, int len )
|
||
|
{
|
||
|
CUtlBuffer buf( pData, len, CUtlBuffer::READ_ONLY );
|
||
|
|
||
|
IVTFTexture *pTex = CreateVTFTexture();
|
||
|
bool bUnserialized = pTex->Unserialize( buf );
|
||
|
DestroyVTFTexture( pTex );
|
||
|
|
||
|
return bUnserialized;
|
||
|
}
|
||
|
|
||
|
|
||
|
bool LogoFile_ReadFile( CRC32_t crcValue, CUtlVector<char> &fileData )
|
||
|
{
|
||
|
CLogoFilename filename( crcValue, true );
|
||
|
FileHandle_t hFile = g_pFileSystem->Open( filename.m_Filename, "rb" );
|
||
|
if ( hFile == FILESYSTEM_INVALID_HANDLE )
|
||
|
{
|
||
|
Warning( "LogoFile_ReadFile: can't open file '%s'.\n", filename.m_Filename );
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
fileData.SetSize( g_pFileSystem->Size( hFile ) );
|
||
|
int amtRead = g_pFileSystem->Read( fileData.Base(), fileData.Count(), hFile );
|
||
|
g_pFileSystem->Close( hFile );
|
||
|
if ( fileData.Count() == 0 || amtRead != fileData.Count() )
|
||
|
{
|
||
|
Warning( "LogoFile_ReadFile: error reading file '%s'.\n", filename.m_Filename );
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// Validate it one last time.
|
||
|
if ( !LogoFile_IsValidVTFFile( fileData.Base(), fileData.Count() ) )
|
||
|
{
|
||
|
g_pFileSystem->RemoveFile( filename.m_Filename );
|
||
|
Warning( "LogoFile_ReadFile: !IsValidVTFFile for '%s'.\n", filename.m_Filename );
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|