mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 23:21:43 +00:00
NBlood: Remove std::string from libsmackerdec to fix cutscene crashing with MinGW builds.
# Conflicts: # source/libsmackerdec/include/FileStream.h # source/libsmackerdec/src/FileStream.cpp
This commit is contained in:
parent
745d78d8d7
commit
4a31447702
6 changed files with 20 additions and 19 deletions
|
@ -20,7 +20,6 @@
|
|||
#ifndef _SmackerFileStream_h_
|
||||
#define _SmackerFileStream_h_
|
||||
|
||||
#include <string>
|
||||
#include "compat.h"
|
||||
#include <stdint.h>
|
||||
#include "files.h"
|
||||
|
@ -31,7 +30,7 @@ class FileStream
|
|||
{
|
||||
public:
|
||||
|
||||
bool Open(const std::string &fileName);
|
||||
bool Open(const char *fileName);
|
||||
bool Is_Open();
|
||||
void Close();
|
||||
|
||||
|
|
|
@ -20,11 +20,11 @@
|
|||
#ifndef _SmackerLogError_h_
|
||||
#define _SmackerLogError_h_
|
||||
|
||||
#include <string>
|
||||
//#include <string>
|
||||
|
||||
namespace SmackerCommon {
|
||||
|
||||
void LogError(const std::string &error);
|
||||
//void LogError(const std::string &error);
|
||||
|
||||
} // close namespace SmackerCommon
|
||||
|
||||
|
|
|
@ -66,7 +66,7 @@ struct SmackerAudioInfo
|
|||
uint32_t idealBufferSize;
|
||||
};
|
||||
|
||||
SmackerHandle Smacker_Open (const char* fileName);
|
||||
SmackerHandle Smacker_Open (const char *fileName);
|
||||
void Smacker_Close (SmackerHandle &handle);
|
||||
uint32_t Smacker_GetNumAudioTracks (SmackerHandle &handle);
|
||||
SmackerAudioInfo Smacker_GetAudioTrackDetails (SmackerHandle &handle, uint32_t trackIndex);
|
||||
|
@ -110,7 +110,7 @@ class SmackerDecoder
|
|||
SmackerDecoder();
|
||||
~SmackerDecoder();
|
||||
|
||||
bool Open(const std::string &fileName);
|
||||
bool Open(const char *fileName);
|
||||
void GetPalette(uint8_t *palette);
|
||||
void GetFrame(uint8_t *frame);
|
||||
|
||||
|
|
|
@ -23,9 +23,9 @@
|
|||
|
||||
namespace SmackerCommon {
|
||||
|
||||
bool FileStream::Open(const std::string &fileName)
|
||||
bool FileStream::Open(const char *fileName)
|
||||
{
|
||||
file = fileSystem.OpenFileReader(fileName.c_str(), 0);
|
||||
file = fileSystem.OpenFileReader(fileName, 0);
|
||||
if (!file.isOpen())
|
||||
{
|
||||
// log error
|
||||
|
|
|
@ -21,11 +21,13 @@
|
|||
|
||||
namespace SmackerCommon {
|
||||
|
||||
#if 0
|
||||
static std::string LastError;
|
||||
|
||||
void LogError(const std::string &error)
|
||||
{
|
||||
LastError = error;
|
||||
}
|
||||
#endif
|
||||
|
||||
} // close namespace SmackerCommon
|
||||
|
|
|
@ -47,8 +47,8 @@
|
|||
#include "LogError.h"
|
||||
#include <assert.h>
|
||||
#include <algorithm>
|
||||
#include <string.h>
|
||||
#include "compat.h"
|
||||
#include "baselayer.h"
|
||||
|
||||
std::vector<class SmackerDecoder*> classInstances;
|
||||
|
||||
|
@ -295,13 +295,13 @@ int SmackerDecoder::GetCode(SmackerCommon::BitReader &bits, std::vector<int> &re
|
|||
return v;
|
||||
}
|
||||
|
||||
bool SmackerDecoder::Open(const std::string &fileName)
|
||||
bool SmackerDecoder::Open(const char *fileName)
|
||||
{
|
||||
// open the file (read only)
|
||||
file.Open(fileName);
|
||||
if (!file.Is_Open())
|
||||
{
|
||||
SmackerCommon::LogError("Can't open file " + fileName);
|
||||
buildprintf("SmackerDecoder::Open() - Can't open file %s\n", fileName);
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -310,7 +310,7 @@ bool SmackerDecoder::Open(const std::string &fileName)
|
|||
if (memcmp(signature, kSMK2iD, 4) != 0
|
||||
&& memcmp(signature, kSMK4iD, 4) != 0)
|
||||
{
|
||||
SmackerCommon::LogError("Unknown Smacker signature");
|
||||
buildprintf("SmackerDecoder::Open() - Unknown Smacker signature\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -358,7 +358,7 @@ bool SmackerDecoder::Open(const std::string &fileName)
|
|||
|
||||
if (nFrames > 0xFFFFFF)
|
||||
{
|
||||
SmackerCommon::LogError("Too many frames!");
|
||||
buildprintf("SmackerDecoder::Open() - Too many frames\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -447,7 +447,7 @@ int SmackerDecoder::DecodeTree(SmackerCommon::BitReader &bits, HuffContext *hc,
|
|||
if (!bits.GetBit()) // Leaf
|
||||
{
|
||||
if (hc->current >= 256){
|
||||
SmackerCommon::LogError("Tree size exceeded!");
|
||||
buildprintf("SmackerDecoder::DecodeTree() - Tree size exceeded\n");
|
||||
return -1;
|
||||
}
|
||||
if (length){
|
||||
|
@ -486,7 +486,7 @@ int SmackerDecoder::DecodeBigTree(SmackerCommon::BitReader &bits, HuffContext *h
|
|||
i2 = 0;
|
||||
|
||||
if (hc->current >= hc->length){
|
||||
SmackerCommon::LogError("Tree size exceeded!");
|
||||
buildprintf("SmackerDecoder::DecodeBigTree() - Tree size exceeded");
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -548,7 +548,7 @@ int SmackerDecoder::DecodeHeaderTree(SmackerCommon::BitReader &bits, std::vector
|
|||
|
||||
if ((uint32_t)size >= UINT_MAX>>4)
|
||||
{
|
||||
SmackerCommon::LogError("Size too large");
|
||||
buildprintf("SmackerDecoder::DecodeHeaderTree() - Size too large\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -971,7 +971,7 @@ int SmackerDecoder::DecodeAudio(uint32_t size, SmackerAudioTrack &track)
|
|||
int buf_size = track.bufferSize;
|
||||
|
||||
if (buf_size <= 4) {
|
||||
SmackerCommon::LogError("packet is too small");
|
||||
buildprintf("SmackerDecoder::DecodeAudio() - Packet is too small\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -988,7 +988,7 @@ int SmackerDecoder::DecodeAudio(uint32_t size, SmackerAudioTrack &track)
|
|||
sampleBits = bits.GetBit();
|
||||
|
||||
if (stereo ^ (track.nChannels != 1)) {
|
||||
SmackerCommon::LogError("channels mismatch");
|
||||
buildprintf("SmackerDecoder::DecodeAudio() - Channels mismatch\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -1112,7 +1112,7 @@ float SmackerDecoder::GetFrameRate()
|
|||
void SmackerDecoder::GotoFrame(uint32_t frameNum)
|
||||
{
|
||||
if (frameNum >= nFrames) {
|
||||
SmackerCommon::LogError("Invalid frame number for GotoFrame");
|
||||
buildprintf("SmackerDecoder::GotoFrame() - Invalid frame number\n");
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue