cosmetics: use spaces instead of tab characters; remove trailing whitespace
This commit is contained in:
parent
dc9a431375
commit
34554928aa
114
ebml/Debug.h
114
ebml/Debug.h
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: Debug.h 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: Debug.h 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_DEBUG_H
|
#ifndef LIBEBML_DEBUG_H
|
||||||
#define LIBEBML_DEBUG_H
|
#define LIBEBML_DEBUG_H
|
||||||
@ -58,47 +58,47 @@ static const int MAX_PREFIX_LENGTH = 128;
|
|||||||
class EBML_DLL_API ADbg
|
class EBML_DLL_API ADbg
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ADbg(int level = 0);
|
ADbg(int level = 0);
|
||||||
virtual ~ADbg();
|
virtual ~ADbg();
|
||||||
|
|
||||||
/// \todo make an inline function to test the level first and the process
|
/// \todo make an inline function to test the level first and the process
|
||||||
int OutPut(int level, const char * format,...) const;
|
int OutPut(int level, const char * format,...) const;
|
||||||
|
|
||||||
int OutPut(const char * format,...) const;
|
int OutPut(const char * format,...) const;
|
||||||
|
|
||||||
inline int setLevel(const int level) {
|
inline int setLevel(const int level) {
|
||||||
return my_level = level;
|
return my_level = level;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool setIncludeTime(const bool included = true) {
|
inline bool setIncludeTime(const bool included = true) {
|
||||||
return my_time_included = included;
|
return my_time_included = included;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool setDebugFile(const char * NewFilename);
|
bool setDebugFile(const char * NewFilename);
|
||||||
bool unsetDebugFile();
|
bool unsetDebugFile();
|
||||||
|
|
||||||
inline bool setUseFile(const bool usefile = true) {
|
inline bool setUseFile(const bool usefile = true) {
|
||||||
return my_use_file = usefile;
|
return my_use_file = usefile;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const char * setPrefix(const char * string) {
|
inline const char * setPrefix(const char * string) {
|
||||||
return strncpy(prefix, string, MAX_PREFIX_LENGTH);
|
return strncpy(prefix, string, MAX_PREFIX_LENGTH);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
int my_level;
|
int my_level;
|
||||||
bool my_time_included;
|
bool my_time_included;
|
||||||
bool my_use_file;
|
bool my_use_file;
|
||||||
bool my_debug_output;
|
bool my_debug_output;
|
||||||
|
|
||||||
int _OutPut(const char * format,va_list params) const;
|
int _OutPut(const char * format,va_list params) const;
|
||||||
|
|
||||||
char prefix[MAX_PREFIX_LENGTH];
|
char prefix[MAX_PREFIX_LENGTH];
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
HANDLE hFile;
|
HANDLE hFile;
|
||||||
#else
|
#else
|
||||||
FILE *hFile;
|
FILE *hFile;
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -109,40 +109,40 @@ private:
|
|||||||
class EBML_DLL_API ADbg
|
class EBML_DLL_API ADbg
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ADbg(int /* level */ = 0){}
|
ADbg(int /* level */ = 0){}
|
||||||
virtual ~ADbg() {}
|
virtual ~ADbg() {}
|
||||||
|
|
||||||
inline int OutPut(int /* level */, const char * /* format */,...) const {
|
inline int OutPut(int /* level */, const char * /* format */,...) const {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int OutPut(const char * /* format */,...) const {
|
inline int OutPut(const char * /* format */,...) const {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int setLevel(const int level) {
|
inline int setLevel(const int level) {
|
||||||
return level;
|
return level;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool setIncludeTime(const bool /* included */ = true) {
|
inline bool setIncludeTime(const bool /* included */ = true) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool setDebugFile(const char * /* NewFilename */) {
|
inline bool setDebugFile(const char * /* NewFilename */) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool unsetDebugFile() {
|
inline bool unsetDebugFile() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool setUseFile(const bool /* usefile */ = true) {
|
inline bool setUseFile(const bool /* usefile */ = true) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const char * setPrefix(const char * string) {
|
inline const char * setPrefix(const char * string) {
|
||||||
return string;
|
return string;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // defined(LIBEBML_DEBUG)
|
#endif // defined(LIBEBML_DEBUG)
|
||||||
|
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Julien Coloos <suiryc @ users.sf.net>
|
\author Julien Coloos <suiryc @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_BINARY_H
|
#ifndef LIBEBML_BINARY_H
|
||||||
#define LIBEBML_BINARY_H
|
#define LIBEBML_BINARY_H
|
||||||
@ -54,51 +54,51 @@ START_LIBEBML_NAMESPACE
|
|||||||
\class EbmlBinary
|
\class EbmlBinary
|
||||||
\brief Handle all operations on an EBML element that contains "unknown" binary data
|
\brief Handle all operations on an EBML element that contains "unknown" binary data
|
||||||
|
|
||||||
\todo handle fix sized elements (like UID of CodecID)
|
\todo handle fix sized elements (like UID of CodecID)
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlBinary : public EbmlElement {
|
class EBML_DLL_API EbmlBinary : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlBinary();
|
EbmlBinary();
|
||||||
EbmlBinary(const EbmlBinary & ElementToClone);
|
EbmlBinary(const EbmlBinary & ElementToClone);
|
||||||
virtual ~EbmlBinary(void);
|
virtual ~EbmlBinary(void);
|
||||||
|
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize() && GetSize() < 0x7FFFFFFF;} // we don't mind about what's inside
|
virtual bool ValidateSize() const {return IsFiniteSize() && GetSize() < 0x7FFFFFFF;} // we don't mind about what's inside
|
||||||
|
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
void SetBuffer(const binary *Buffer, const uint32 BufferSize) {
|
void SetBuffer(const binary *Buffer, const uint32 BufferSize) {
|
||||||
Data = (binary *) Buffer;
|
Data = (binary *) Buffer;
|
||||||
SetSize_(BufferSize);
|
SetSize_(BufferSize);
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
binary *GetBuffer() const {return Data;}
|
binary *GetBuffer() const {return Data;}
|
||||||
|
|
||||||
void CopyBuffer(const binary *Buffer, const uint32 BufferSize) {
|
void CopyBuffer(const binary *Buffer, const uint32 BufferSize) {
|
||||||
if (Data != NULL)
|
if (Data != NULL)
|
||||||
free(Data);
|
free(Data);
|
||||||
Data = (binary *)malloc(BufferSize * sizeof(binary));
|
Data = (binary *)malloc(BufferSize * sizeof(binary));
|
||||||
memcpy(Data, Buffer, BufferSize);
|
memcpy(Data, Buffer, BufferSize);
|
||||||
SetSize_(BufferSize);
|
SetSize_(BufferSize);
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
operator const binary &() const;
|
operator const binary &() const;
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator==(const EbmlBinary & ElementToCompare) const;
|
bool operator==(const EbmlBinary & ElementToCompare) const;
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
binary *Data; // the binary data inside the element
|
binary *Data; // the binary data inside the element
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,10 +27,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlConfig.h 1241 2006-01-25 00:59:45Z robux4 $
|
\version \$Id: EbmlConfig.h 1241 2006-01-25 00:59:45Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBEBML_CONFIG_H
|
#ifndef LIBEBML_CONFIG_H
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlContexts.h 736 2004-08-28 14:05:09Z robux4 $
|
\version \$Id: EbmlContexts.h 736 2004-08-28 14:05:09Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_CONTEXTS_H
|
#ifndef LIBEBML_CONTEXTS_H
|
||||||
#define LIBEBML_CONTEXTS_H
|
#define LIBEBML_CONTEXTS_H
|
||||||
|
106
ebml/EbmlCrc32.h
106
ebml/EbmlCrc32.h
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_CRC32_H
|
#ifndef LIBEBML_CRC32_H
|
||||||
#define LIBEBML_CRC32_H
|
#define LIBEBML_CRC32_H
|
||||||
@ -45,57 +45,57 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
DECLARE_EBML_BINARY(EbmlCrc32)
|
DECLARE_EBML_BINARY(EbmlCrc32)
|
||||||
public:
|
public:
|
||||||
EbmlCrc32(const EbmlCrc32 & ElementToClone);
|
EbmlCrc32(const EbmlCrc32 & ElementToClone);
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() == 4);}
|
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() == 4);}
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
// filepos_t UpdateSize(bool bWithDefault = false);
|
// filepos_t UpdateSize(bool bWithDefault = false);
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AddElementCRC32(EbmlElement &ElementToCRC);
|
void AddElementCRC32(EbmlElement &ElementToCRC);
|
||||||
bool CheckElementCRC32(EbmlElement &ElementToCRC);
|
bool CheckElementCRC32(EbmlElement &ElementToCRC);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Use this to quickly check a CRC32 with some data
|
Use this to quickly check a CRC32 with some data
|
||||||
\return True if inputCRC matches CRC32 generated from input data
|
\return True if inputCRC matches CRC32 generated from input data
|
||||||
*/
|
*/
|
||||||
static bool CheckCRC(uint32 inputCRC, const binary *input, uint32 length);
|
static bool CheckCRC(uint32 inputCRC, const binary *input, uint32 length);
|
||||||
/*!
|
/*!
|
||||||
Calls Update() and Finalize(), use to create a CRC32 in one go
|
Calls Update() and Finalize(), use to create a CRC32 in one go
|
||||||
*/
|
*/
|
||||||
void FillCRC32(const binary *input, uint32 length);
|
void FillCRC32(const binary *input, uint32 length);
|
||||||
/*!
|
/*!
|
||||||
Add data to the CRC table, in other words process some data bit by bit
|
Add data to the CRC table, in other words process some data bit by bit
|
||||||
*/
|
*/
|
||||||
void Update(const binary *input, uint32 length);
|
void Update(const binary *input, uint32 length);
|
||||||
/*!
|
/*!
|
||||||
Use this with Update() to Finalize() or Complete the CRC32
|
Use this with Update() to Finalize() or Complete the CRC32
|
||||||
*/
|
*/
|
||||||
void Finalize();
|
void Finalize();
|
||||||
/*!
|
/*!
|
||||||
Returns a uint32 that has the value of the CRC32
|
Returns a uint32 that has the value of the CRC32
|
||||||
*/
|
*/
|
||||||
uint32 GetCrc32() const {
|
uint32 GetCrc32() const {
|
||||||
return m_crc_final;
|
return m_crc_final;
|
||||||
};
|
};
|
||||||
|
|
||||||
void ForceCrc32(uint32 NewValue) { m_crc_final = NewValue; SetValueIsSet();}
|
void ForceCrc32(uint32 NewValue) { m_crc_final = NewValue; SetValueIsSet();}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
void ResetCRC();
|
void ResetCRC();
|
||||||
void UpdateByte(binary b);
|
void UpdateByte(binary b);
|
||||||
|
|
||||||
static const uint32 m_tab[256];
|
static const uint32 m_tab[256];
|
||||||
uint32 m_crc;
|
uint32 m_crc;
|
||||||
uint32 m_crc_final;
|
uint32 m_crc_final;
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EbmlCrc32)
|
EBML_CONCRETE_CLASS(EbmlCrc32)
|
||||||
};
|
};
|
||||||
@ -104,36 +104,36 @@ template <class T>
|
|||||||
inline unsigned int GetAlignment(T */* dummy */=NULL) // VC60 workaround
|
inline unsigned int GetAlignment(T */* dummy */=NULL) // VC60 workaround
|
||||||
{
|
{
|
||||||
#if defined(_MSC_VER) && (_MSC_VER >= 1300)
|
#if defined(_MSC_VER) && (_MSC_VER >= 1300)
|
||||||
return __alignof(T);
|
return __alignof(T);
|
||||||
#elif defined(__GNUC__)
|
#elif defined(__GNUC__)
|
||||||
return __alignof__(T);
|
return __alignof__(T);
|
||||||
#else
|
#else
|
||||||
return sizeof(T);
|
return sizeof(T);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
inline bool IsPowerOf2(T n)
|
inline bool IsPowerOf2(T n)
|
||||||
{
|
{
|
||||||
return n > 0 && (n & (n-1)) == 0;
|
return n > 0 && (n & (n-1)) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T1, class T2>
|
template <class T1, class T2>
|
||||||
inline T2 ModPowerOf2(T1 a, T2 b)
|
inline T2 ModPowerOf2(T1 a, T2 b)
|
||||||
{
|
{
|
||||||
assert(IsPowerOf2(b));
|
assert(IsPowerOf2(b));
|
||||||
return T2(a) & (b-1);
|
return T2(a) & (b-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool IsAlignedOn(const void *p, unsigned int alignment)
|
inline bool IsAlignedOn(const void *p, unsigned int alignment)
|
||||||
{
|
{
|
||||||
return IsPowerOf2(alignment) ? ModPowerOf2((uintptr_t)p, alignment) == 0 : (uintptr_t)p % alignment == 0;
|
return IsPowerOf2(alignment) ? ModPowerOf2((uintptr_t)p, alignment) == 0 : (uintptr_t)p % alignment == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
inline bool IsAligned(const void *p, T */* dummy */=NULL) // VC60 workaround
|
inline bool IsAligned(const void *p, T */* dummy */=NULL) // VC60 workaround
|
||||||
{
|
{
|
||||||
return IsAlignedOn(p, GetAlignment<T>());
|
return IsAlignedOn(p, GetAlignment<T>());
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,9 +27,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_DATE_H
|
#ifndef LIBEBML_DATE_H
|
||||||
#define LIBEBML_DATE_H
|
#define LIBEBML_DATE_H
|
||||||
@ -44,55 +44,55 @@ START_LIBEBML_NAMESPACE
|
|||||||
\brief Handle all operations related to an EBML date
|
\brief Handle all operations related to an EBML date
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlDate : public EbmlElement {
|
class EBML_DLL_API EbmlDate : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlDate() :EbmlElement(8, false), myDate(0) {}
|
EbmlDate() :EbmlElement(8, false), myDate(0) {}
|
||||||
EbmlDate(const EbmlDate & ElementToClone);
|
EbmlDate(const EbmlDate & ElementToClone);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief set the date with a UNIX/C/EPOCH form
|
\brief set the date with a UNIX/C/EPOCH form
|
||||||
\param NewDate UNIX/C date in UTC (no timezone)
|
\param NewDate UNIX/C date in UTC (no timezone)
|
||||||
*/
|
*/
|
||||||
void SetEpochDate(int64 NewDate) {myDate = (NewDate - UnixEpochDelay) * 1000000000; SetValueIsSet();}
|
void SetEpochDate(int64 NewDate) {myDate = (NewDate - UnixEpochDelay) * 1000000000; SetValueIsSet();}
|
||||||
EbmlDate &SetValue(int64 NewValue) {SetEpochDate(NewValue); return *this;}
|
EbmlDate &SetValue(int64 NewValue) {SetEpochDate(NewValue); return *this;}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief get the date with a UNIX/C/EPOCH form
|
\brief get the date with a UNIX/C/EPOCH form
|
||||||
\note the date is in UTC (no timezone)
|
\note the date is in UTC (no timezone)
|
||||||
*/
|
*/
|
||||||
int64 GetEpochDate() const {return int64(myDate/1000000000 + UnixEpochDelay);}
|
int64 GetEpochDate() const {return int64(myDate/1000000000 + UnixEpochDelay);}
|
||||||
int64 GetValue() const {return GetEpochDate();}
|
int64 GetValue() const {return GetEpochDate();}
|
||||||
|
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize() && ((GetSize() == 8) || (GetSize() == 0));}
|
virtual bool ValidateSize() const {return IsFiniteSize() && ((GetSize() == 8) || (GetSize() == 0));}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\note no Default date handled
|
\note no Default date handled
|
||||||
*/
|
*/
|
||||||
filepos_t UpdateSize(bool /* bWithDefault = false */, bool /* bForceRender = false */) {
|
filepos_t UpdateSize(bool /* bWithDefault = false */, bool /* bForceRender = false */) {
|
||||||
if(!ValueIsSet())
|
if(!ValueIsSet())
|
||||||
SetSize_(0);
|
SetSize_(0);
|
||||||
else
|
else
|
||||||
SetSize_(8);
|
SetSize_(8);
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||||
|
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
|
|
||||||
int64 myDate; ///< internal format of the date
|
int64 myDate; ///< internal format of the date
|
||||||
|
|
||||||
static const uint64 UnixEpochDelay;
|
static const uint64 UnixEpochDelay;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_DUMMY_H
|
#ifndef LIBEBML_DUMMY_H
|
||||||
#define LIBEBML_DUMMY_H
|
#define LIBEBML_DUMMY_H
|
||||||
@ -41,13 +41,13 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
class EBML_DLL_API EbmlDummy : public EbmlBinary {
|
class EBML_DLL_API EbmlDummy : public EbmlBinary {
|
||||||
public:
|
public:
|
||||||
EbmlDummy() :DummyId(DummyRawId) {}
|
EbmlDummy() :DummyId(DummyRawId) {}
|
||||||
EbmlDummy(const EbmlId & aId) :EbmlBinary(), DummyId(aId) {}
|
EbmlDummy(const EbmlId & aId) :EbmlBinary(), DummyId(aId) {}
|
||||||
EbmlDummy(const EbmlDummy & ElementToClone):EbmlBinary(ElementToClone), DummyId(ElementToClone.DummyId) {}
|
EbmlDummy(const EbmlDummy & ElementToClone):EbmlBinary(ElementToClone), DummyId(ElementToClone.DummyId) {}
|
||||||
|
|
||||||
bool IsDummy() const {return true;}
|
bool IsDummy() const {return true;}
|
||||||
bool IsDefaultValue() const {return true;}
|
bool IsDefaultValue() const {return true;}
|
||||||
|
|
||||||
virtual operator const EbmlId &() const {
|
virtual operator const EbmlId &() const {
|
||||||
return DummyId;
|
return DummyId;
|
||||||
@ -58,8 +58,8 @@ class EBML_DLL_API EbmlDummy : public EbmlBinary {
|
|||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
const EbmlId DummyId;
|
const EbmlId DummyId;
|
||||||
static const EbmlId DummyRawId;
|
static const EbmlId DummyRawId;
|
||||||
|
|
||||||
EBML_CONCRETE_DUMMY_CLASS(EbmlDummy)
|
EBML_CONCRETE_DUMMY_CLASS(EbmlDummy)
|
||||||
};
|
};
|
||||||
|
@ -27,9 +27,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_ELEMENT_H
|
#ifndef LIBEBML_ELEMENT_H
|
||||||
#define LIBEBML_ELEMENT_H
|
#define LIBEBML_ELEMENT_H
|
||||||
@ -41,36 +41,36 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief The size of the EBML-coded length
|
\brief The size of the EBML-coded length
|
||||||
*/
|
*/
|
||||||
int EBML_DLL_API CodedSizeLength(uint64 Length, unsigned int SizeLength, bool bSizeIsFinite = true);
|
int EBML_DLL_API CodedSizeLength(uint64 Length, unsigned int SizeLength, bool bSizeIsFinite = true);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief The coded value of the EBML-coded length
|
\brief The coded value of the EBML-coded length
|
||||||
\note The size of OutBuffer must be 8 octets at least
|
\note The size of OutBuffer must be 8 octets at least
|
||||||
*/
|
*/
|
||||||
int EBML_DLL_API CodedValueLength(uint64 Length, int CodedSize, binary * OutBuffer);
|
int EBML_DLL_API CodedValueLength(uint64 Length, int CodedSize, binary * OutBuffer);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Read an EBML-coded value from a buffer
|
\brief Read an EBML-coded value from a buffer
|
||||||
\return the value read
|
\return the value read
|
||||||
*/
|
*/
|
||||||
uint64 EBML_DLL_API ReadCodedSizeValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown);
|
uint64 EBML_DLL_API ReadCodedSizeValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief The size of the EBML-coded signed length
|
\brief The size of the EBML-coded signed length
|
||||||
*/
|
*/
|
||||||
int EBML_DLL_API CodedSizeLengthSigned(int64 Length, unsigned int SizeLength);
|
int EBML_DLL_API CodedSizeLengthSigned(int64 Length, unsigned int SizeLength);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief The coded value of the EBML-coded signed length
|
\brief The coded value of the EBML-coded signed length
|
||||||
\note the size of OutBuffer must be 8 octets at least
|
\note the size of OutBuffer must be 8 octets at least
|
||||||
*/
|
*/
|
||||||
int EBML_DLL_API CodedValueLengthSigned(int64 Length, int CodedSize, binary * OutBuffer);
|
int EBML_DLL_API CodedValueLengthSigned(int64 Length, int CodedSize, binary * OutBuffer);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Read a signed EBML-coded value from a buffer
|
\brief Read a signed EBML-coded value from a buffer
|
||||||
\return the value read
|
\return the value read
|
||||||
*/
|
*/
|
||||||
int64 EBML_DLL_API ReadCodedSizeSignedValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown);
|
int64 EBML_DLL_API ReadCodedSizeSignedValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown);
|
||||||
|
|
||||||
@ -176,25 +176,25 @@ extern const EbmlSemanticContext Context_EbmlGlobal;
|
|||||||
public: \
|
public: \
|
||||||
virtual const EbmlSemanticContext &Context() const {return ClassInfos.GetContext();} \
|
virtual const EbmlSemanticContext &Context() const {return ClassInfos.GetContext();} \
|
||||||
virtual const char *DebugName() const {return ClassInfos.GetName();} \
|
virtual const char *DebugName() const {return ClassInfos.GetName();} \
|
||||||
virtual operator const EbmlId &() const {return ClassInfos.ClassId();} \
|
virtual operator const EbmlId &() const {return ClassInfos.ClassId();} \
|
||||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||||
static EbmlElement & Create() {return *(new Type);} \
|
static EbmlElement & Create() {return *(new Type);} \
|
||||||
static const EbmlCallbacks & ClassInfo() {return ClassInfos;} \
|
static const EbmlCallbacks & ClassInfo() {return ClassInfos;} \
|
||||||
static const EbmlId & ClassId() {return ClassInfos.ClassId();} \
|
static const EbmlId & ClassId() {return ClassInfos.ClassId();} \
|
||||||
private: \
|
private: \
|
||||||
static const EbmlCallbacks ClassInfos; \
|
static const EbmlCallbacks ClassInfos; \
|
||||||
|
|
||||||
#define EBML_CONCRETE_DUMMY_CLASS(Type) \
|
#define EBML_CONCRETE_DUMMY_CLASS(Type) \
|
||||||
public: \
|
public: \
|
||||||
virtual const EbmlSemanticContext &Context() const {return *static_cast<EbmlSemanticContext*>(NULL);} \
|
virtual const EbmlSemanticContext &Context() const {return *static_cast<EbmlSemanticContext*>(NULL);} \
|
||||||
virtual const char *DebugName() const {return "DummyElement";} \
|
virtual const char *DebugName() const {return "DummyElement";} \
|
||||||
virtual operator const EbmlId &(); \
|
virtual operator const EbmlId &(); \
|
||||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||||
static EbmlElement & Create() {return *(new Type);} \
|
static EbmlElement & Create() {return *(new Type);} \
|
||||||
static const EbmlId & ClassId(); \
|
static const EbmlId & ClassId(); \
|
||||||
static const EbmlCallbacks ClassInfos; \
|
static const EbmlCallbacks ClassInfos; \
|
||||||
|
|
||||||
|
|
||||||
#define EBML_INFO(ref) ref::ClassInfo()
|
#define EBML_INFO(ref) ref::ClassInfo()
|
||||||
@ -223,21 +223,21 @@ extern const EbmlSemanticContext Context_EbmlGlobal;
|
|||||||
#else
|
#else
|
||||||
#define EBML_CONCRETE_CLASS(Type) \
|
#define EBML_CONCRETE_CLASS(Type) \
|
||||||
public: \
|
public: \
|
||||||
virtual const EbmlCallbacks & Generic() const {return ClassInfos;} \
|
virtual const EbmlCallbacks & Generic() const {return ClassInfos;} \
|
||||||
virtual operator const EbmlId &() const {return ClassInfos.GlobalId;} \
|
virtual operator const EbmlId &() const {return ClassInfos.GlobalId;} \
|
||||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||||
static EbmlElement & Create() {return *(new Type);} \
|
static EbmlElement & Create() {return *(new Type);} \
|
||||||
static const EbmlCallbacks ClassInfos; \
|
static const EbmlCallbacks ClassInfos; \
|
||||||
|
|
||||||
#define EBML_CONCRETE_DUMMY_CLASS(Type) \
|
#define EBML_CONCRETE_DUMMY_CLASS(Type) \
|
||||||
public: \
|
public: \
|
||||||
virtual const EbmlCallbacks & Generic() const {return ClassInfos;} \
|
virtual const EbmlCallbacks & Generic() const {return ClassInfos;} \
|
||||||
virtual operator const EbmlId &(); \
|
virtual operator const EbmlId &(); \
|
||||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||||
static EbmlElement & Create() {return *(new Type);} \
|
static EbmlElement & Create() {return *(new Type);} \
|
||||||
static const EbmlCallbacks ClassInfos; \
|
static const EbmlCallbacks ClassInfos; \
|
||||||
|
|
||||||
|
|
||||||
#define EBML_INFO(ref) ref::ClassInfos
|
#define EBML_INFO(ref) ref::ClassInfos
|
||||||
@ -282,11 +282,11 @@ extern const EbmlSemanticContext Context_EbmlGlobal;
|
|||||||
|
|
||||||
// functions for generic handling of data (should be static to all classes)
|
// functions for generic handling of data (should be static to all classes)
|
||||||
/*!
|
/*!
|
||||||
\todo Handle default value
|
\todo Handle default value
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlCallbacks {
|
class EBML_DLL_API EbmlCallbacks {
|
||||||
public:
|
public:
|
||||||
EbmlCallbacks(EbmlElement & (*Creator)(), const EbmlId & aGlobalId, const char * aDebugName, const EbmlSemanticContext & aContext);
|
EbmlCallbacks(EbmlElement & (*Creator)(), const EbmlId & aGlobalId, const char * aDebugName, const EbmlSemanticContext & aContext);
|
||||||
|
|
||||||
inline const EbmlId & ClassId() const { return GlobalId; }
|
inline const EbmlId & ClassId() const { return GlobalId; }
|
||||||
inline const EbmlSemanticContext & GetContext() const { return Context; }
|
inline const EbmlSemanticContext & GetContext() const { return Context; }
|
||||||
@ -296,20 +296,20 @@ class EBML_DLL_API EbmlCallbacks {
|
|||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#endif
|
#endif
|
||||||
EbmlElement & (*Create)();
|
EbmlElement & (*Create)();
|
||||||
const EbmlId & GlobalId;
|
const EbmlId & GlobalId;
|
||||||
const char * DebugName;
|
const char * DebugName;
|
||||||
const EbmlSemanticContext & Context;
|
const EbmlSemanticContext & Context;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief contains the semantic informations for a given level and all sublevels
|
\brief contains the semantic informations for a given level and all sublevels
|
||||||
\todo move the ID in the element class
|
\todo move the ID in the element class
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlSemantic {
|
class EBML_DLL_API EbmlSemantic {
|
||||||
public:
|
public:
|
||||||
EbmlSemantic(bool aMandatory, bool aUnique, const EbmlCallbacks & aGetCallbacks)
|
EbmlSemantic(bool aMandatory, bool aUnique, const EbmlCallbacks & aGetCallbacks)
|
||||||
:Mandatory(aMandatory), Unique(aUnique), GetCallbacks(aGetCallbacks) {}
|
:Mandatory(aMandatory), Unique(aUnique), GetCallbacks(aGetCallbacks) {}
|
||||||
|
|
||||||
inline bool IsMandatory() const { return Mandatory; }
|
inline bool IsMandatory() const { return Mandatory; }
|
||||||
inline bool IsUnique() const { return Unique; }
|
inline bool IsUnique() const { return Unique; }
|
||||||
@ -319,172 +319,172 @@ class EBML_DLL_API EbmlSemantic {
|
|||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#endif
|
#endif
|
||||||
bool Mandatory; ///< wether the element is mandatory in the context or not
|
bool Mandatory; ///< wether the element is mandatory in the context or not
|
||||||
bool Unique;
|
bool Unique;
|
||||||
const EbmlCallbacks & GetCallbacks;
|
const EbmlCallbacks & GetCallbacks;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef const class EbmlSemanticContext & (*_GetSemanticContext)();
|
typedef const class EbmlSemanticContext & (*_GetSemanticContext)();
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Context of the element
|
Context of the element
|
||||||
\todo allow more than one parent ?
|
\todo allow more than one parent ?
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlSemanticContext {
|
class EBML_DLL_API EbmlSemanticContext {
|
||||||
public:
|
public:
|
||||||
EbmlSemanticContext(size_t aSize,
|
EbmlSemanticContext(size_t aSize,
|
||||||
const EbmlSemantic *aMyTable,
|
const EbmlSemantic *aMyTable,
|
||||||
const EbmlSemanticContext *aUpTable,
|
const EbmlSemanticContext *aUpTable,
|
||||||
const _GetSemanticContext aGetGlobalContext,
|
const _GetSemanticContext aGetGlobalContext,
|
||||||
const EbmlCallbacks *aMasterElt)
|
const EbmlCallbacks *aMasterElt)
|
||||||
: GetGlobalContext(aGetGlobalContext), MyTable(aMyTable), Size(aSize),
|
: GetGlobalContext(aGetGlobalContext), MyTable(aMyTable), Size(aSize),
|
||||||
UpTable(aUpTable), MasterElt(aMasterElt) {}
|
UpTable(aUpTable), MasterElt(aMasterElt) {}
|
||||||
|
|
||||||
bool operator!=(const EbmlSemanticContext & aElt) const {
|
bool operator!=(const EbmlSemanticContext & aElt) const {
|
||||||
return ((Size != aElt.Size) || (MyTable != aElt.MyTable) ||
|
return ((Size != aElt.Size) || (MyTable != aElt.MyTable) ||
|
||||||
(UpTable != aElt.UpTable) || (GetGlobalContext != aElt.GetGlobalContext) |
|
(UpTable != aElt.UpTable) || (GetGlobalContext != aElt.GetGlobalContext) |
|
||||||
(MasterElt != aElt.MasterElt));
|
(MasterElt != aElt.MasterElt));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline size_t GetSize() const { return Size; }
|
inline size_t GetSize() const { return Size; }
|
||||||
inline const EbmlCallbacks* GetMaster() const { return MasterElt; }
|
inline const EbmlCallbacks* GetMaster() const { return MasterElt; }
|
||||||
inline const EbmlSemanticContext* Parent() const { return UpTable; }
|
inline const EbmlSemanticContext* Parent() const { return UpTable; }
|
||||||
const EbmlSemantic & GetSemantic(size_t i) const;
|
const EbmlSemantic & GetSemantic(size_t i) const;
|
||||||
|
|
||||||
const _GetSemanticContext GetGlobalContext; ///< global elements supported at this level
|
const _GetSemanticContext GetGlobalContext; ///< global elements supported at this level
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#endif
|
#endif
|
||||||
const EbmlSemantic *MyTable; ///< First element in the table
|
const EbmlSemantic *MyTable; ///< First element in the table
|
||||||
size_t Size; ///< number of elements in the table
|
size_t Size; ///< number of elements in the table
|
||||||
const EbmlSemanticContext *UpTable; ///< Parent element
|
const EbmlSemanticContext *UpTable; ///< Parent element
|
||||||
/// \todo replace with the global context directly
|
/// \todo replace with the global context directly
|
||||||
const EbmlCallbacks *MasterElt;
|
const EbmlCallbacks *MasterElt;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\class EbmlElement
|
\class EbmlElement
|
||||||
\brief Hold basic informations about an EBML element (ID + length)
|
\brief Hold basic informations about an EBML element (ID + length)
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlElement {
|
class EBML_DLL_API EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlElement(uint64 aDefaultSize, bool bValueSet = false);
|
EbmlElement(uint64 aDefaultSize, bool bValueSet = false);
|
||||||
virtual ~EbmlElement();
|
virtual ~EbmlElement();
|
||||||
|
|
||||||
/// Set the minimum length that will be used to write the element size (-1 = optimal)
|
/// Set the minimum length that will be used to write the element size (-1 = optimal)
|
||||||
void SetSizeLength(int NewSizeLength) {SizeLength = NewSizeLength;}
|
void SetSizeLength(int NewSizeLength) {SizeLength = NewSizeLength;}
|
||||||
int GetSizeLength() const {return SizeLength;}
|
int GetSizeLength() const {return SizeLength;}
|
||||||
|
|
||||||
static EbmlElement * FindNextElement(IOCallback & DataStream, const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel = 1);
|
static EbmlElement * FindNextElement(IOCallback & DataStream, const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel = 1);
|
||||||
static EbmlElement * FindNextID(IOCallback & DataStream, const EbmlCallbacks & ClassInfos, uint64 MaxDataSize);
|
static EbmlElement * FindNextID(IOCallback & DataStream, const EbmlCallbacks & ClassInfos, uint64 MaxDataSize);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief find the next element with the same ID
|
\brief find the next element with the same ID
|
||||||
*/
|
*/
|
||||||
EbmlElement * FindNext(IOCallback & DataStream, uint64 MaxDataSize);
|
EbmlElement * FindNext(IOCallback & DataStream, uint64 MaxDataSize);
|
||||||
|
|
||||||
EbmlElement * SkipData(EbmlStream & DataStream, const EbmlSemanticContext & Context, EbmlElement * TestReadElt = NULL, bool AllowDummyElt = false);
|
EbmlElement * SkipData(EbmlStream & DataStream, const EbmlSemanticContext & Context, EbmlElement * TestReadElt = NULL, bool AllowDummyElt = false);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Give a copy of the element, all data inside the element is copied
|
\brief Give a copy of the element, all data inside the element is copied
|
||||||
\return NULL if there is not enough memory
|
\return NULL if there is not enough memory
|
||||||
*/
|
*/
|
||||||
virtual EbmlElement * Clone() const = 0;
|
virtual EbmlElement * Clone() const = 0;
|
||||||
|
|
||||||
virtual operator const EbmlId &() const = 0;
|
virtual operator const EbmlId &() const = 0;
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
virtual const char *DebugName() const = 0;
|
virtual const char *DebugName() const = 0;
|
||||||
virtual const EbmlSemanticContext &Context() const = 0;
|
virtual const EbmlSemanticContext &Context() const = 0;
|
||||||
#else
|
#else
|
||||||
/// return the generic callback to monitor a derived class
|
/// return the generic callback to monitor a derived class
|
||||||
virtual const EbmlCallbacks & Generic() const = 0;
|
virtual const EbmlCallbacks & Generic() const = 0;
|
||||||
#endif
|
#endif
|
||||||
virtual EbmlElement & CreateElement() const = 0;
|
virtual EbmlElement & CreateElement() const = 0;
|
||||||
|
|
||||||
// by default only allow to set element as finite (override when needed)
|
// by default only allow to set element as finite (override when needed)
|
||||||
virtual bool SetSizeInfinite(bool bIsInfinite = true) {return !bIsInfinite;}
|
virtual bool SetSizeInfinite(bool bIsInfinite = true) {return !bIsInfinite;}
|
||||||
|
|
||||||
virtual bool ValidateSize() const = 0;
|
virtual bool ValidateSize() const = 0;
|
||||||
|
|
||||||
uint64 GetElementPosition() const {
|
uint64 GetElementPosition() const {
|
||||||
return ElementPosition;
|
return ElementPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 ElementSize(bool bWithDefault = false) const; /// return the size of the header+data, before writing
|
uint64 ElementSize(bool bWithDefault = false) const; /// return the size of the header+data, before writing
|
||||||
|
|
||||||
filepos_t Render(IOCallback & output, bool bWithDefault = false, bool bKeepPosition = false, bool bForceRender = false);
|
filepos_t Render(IOCallback & output, bool bWithDefault = false, bool bKeepPosition = false, bool bForceRender = false);
|
||||||
|
|
||||||
virtual filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false) = 0; /// update the Size of the Data stored
|
virtual filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false) = 0; /// update the Size of the Data stored
|
||||||
virtual filepos_t GetSize() const {return Size;} /// return the size of the data stored in the element, on reading
|
virtual filepos_t GetSize() const {return Size;} /// return the size of the data stored in the element, on reading
|
||||||
|
|
||||||
virtual filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA) = 0;
|
virtual filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA) = 0;
|
||||||
virtual void Read(EbmlStream & inDataStream, const EbmlSemanticContext & Context, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt = false, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
virtual void Read(EbmlStream & inDataStream, const EbmlSemanticContext & Context, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt = false, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
|
|
||||||
bool IsLocked() const {return bLocked;}
|
bool IsLocked() const {return bLocked;}
|
||||||
void Lock(bool bLock = true) { bLocked = bLock;}
|
void Lock(bool bLock = true) { bLocked = bLock;}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief default comparison for elements that can't be compared
|
\brief default comparison for elements that can't be compared
|
||||||
*/
|
*/
|
||||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||||
static bool CompareElements(const EbmlElement *A, const EbmlElement *B);
|
static bool CompareElements(const EbmlElement *A, const EbmlElement *B);
|
||||||
|
|
||||||
virtual bool IsDummy() const {return false;}
|
virtual bool IsDummy() const {return false;}
|
||||||
virtual bool IsMaster() const {return false;}
|
virtual bool IsMaster() const {return false;}
|
||||||
|
|
||||||
uint8 HeadSize() const {
|
uint8 HeadSize() const {
|
||||||
return EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(Size, SizeLength, bSizeIsFinite);
|
return EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(Size, SizeLength, bSizeIsFinite);
|
||||||
} /// return the size of the head, on reading/writing
|
} /// return the size of the head, on reading/writing
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Force the size of an element
|
\brief Force the size of an element
|
||||||
\warning only possible if the size is "undefined"
|
\warning only possible if the size is "undefined"
|
||||||
*/
|
*/
|
||||||
bool ForceSize(uint64 NewSize);
|
bool ForceSize(uint64 NewSize);
|
||||||
|
|
||||||
filepos_t OverwriteHead(IOCallback & output, bool bKeepPosition = false);
|
filepos_t OverwriteHead(IOCallback & output, bool bKeepPosition = false);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief void the content of the element (replace by EbmlVoid)
|
\brief void the content of the element (replace by EbmlVoid)
|
||||||
*/
|
*/
|
||||||
uint64 VoidMe(IOCallback & output, bool bWithDefault = false);
|
uint64 VoidMe(IOCallback & output, bool bWithDefault = false);
|
||||||
|
|
||||||
bool DefaultISset() const {return DefaultIsSet;}
|
bool DefaultISset() const {return DefaultIsSet;}
|
||||||
virtual bool IsDefaultValue() const = 0;
|
virtual bool IsDefaultValue() const = 0;
|
||||||
bool IsFiniteSize() const {return bSizeIsFinite;}
|
bool IsFiniteSize() const {return bSizeIsFinite;}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief set the default size of an element
|
\brief set the default size of an element
|
||||||
*/
|
*/
|
||||||
virtual void SetDefaultSize(uint64 aDefaultSize) {DefaultSize = aDefaultSize;}
|
virtual void SetDefaultSize(uint64 aDefaultSize) {DefaultSize = aDefaultSize;}
|
||||||
|
|
||||||
bool ValueIsSet() const {return bValueIsSet;}
|
bool ValueIsSet() const {return bValueIsSet;}
|
||||||
|
|
||||||
inline uint64 GetEndPosition() const {
|
inline uint64 GetEndPosition() const {
|
||||||
assert(bSizeIsFinite); // we don't know where the end is
|
assert(bSizeIsFinite); // we don't know where the end is
|
||||||
return SizePosition + CodedSizeLength(Size, SizeLength, bSizeIsFinite) + Size;
|
return SizePosition + CodedSizeLength(Size, SizeLength, bSizeIsFinite) + Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/*!
|
/*!
|
||||||
\brief find any element in the stream
|
\brief find any element in the stream
|
||||||
\return a DummyRawElement if the element is unknown or NULL if the element dummy is not allowed
|
\return a DummyRawElement if the element is unknown or NULL if the element dummy is not allowed
|
||||||
*/
|
*/
|
||||||
static EbmlElement *CreateElementUsingContext(const EbmlId & aID, const EbmlSemanticContext & Context, int & LowLevel, bool IsGlobalContext, bool bAllowDummy = false, unsigned int MaxLowerLevel = 1);
|
static EbmlElement *CreateElementUsingContext(const EbmlId & aID, const EbmlSemanticContext & Context, int & LowLevel, bool IsGlobalContext, bool bAllowDummy = false, unsigned int MaxLowerLevel = 1);
|
||||||
|
|
||||||
filepos_t RenderHead(IOCallback & output, bool bForceRender, bool bWithDefault = false, bool bKeepPosition = false);
|
filepos_t RenderHead(IOCallback & output, bool bForceRender, bool bWithDefault = false, bool bKeepPosition = false);
|
||||||
filepos_t MakeRenderHead(IOCallback & output, bool bKeepPosition);
|
filepos_t MakeRenderHead(IOCallback & output, bool bKeepPosition);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief prepare the data before writing them (in case it's not already done by default)
|
\brief prepare the data before writing them (in case it's not already done by default)
|
||||||
*/
|
*/
|
||||||
virtual filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false) = 0;
|
virtual filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false) = 0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief special constructor for cloning
|
\brief special constructor for cloning
|
||||||
*/
|
*/
|
||||||
EbmlElement(const EbmlElement & ElementToClone);
|
EbmlElement(const EbmlElement & ElementToClone);
|
||||||
|
|
||||||
inline uint64 GetDefaultSize() const {return DefaultSize;}
|
inline uint64 GetDefaultSize() const {return DefaultSize;}
|
||||||
inline void SetSize_(uint64 aSize) {Size = aSize;}
|
inline void SetSize_(uint64 aSize) {Size = aSize;}
|
||||||
@ -494,17 +494,17 @@ class EBML_DLL_API EbmlElement {
|
|||||||
inline uint64 GetSizePosition() const {return SizePosition;}
|
inline uint64 GetSizePosition() const {return SizePosition;}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#endif
|
#endif
|
||||||
uint64 Size; ///< the size of the data to write
|
uint64 Size; ///< the size of the data to write
|
||||||
uint64 DefaultSize; ///< Minimum data size to fill on rendering (0 = optimal)
|
uint64 DefaultSize; ///< Minimum data size to fill on rendering (0 = optimal)
|
||||||
int SizeLength; /// the minimum size on which the size will be written (0 = optimal)
|
int SizeLength; /// the minimum size on which the size will be written (0 = optimal)
|
||||||
bool bSizeIsFinite;
|
bool bSizeIsFinite;
|
||||||
uint64 ElementPosition;
|
uint64 ElementPosition;
|
||||||
uint64 SizePosition;
|
uint64 SizePosition;
|
||||||
bool bValueIsSet;
|
bool bValueIsSet;
|
||||||
bool DefaultIsSet;
|
bool DefaultIsSet;
|
||||||
bool bLocked;
|
bool bLocked;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -58,63 +58,63 @@ enum endianess {
|
|||||||
template<class TYPE, endianess ENDIAN> class Endian
|
template<class TYPE, endianess ENDIAN> class Endian
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Endian() {}
|
Endian() {}
|
||||||
|
|
||||||
Endian(const TYPE value)
|
Endian(const TYPE value)
|
||||||
{
|
{
|
||||||
memcpy(&platform_value, &value, sizeof(TYPE));
|
memcpy(&platform_value, &value, sizeof(TYPE));
|
||||||
process_endian();
|
process_endian();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Endian & Eval(const binary *endian_buffer)
|
inline Endian & Eval(const binary *endian_buffer)
|
||||||
{
|
{
|
||||||
//endian_value = *(TYPE *)(endian_buffer);
|
//endian_value = *(TYPE *)(endian_buffer);
|
||||||
memcpy(&endian_value, endian_buffer, sizeof(TYPE)); // Some (all?) RISC processors do not allow reading objects bigger than 1 byte from non-aligned addresses, and endian_buffer may point to a non-aligned address.
|
memcpy(&endian_value, endian_buffer, sizeof(TYPE)); // Some (all?) RISC processors do not allow reading objects bigger than 1 byte from non-aligned addresses, and endian_buffer may point to a non-aligned address.
|
||||||
process_platform();
|
process_platform();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Fill(binary *endian_buffer) const
|
inline void Fill(binary *endian_buffer) const
|
||||||
{
|
{
|
||||||
//*(TYPE*)endian_buffer = endian_value;
|
//*(TYPE*)endian_buffer = endian_value;
|
||||||
memcpy(endian_buffer, &endian_value, sizeof(TYPE)); // See above.
|
memcpy(endian_buffer, &endian_value, sizeof(TYPE)); // See above.
|
||||||
}
|
}
|
||||||
|
|
||||||
inline operator const TYPE&() const { return platform_value; }
|
inline operator const TYPE&() const { return platform_value; }
|
||||||
// inline TYPE endian() const { return endian_value; }
|
// inline TYPE endian() const { return endian_value; }
|
||||||
inline const TYPE &endian() const { return endian_value; }
|
inline const TYPE &endian() const { return endian_value; }
|
||||||
inline size_t size() const { return sizeof(TYPE); }
|
inline size_t size() const { return sizeof(TYPE); }
|
||||||
inline bool operator!=(const binary *buffer) const {return *((TYPE*)buffer) == platform_value;}
|
inline bool operator!=(const binary *buffer) const {return *((TYPE*)buffer) == platform_value;}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
TYPE platform_value;
|
TYPE platform_value;
|
||||||
TYPE endian_value;
|
TYPE endian_value;
|
||||||
|
|
||||||
inline void process_endian()
|
inline void process_endian()
|
||||||
{
|
{
|
||||||
endian_value = platform_value;
|
endian_value = platform_value;
|
||||||
#ifdef WORDS_BIGENDIAN
|
#ifdef WORDS_BIGENDIAN
|
||||||
if (ENDIAN == little_endian)
|
if (ENDIAN == little_endian)
|
||||||
#else // _ENDIANESS_
|
#else // _ENDIANESS_
|
||||||
if (ENDIAN == big_endian)
|
if (ENDIAN == big_endian)
|
||||||
#endif // _ENDIANESS_
|
#endif // _ENDIANESS_
|
||||||
std::reverse(reinterpret_cast<uint8*>(&endian_value),reinterpret_cast<uint8*>(&endian_value+1));
|
std::reverse(reinterpret_cast<uint8*>(&endian_value),reinterpret_cast<uint8*>(&endian_value+1));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void process_platform()
|
inline void process_platform()
|
||||||
{
|
{
|
||||||
platform_value = endian_value;
|
platform_value = endian_value;
|
||||||
#ifdef WORDS_BIGENDIAN
|
#ifdef WORDS_BIGENDIAN
|
||||||
if (ENDIAN == little_endian)
|
if (ENDIAN == little_endian)
|
||||||
#else // _ENDIANESS_
|
#else // _ENDIANESS_
|
||||||
if (ENDIAN == big_endian)
|
if (ENDIAN == big_endian)
|
||||||
#endif // _ENDIANESS_
|
#endif // _ENDIANESS_
|
||||||
std::reverse(reinterpret_cast<uint8*>(&platform_value),reinterpret_cast<uint8*>(&platform_value+1));
|
std::reverse(reinterpret_cast<uint8*>(&platform_value),reinterpret_cast<uint8*>(&platform_value+1));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_FLOAT_H
|
#ifndef LIBEBML_FLOAT_H
|
||||||
#define LIBEBML_FLOAT_H
|
#define LIBEBML_FLOAT_H
|
||||||
@ -46,60 +46,60 @@ START_LIBEBML_NAMESPACE
|
|||||||
\brief Handle all operations on a float EBML element
|
\brief Handle all operations on a float EBML element
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlFloat : public EbmlElement {
|
class EBML_DLL_API EbmlFloat : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
enum Precision {
|
enum Precision {
|
||||||
FLOAT_32
|
FLOAT_32
|
||||||
,FLOAT_64
|
,FLOAT_64
|
||||||
};
|
};
|
||||||
|
|
||||||
EbmlFloat(const Precision prec = FLOAT_32);
|
EbmlFloat(const Precision prec = FLOAT_32);
|
||||||
EbmlFloat(const double DefaultValue, const Precision prec = FLOAT_32);
|
EbmlFloat(const double DefaultValue, const Precision prec = FLOAT_32);
|
||||||
EbmlFloat(const EbmlFloat & ElementToClone);
|
EbmlFloat(const EbmlFloat & ElementToClone);
|
||||||
|
|
||||||
virtual bool ValidateSize() const
|
virtual bool ValidateSize() const
|
||||||
{
|
{
|
||||||
return (GetSize() == 4 || GetSize() == 8);
|
return (GetSize() == 4 || GetSize() == 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
void SetPrecision(const EbmlFloat::Precision prec = FLOAT_32)
|
void SetPrecision(const EbmlFloat::Precision prec = FLOAT_32)
|
||||||
{
|
{
|
||||||
if (prec == FLOAT_64)
|
if (prec == FLOAT_64)
|
||||||
SetSize_(8);
|
SetSize_(8);
|
||||||
else
|
else
|
||||||
SetSize_(4); // default size
|
SetSize_(4); // default size
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// EbmlFloat & operator=(const float NewValue) { Value = NewValue; return *this;}
|
// EbmlFloat & operator=(const float NewValue) { Value = NewValue; return *this;}
|
||||||
EbmlFloat & operator=(const double NewValue) { Value = NewValue; SetValueIsSet(); return *this;}
|
EbmlFloat & operator=(const double NewValue) { Value = NewValue; SetValueIsSet(); return *this;}
|
||||||
|
|
||||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||||
|
|
||||||
operator float() const;
|
operator float() const;
|
||||||
operator double() const;
|
operator double() const;
|
||||||
|
|
||||||
EbmlFloat &SetValue(double NewValue);
|
EbmlFloat &SetValue(double NewValue);
|
||||||
double GetValue() const;
|
double GetValue() const;
|
||||||
|
|
||||||
void SetDefaultValue(double);
|
void SetDefaultValue(double);
|
||||||
|
|
||||||
double DefaultVal() const;
|
double DefaultVal() const;
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return (DefaultISset() && Value == DefaultValue);
|
return (DefaultISset() && Value == DefaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
double Value; /// The actual value of the element
|
double Value; /// The actual value of the element
|
||||||
double DefaultValue;
|
double DefaultValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlHead.h 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: EbmlHead.h 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_HEAD_H
|
#ifndef LIBEBML_HEAD_H
|
||||||
#define LIBEBML_HEAD_H
|
#define LIBEBML_HEAD_H
|
||||||
@ -42,8 +42,8 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
DECLARE_EBML_MASTER(EbmlHead)
|
DECLARE_EBML_MASTER(EbmlHead)
|
||||||
public:
|
public:
|
||||||
EbmlHead(const EbmlHead & ElementToClone) : EbmlMaster(ElementToClone) {}
|
EbmlHead(const EbmlHead & ElementToClone) : EbmlMaster(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EbmlHead)
|
EBML_CONCRETE_CLASS(EbmlHead)
|
||||||
};
|
};
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlId.h 936 2004-11-10 20:46:28Z mosu $
|
\version \$Id: EbmlId.h 936 2004-11-10 20:46:28Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_ID_H
|
#ifndef LIBEBML_ID_H
|
||||||
#define LIBEBML_ID_H
|
#define LIBEBML_ID_H
|
||||||
@ -50,39 +50,39 @@ START_LIBEBML_NAMESPACE
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\class EbmlId
|
\class EbmlId
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlId {
|
class EBML_DLL_API EbmlId {
|
||||||
public:
|
public:
|
||||||
EbmlId(const binary aValue[4], const unsigned int aLength)
|
EbmlId(const binary aValue[4], const unsigned int aLength)
|
||||||
:Length(aLength)
|
:Length(aLength)
|
||||||
{
|
{
|
||||||
Value = 0;
|
Value = 0;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
for (i=0; i<aLength; i++) {
|
for (i=0; i<aLength; i++) {
|
||||||
Value <<= 8;
|
Value <<= 8;
|
||||||
Value += aValue[i];
|
Value += aValue[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlId(const uint32 aValue, const unsigned int aLength)
|
EbmlId(const uint32 aValue, const unsigned int aLength)
|
||||||
:Value(aValue), Length(aLength) {}
|
:Value(aValue), Length(aLength) {}
|
||||||
|
|
||||||
inline bool operator==(const EbmlId & TestId) const
|
inline bool operator==(const EbmlId & TestId) const
|
||||||
{
|
{
|
||||||
return ((TestId.Length == Length) && (TestId.Value == Value));
|
return ((TestId.Length == Length) && (TestId.Value == Value));
|
||||||
}
|
}
|
||||||
inline bool operator!=(const EbmlId & TestId) const
|
inline bool operator!=(const EbmlId & TestId) const
|
||||||
{
|
{
|
||||||
return !(*this == TestId);
|
return !(*this == TestId);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Fill(binary * Buffer) const {
|
inline void Fill(binary * Buffer) const {
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
for (i = 0; i<Length; i++) {
|
for (i = 0; i<Length; i++) {
|
||||||
Buffer[i] = (Value >> (8*(Length-i-1))) & 0xFF;
|
Buffer[i] = (Value >> (8*(Length-i-1))) & 0xFF;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline size_t GetLength() const { return Length; }
|
inline size_t GetLength() const { return Length; }
|
||||||
inline uint32 GetValue() const { return Value; }
|
inline uint32 GetValue() const { return Value; }
|
||||||
@ -90,8 +90,8 @@ class EBML_DLL_API EbmlId {
|
|||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#endif
|
#endif
|
||||||
uint32 Value;
|
uint32 Value;
|
||||||
size_t Length;
|
size_t Length;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlMaster.h 1232 2005-10-15 15:56:52Z robux4 $
|
\version \$Id: EbmlMaster.h 1232 2005-10-15 15:56:52Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_MASTER_H
|
#ifndef LIBEBML_MASTER_H
|
||||||
#define LIBEBML_MASTER_H
|
#define LIBEBML_MASTER_H
|
||||||
@ -57,70 +57,70 @@ const bool bChecksumUsedByDefault = false;
|
|||||||
\brief Handle all operations on an EBML element that contains other EBML elements
|
\brief Handle all operations on an EBML element that contains other EBML elements
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlMaster : public EbmlElement {
|
class EBML_DLL_API EbmlMaster : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlMaster(const EbmlSemanticContext & aContext, bool bSizeIsKnown = true);
|
EbmlMaster(const EbmlSemanticContext & aContext, bool bSizeIsKnown = true);
|
||||||
EbmlMaster(const EbmlMaster & ElementToClone);
|
EbmlMaster(const EbmlMaster & ElementToClone);
|
||||||
virtual bool ValidateSize() const {return true;}
|
virtual bool ValidateSize() const {return true;}
|
||||||
/*!
|
/*!
|
||||||
\warning be carefull to clear the memory allocated in the ElementList elsewhere
|
\warning be carefull to clear the memory allocated in the ElementList elsewhere
|
||||||
*/
|
*/
|
||||||
virtual ~EbmlMaster();
|
virtual ~EbmlMaster();
|
||||||
|
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Set wether the size is finite (size is known in advance when writing, or infinite size is not known on writing)
|
\brief Set wether the size is finite (size is known in advance when writing, or infinite size is not known on writing)
|
||||||
*/
|
*/
|
||||||
bool SetSizeInfinite(bool aIsInfinite = true) {SetSizeIsFinite(!aIsInfinite); return true;}
|
bool SetSizeInfinite(bool aIsInfinite = true) {SetSizeIsFinite(!aIsInfinite); return true;}
|
||||||
|
|
||||||
bool PushElement(EbmlElement & element);
|
bool PushElement(EbmlElement & element);
|
||||||
uint64 GetSize() const {
|
uint64 GetSize() const {
|
||||||
if (IsFiniteSize())
|
if (IsFiniteSize())
|
||||||
return EbmlElement::GetSize();
|
return EbmlElement::GetSize();
|
||||||
else
|
else
|
||||||
return (0-1);
|
return (0-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 GetDataStart() const {
|
uint64 GetDataStart() const {
|
||||||
return GetElementPosition() + EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize());
|
return GetElementPosition() + EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief find the element corresponding to the ID of the element, NULL if not found
|
\brief find the element corresponding to the ID of the element, NULL if not found
|
||||||
*/
|
*/
|
||||||
EbmlElement *FindElt(const EbmlCallbacks & Callbacks) const;
|
EbmlElement *FindElt(const EbmlCallbacks & Callbacks) const;
|
||||||
/*!
|
/*!
|
||||||
\brief find the first element corresponding to the ID of the element
|
\brief find the first element corresponding to the ID of the element
|
||||||
*/
|
*/
|
||||||
EbmlElement *FindFirstElt(const EbmlCallbacks & Callbacks, bool bCreateIfNull);
|
EbmlElement *FindFirstElt(const EbmlCallbacks & Callbacks, bool bCreateIfNull);
|
||||||
EbmlElement *FindFirstElt(const EbmlCallbacks & Callbacks) const;
|
EbmlElement *FindFirstElt(const EbmlCallbacks & Callbacks) const;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief find the element of the same type of PasElt following in the list of elements
|
\brief find the element of the same type of PasElt following in the list of elements
|
||||||
*/
|
*/
|
||||||
EbmlElement *FindNextElt(const EbmlElement & PastElt, bool bCreateIfNull);
|
EbmlElement *FindNextElt(const EbmlElement & PastElt, bool bCreateIfNull);
|
||||||
EbmlElement *FindNextElt(const EbmlElement & PastElt) const;
|
EbmlElement *FindNextElt(const EbmlElement & PastElt) const;
|
||||||
EbmlElement *AddNewElt(const EbmlCallbacks & Callbacks);
|
EbmlElement *AddNewElt(const EbmlCallbacks & Callbacks);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief add an element at a specified location
|
\brief add an element at a specified location
|
||||||
*/
|
*/
|
||||||
bool InsertElement(EbmlElement & element, size_t position = 0);
|
bool InsertElement(EbmlElement & element, size_t position = 0);
|
||||||
bool InsertElement(EbmlElement & element, const EbmlElement & before);
|
bool InsertElement(EbmlElement & element, const EbmlElement & before);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Read the data and keep the known children
|
\brief Read the data and keep the known children
|
||||||
*/
|
*/
|
||||||
void Read(EbmlStream & inDataStream, const EbmlSemanticContext & Context, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
void Read(EbmlStream & inDataStream, const EbmlSemanticContext & Context, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief sort Data when they can
|
\brief sort Data when they can
|
||||||
*/
|
*/
|
||||||
void Sort();
|
void Sort();
|
||||||
|
|
||||||
size_t ListSize() const {return ElementList.size();}
|
size_t ListSize() const {return ElementList.size();}
|
||||||
std::vector<EbmlElement *> const &GetElementList() const {return ElementList;}
|
std::vector<EbmlElement *> const &GetElementList() const {return ElementList;}
|
||||||
std::vector<EbmlElement *> &GetElementList() {return ElementList;}
|
std::vector<EbmlElement *> &GetElementList() {return ElementList;}
|
||||||
|
|
||||||
@ -133,76 +133,76 @@ class EBML_DLL_API EbmlMaster : public EbmlElement {
|
|||||||
inline EBML_MASTER_CONST_RITERATOR rbegin() const {return ElementList.rbegin();}
|
inline EBML_MASTER_CONST_RITERATOR rbegin() const {return ElementList.rbegin();}
|
||||||
inline EBML_MASTER_CONST_RITERATOR rend() const {return ElementList.rend();}
|
inline EBML_MASTER_CONST_RITERATOR rend() const {return ElementList.rend();}
|
||||||
|
|
||||||
EbmlElement * operator[](unsigned int position) {return ElementList[position];}
|
EbmlElement * operator[](unsigned int position) {return ElementList[position];}
|
||||||
const EbmlElement * operator[](unsigned int position) const {return ElementList[position];}
|
const EbmlElement * operator[](unsigned int position) const {return ElementList[position];}
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return (ElementList.size() == 0);
|
return (ElementList.size() == 0);
|
||||||
}
|
}
|
||||||
virtual bool IsMaster() const {return true;}
|
virtual bool IsMaster() const {return true;}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief verify that all mandatory elements are present
|
\brief verify that all mandatory elements are present
|
||||||
\note usefull after reading or before writing
|
\note usefull after reading or before writing
|
||||||
*/
|
*/
|
||||||
bool CheckMandatory() const;
|
bool CheckMandatory() const;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Remove an element from the list of the master
|
\brief Remove an element from the list of the master
|
||||||
*/
|
*/
|
||||||
void Remove(size_t Index);
|
void Remove(size_t Index);
|
||||||
void Remove(EBML_MASTER_ITERATOR & Itr);
|
void Remove(EBML_MASTER_ITERATOR & Itr);
|
||||||
void Remove(EBML_MASTER_RITERATOR & Itr);
|
void Remove(EBML_MASTER_RITERATOR & Itr);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief remove all elements, even the mandatory ones
|
\brief remove all elements, even the mandatory ones
|
||||||
*/
|
*/
|
||||||
void RemoveAll() {ElementList.clear();}
|
void RemoveAll() {ElementList.clear();}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief facility for Master elements to write only the head and force the size later
|
\brief facility for Master elements to write only the head and force the size later
|
||||||
\warning
|
\warning
|
||||||
*/
|
*/
|
||||||
filepos_t WriteHead(IOCallback & output, int SizeLength, bool bWithDefault = false);
|
filepos_t WriteHead(IOCallback & output, int SizeLength, bool bWithDefault = false);
|
||||||
|
|
||||||
void EnableChecksum(bool bIsEnabled = true) { bChecksumUsed = bIsEnabled; }
|
void EnableChecksum(bool bIsEnabled = true) { bChecksumUsed = bIsEnabled; }
|
||||||
bool HasChecksum() const {return bChecksumUsed;}
|
bool HasChecksum() const {return bChecksumUsed;}
|
||||||
bool VerifyChecksum() const;
|
bool VerifyChecksum() const;
|
||||||
uint32 GetCrc32() const {return Checksum.GetCrc32();}
|
uint32 GetCrc32() const {return Checksum.GetCrc32();}
|
||||||
void ForceChecksum(uint32 NewChecksum) {
|
void ForceChecksum(uint32 NewChecksum) {
|
||||||
Checksum.ForceCrc32(NewChecksum);
|
Checksum.ForceCrc32(NewChecksum);
|
||||||
bChecksumUsed = true;
|
bChecksumUsed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief drill down all sub-elements, finding any missing elements
|
\brief drill down all sub-elements, finding any missing elements
|
||||||
*/
|
*/
|
||||||
std::vector<std::string> FindAllMissingElements();
|
std::vector<std::string> FindAllMissingElements();
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
std::vector<EbmlElement *> ElementList;
|
std::vector<EbmlElement *> ElementList;
|
||||||
|
|
||||||
const EbmlSemanticContext & Context;
|
const EbmlSemanticContext & Context;
|
||||||
|
|
||||||
bool bChecksumUsed;
|
bool bChecksumUsed;
|
||||||
EbmlCrc32 Checksum;
|
EbmlCrc32 Checksum;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/*!
|
/*!
|
||||||
\brief Add all the mandatory elements to the list
|
\brief Add all the mandatory elements to the list
|
||||||
*/
|
*/
|
||||||
bool ProcessMandatory();
|
bool ProcessMandatory();
|
||||||
};
|
};
|
||||||
|
|
||||||
///< \todo add a restriction to only elements legal in the context
|
///< \todo add a restriction to only elements legal in the context
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type & GetChild(EbmlMaster & Master)
|
Type & GetChild(EbmlMaster & Master)
|
||||||
{
|
{
|
||||||
return *(static_cast<Type *>(Master.FindFirstElt(EBML_INFO(Type), true)));
|
return *(static_cast<Type *>(Master.FindFirstElt(EBML_INFO(Type), true)));
|
||||||
}
|
}
|
||||||
// call with
|
// call with
|
||||||
// MyDocType = GetChild<EDocType>(TestHead);
|
// MyDocType = GetChild<EDocType>(TestHead);
|
||||||
@ -210,19 +210,19 @@ Type & GetChild(EbmlMaster & Master)
|
|||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type * FindChild(EbmlMaster & Master)
|
Type * FindChild(EbmlMaster & Master)
|
||||||
{
|
{
|
||||||
return static_cast<Type *>(Master.FindFirstElt(EBML_INFO(Type), false));
|
return static_cast<Type *>(Master.FindFirstElt(EBML_INFO(Type), false));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type & GetNextChild(EbmlMaster & Master, const Type & PastElt)
|
Type & GetNextChild(EbmlMaster & Master, const Type & PastElt)
|
||||||
{
|
{
|
||||||
return *(static_cast<Type *>(Master.FindNextElt(PastElt, true)));
|
return *(static_cast<Type *>(Master.FindNextElt(PastElt, true)));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Type>
|
template <typename Type>
|
||||||
Type & AddNewChild(EbmlMaster & Master)
|
Type & AddNewChild(EbmlMaster & Master)
|
||||||
{
|
{
|
||||||
return *(static_cast<Type *>(Master.AddNewElt(EBML_INFO(Type))));
|
return *(static_cast<Type *>(Master.AddNewElt(EBML_INFO(Type))));
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,11 +29,11 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Julien Coloos <suiryc @ users.sf.net>
|
\author Julien Coloos <suiryc @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_SINTEGER_H
|
#ifndef LIBEBML_SINTEGER_H
|
||||||
#define LIBEBML_SINTEGER_H
|
#define LIBEBML_SINTEGER_H
|
||||||
@ -52,48 +52,48 @@ const int DEFAULT_INT_SIZE = 1; ///< optimal size stored
|
|||||||
\brief Handle all operations on a signed integer EBML element
|
\brief Handle all operations on a signed integer EBML element
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlSInteger : public EbmlElement {
|
class EBML_DLL_API EbmlSInteger : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlSInteger();
|
EbmlSInteger();
|
||||||
EbmlSInteger(int64 DefaultValue);
|
EbmlSInteger(int64 DefaultValue);
|
||||||
EbmlSInteger(const EbmlSInteger & ElementToClone);
|
EbmlSInteger(const EbmlSInteger & ElementToClone);
|
||||||
|
|
||||||
EbmlSInteger & operator = (int64 NewValue) {Value = NewValue; SetValueIsSet(); return *this;}
|
EbmlSInteger & operator = (int64 NewValue) {Value = NewValue; SetValueIsSet(); return *this;}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Set the default size of the integer (usually 1,2,4 or 8)
|
Set the default size of the integer (usually 1,2,4 or 8)
|
||||||
*/
|
*/
|
||||||
virtual void SetDefaultSize(uint64 nDefaultSize = DEFAULT_INT_SIZE) {EbmlElement::SetDefaultSize(nDefaultSize); SetSize_(nDefaultSize);}
|
virtual void SetDefaultSize(uint64 nDefaultSize = DEFAULT_INT_SIZE) {EbmlElement::SetDefaultSize(nDefaultSize); SetSize_(nDefaultSize);}
|
||||||
|
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() <= 8);}
|
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() <= 8);}
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||||
|
|
||||||
operator int8() const;
|
operator int8() const;
|
||||||
operator int16() const;
|
operator int16() const;
|
||||||
operator int32() const;
|
operator int32() const;
|
||||||
operator int64() const;
|
operator int64() const;
|
||||||
|
|
||||||
EbmlSInteger &SetValue(int64 NewValue);
|
EbmlSInteger &SetValue(int64 NewValue);
|
||||||
int64 GetValue() const;
|
int64 GetValue() const;
|
||||||
|
|
||||||
void SetDefaultValue(int64 aValue) {assert(!DefaultISset()); DefaultValue = aValue; SetDefaultIsSet();}
|
void SetDefaultValue(int64 aValue) {assert(!DefaultISset()); DefaultValue = aValue; SetDefaultIsSet();}
|
||||||
|
|
||||||
int64 DefaultVal() const {assert(DefaultISset()); return DefaultValue;}
|
int64 DefaultVal() const {assert(DefaultISset()); return DefaultValue;}
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return (DefaultISset() && Value == DefaultValue);
|
return (DefaultISset() && Value == DefaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
int64 Value; /// The actual value of the element
|
int64 Value; /// The actual value of the element
|
||||||
int64 DefaultValue;
|
int64 DefaultValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_STREAM_H
|
#ifndef LIBEBML_STREAM_H
|
||||||
#define LIBEBML_STREAM_H
|
#define LIBEBML_STREAM_H
|
||||||
@ -47,20 +47,20 @@ START_LIBEBML_NAMESPACE
|
|||||||
\brief Handle an input/output stream of EBML elements
|
\brief Handle an input/output stream of EBML elements
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlStream {
|
class EBML_DLL_API EbmlStream {
|
||||||
public:
|
public:
|
||||||
EbmlStream(IOCallback & output);
|
EbmlStream(IOCallback & output);
|
||||||
~EbmlStream();
|
~EbmlStream();
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Find a possible next ID in the data stream
|
\brief Find a possible next ID in the data stream
|
||||||
\param MaxDataSize The maximum possible of the data in the element (for sanity checks)
|
\param MaxDataSize The maximum possible of the data in the element (for sanity checks)
|
||||||
\note the user will have to delete that element later
|
\note the user will have to delete that element later
|
||||||
*/
|
*/
|
||||||
EbmlElement * FindNextID(const EbmlCallbacks & ClassInfos, uint64 MaxDataSize);
|
EbmlElement * FindNextID(const EbmlCallbacks & ClassInfos, uint64 MaxDataSize);
|
||||||
|
|
||||||
EbmlElement * FindNextElement(const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel = 1);
|
EbmlElement * FindNextElement(const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel = 1);
|
||||||
|
|
||||||
inline IOCallback & I_O() {return Stream;}
|
inline IOCallback & I_O() {return Stream;}
|
||||||
operator IOCallback &() {return Stream;}
|
operator IOCallback &() {return Stream;}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
@ -68,7 +68,7 @@ class EBML_DLL_API EbmlStream {
|
|||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
IOCallback & Stream;
|
IOCallback & Stream;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_STRING_H
|
#ifndef LIBEBML_STRING_H
|
||||||
#define LIBEBML_STRING_H
|
#define LIBEBML_STRING_H
|
||||||
@ -48,39 +48,39 @@ START_LIBEBML_NAMESPACE
|
|||||||
\brief Handle all operations on a printable string EBML element
|
\brief Handle all operations on a printable string EBML element
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlString : public EbmlElement {
|
class EBML_DLL_API EbmlString : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlString();
|
EbmlString();
|
||||||
EbmlString(const std::string & aDefaultValue);
|
EbmlString(const std::string & aDefaultValue);
|
||||||
EbmlString(const EbmlString & ElementToClone);
|
EbmlString(const EbmlString & ElementToClone);
|
||||||
|
|
||||||
virtual ~EbmlString() {}
|
virtual ~EbmlString() {}
|
||||||
|
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize();} // any size is possible
|
virtual bool ValidateSize() const {return IsFiniteSize();} // any size is possible
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
EbmlString & operator=(const std::string &);
|
EbmlString & operator=(const std::string &);
|
||||||
operator const std::string &() const;
|
operator const std::string &() const;
|
||||||
|
|
||||||
EbmlString &SetValue(std::string const &NewValue);
|
EbmlString &SetValue(std::string const &NewValue);
|
||||||
std::string GetValue() const;
|
std::string GetValue() const;
|
||||||
|
|
||||||
void SetDefaultValue(std::string &);
|
void SetDefaultValue(std::string &);
|
||||||
|
|
||||||
const std::string & DefaultVal() const;
|
const std::string & DefaultVal() const;
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return (DefaultISset() && Value == DefaultValue);
|
return (DefaultISset() && Value == DefaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
std::string Value; /// The actual value of the element
|
std::string Value; /// The actual value of the element
|
||||||
std::string DefaultValue;
|
std::string DefaultValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlSubHead.h 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: EbmlSubHead.h 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_SUBHEAD_H
|
#ifndef LIBEBML_SUBHEAD_H
|
||||||
#define LIBEBML_SUBHEAD_H
|
#define LIBEBML_SUBHEAD_H
|
||||||
@ -44,50 +44,50 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
DECLARE_EBML_UINTEGER(EVersion)
|
DECLARE_EBML_UINTEGER(EVersion)
|
||||||
public:
|
public:
|
||||||
EVersion(const EVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
EVersion(const EVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EVersion)
|
EBML_CONCRETE_CLASS(EVersion)
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_EBML_UINTEGER(EReadVersion)
|
DECLARE_EBML_UINTEGER(EReadVersion)
|
||||||
public:
|
public:
|
||||||
EReadVersion(const EReadVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
EReadVersion(const EReadVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EReadVersion)
|
EBML_CONCRETE_CLASS(EReadVersion)
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_EBML_UINTEGER(EMaxIdLength)
|
DECLARE_EBML_UINTEGER(EMaxIdLength)
|
||||||
public:
|
public:
|
||||||
EMaxIdLength(const EMaxIdLength & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
EMaxIdLength(const EMaxIdLength & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EMaxIdLength)
|
EBML_CONCRETE_CLASS(EMaxIdLength)
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_EBML_UINTEGER(EMaxSizeLength)
|
DECLARE_EBML_UINTEGER(EMaxSizeLength)
|
||||||
public:
|
public:
|
||||||
EMaxSizeLength(const EMaxSizeLength & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
EMaxSizeLength(const EMaxSizeLength & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EMaxSizeLength)
|
EBML_CONCRETE_CLASS(EMaxSizeLength)
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_EBML_STRING(EDocType)
|
DECLARE_EBML_STRING(EDocType)
|
||||||
public:
|
public:
|
||||||
EDocType(const EDocType & ElementToClone) : EbmlString(ElementToClone) {}
|
EDocType(const EDocType & ElementToClone) : EbmlString(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EDocType)
|
EBML_CONCRETE_CLASS(EDocType)
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_EBML_UINTEGER(EDocTypeVersion)
|
DECLARE_EBML_UINTEGER(EDocTypeVersion)
|
||||||
public:
|
public:
|
||||||
EDocTypeVersion(const EDocTypeVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
EDocTypeVersion(const EDocTypeVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EDocTypeVersion)
|
EBML_CONCRETE_CLASS(EDocTypeVersion)
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_EBML_UINTEGER(EDocTypeReadVersion)
|
DECLARE_EBML_UINTEGER(EDocTypeReadVersion)
|
||||||
public:
|
public:
|
||||||
EDocTypeReadVersion(const EDocTypeReadVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
EDocTypeReadVersion(const EDocTypeReadVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EDocTypeReadVersion)
|
EBML_CONCRETE_CLASS(EDocTypeReadVersion)
|
||||||
};
|
};
|
||||||
|
@ -27,8 +27,8 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlTypes.h 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: EbmlTypes.h 639 2004-07-09 20:59:14Z mosu $
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_TYPES_H
|
#ifndef LIBEBML_TYPES_H
|
||||||
#define LIBEBML_TYPES_H
|
#define LIBEBML_TYPES_H
|
||||||
@ -62,9 +62,9 @@ typedef Endian<bits80,big_endian> big_80bits;
|
|||||||
|
|
||||||
|
|
||||||
enum ScopeMode {
|
enum ScopeMode {
|
||||||
SCOPE_PARTIAL_DATA = 0,
|
SCOPE_PARTIAL_DATA = 0,
|
||||||
SCOPE_ALL_DATA,
|
SCOPE_ALL_DATA,
|
||||||
SCOPE_NO_DATA
|
SCOPE_NO_DATA
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,11 +29,11 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Julien Coloos <suiryc @ users.sf.net>
|
\author Julien Coloos <suiryc @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_UINTEGER_H
|
#ifndef LIBEBML_UINTEGER_H
|
||||||
#define LIBEBML_UINTEGER_H
|
#define LIBEBML_UINTEGER_H
|
||||||
@ -50,48 +50,48 @@ const int DEFAULT_UINT_SIZE = 0; ///< optimal size stored
|
|||||||
\brief Handle all operations on an unsigned integer EBML element
|
\brief Handle all operations on an unsigned integer EBML element
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlUInteger : public EbmlElement {
|
class EBML_DLL_API EbmlUInteger : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlUInteger();
|
EbmlUInteger();
|
||||||
EbmlUInteger(uint64 DefaultValue);
|
EbmlUInteger(uint64 DefaultValue);
|
||||||
EbmlUInteger(const EbmlUInteger & ElementToClone);
|
EbmlUInteger(const EbmlUInteger & ElementToClone);
|
||||||
|
|
||||||
EbmlUInteger & operator=(uint64 NewValue) {Value = NewValue; SetValueIsSet(); return *this;}
|
EbmlUInteger & operator=(uint64 NewValue) {Value = NewValue; SetValueIsSet(); return *this;}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Set the default size of the integer (usually 1,2,4 or 8)
|
Set the default size of the integer (usually 1,2,4 or 8)
|
||||||
*/
|
*/
|
||||||
virtual void SetDefaultSize(uint64 nDefaultSize = DEFAULT_UINT_SIZE) {EbmlElement::SetDefaultSize(nDefaultSize); SetSize_(nDefaultSize);}
|
virtual void SetDefaultSize(uint64 nDefaultSize = DEFAULT_UINT_SIZE) {EbmlElement::SetDefaultSize(nDefaultSize); SetSize_(nDefaultSize);}
|
||||||
|
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() <= 8);}
|
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() <= 8);}
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||||
|
|
||||||
operator uint8() const;
|
operator uint8() const;
|
||||||
operator uint16() const;
|
operator uint16() const;
|
||||||
operator uint32() const;
|
operator uint32() const;
|
||||||
operator uint64() const;
|
operator uint64() const;
|
||||||
|
|
||||||
EbmlUInteger &SetValue(uint64 NewValue);
|
EbmlUInteger &SetValue(uint64 NewValue);
|
||||||
uint64 GetValue() const;
|
uint64 GetValue() const;
|
||||||
|
|
||||||
void SetDefaultValue(uint64);
|
void SetDefaultValue(uint64);
|
||||||
|
|
||||||
uint64 DefaultVal() const;
|
uint64 DefaultVal() const;
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return (DefaultISset() && Value == DefaultValue);
|
return (DefaultISset() && Value == DefaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
uint64 Value; /// The actual value of the element
|
uint64 Value; /// The actual value of the element
|
||||||
uint64 DefaultValue;
|
uint64 DefaultValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,11 +29,11 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_UNICODE_STRING_H
|
#ifndef LIBEBML_UNICODE_STRING_H
|
||||||
#define LIBEBML_UNICODE_STRING_H
|
#define LIBEBML_UNICODE_STRING_H
|
||||||
@ -52,87 +52,87 @@ START_LIBEBML_NAMESPACE
|
|||||||
*/
|
*/
|
||||||
class EBML_DLL_API UTFstring {
|
class EBML_DLL_API UTFstring {
|
||||||
public:
|
public:
|
||||||
typedef wchar_t value_type;
|
typedef wchar_t value_type;
|
||||||
|
|
||||||
UTFstring();
|
UTFstring();
|
||||||
UTFstring(const wchar_t *); // should be NULL terminated
|
UTFstring(const wchar_t *); // should be NULL terminated
|
||||||
UTFstring(const UTFstring &);
|
UTFstring(const UTFstring &);
|
||||||
UTFstring(std::wstring const &);
|
UTFstring(std::wstring const &);
|
||||||
|
|
||||||
virtual ~UTFstring();
|
virtual ~UTFstring();
|
||||||
bool operator==(const UTFstring&) const;
|
bool operator==(const UTFstring&) const;
|
||||||
inline bool operator!=(const UTFstring &cmp) const
|
inline bool operator!=(const UTFstring &cmp) const
|
||||||
{
|
{
|
||||||
return !(*this == cmp);
|
return !(*this == cmp);
|
||||||
}
|
}
|
||||||
UTFstring & operator=(const UTFstring &);
|
UTFstring & operator=(const UTFstring &);
|
||||||
UTFstring & operator=(const wchar_t *);
|
UTFstring & operator=(const wchar_t *);
|
||||||
UTFstring & operator=(wchar_t);
|
UTFstring & operator=(wchar_t);
|
||||||
|
|
||||||
/// Return length of string
|
/// Return length of string
|
||||||
size_t length() const {return _Length;}
|
size_t length() const {return _Length;}
|
||||||
|
|
||||||
operator const wchar_t*() const;
|
operator const wchar_t*() const;
|
||||||
const wchar_t* c_str() const {return _Data;}
|
const wchar_t* c_str() const {return _Data;}
|
||||||
|
|
||||||
const std::string & GetUTF8() const {return UTF8string;}
|
const std::string & GetUTF8() const {return UTF8string;}
|
||||||
void SetUTF8(const std::string &);
|
void SetUTF8(const std::string &);
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
size_t _Length; ///< length of the UCS string excluding the \0
|
size_t _Length; ///< length of the UCS string excluding the \0
|
||||||
wchar_t* _Data; ///< internal UCS representation
|
wchar_t* _Data; ///< internal UCS representation
|
||||||
std::string UTF8string;
|
std::string UTF8string;
|
||||||
static bool wcscmp_internal(const wchar_t *str1, const wchar_t *str2);
|
static bool wcscmp_internal(const wchar_t *str1, const wchar_t *str2);
|
||||||
void UpdateFromUTF8();
|
void UpdateFromUTF8();
|
||||||
void UpdateFromUCS2();
|
void UpdateFromUCS2();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\class EbmlUnicodeString
|
\class EbmlUnicodeString
|
||||||
\brief Handle all operations on a Unicode string EBML element
|
\brief Handle all operations on a Unicode string EBML element
|
||||||
\note internally treated as a string made of wide characters (ie UCS-2 or UCS-4 depending on the machine)
|
\note internally treated as a string made of wide characters (ie UCS-2 or UCS-4 depending on the machine)
|
||||||
*/
|
*/
|
||||||
class EBML_DLL_API EbmlUnicodeString : public EbmlElement {
|
class EBML_DLL_API EbmlUnicodeString : public EbmlElement {
|
||||||
public:
|
public:
|
||||||
EbmlUnicodeString();
|
EbmlUnicodeString();
|
||||||
EbmlUnicodeString(const UTFstring & DefaultValue);
|
EbmlUnicodeString(const UTFstring & DefaultValue);
|
||||||
EbmlUnicodeString(const EbmlUnicodeString & ElementToClone);
|
EbmlUnicodeString(const EbmlUnicodeString & ElementToClone);
|
||||||
|
|
||||||
virtual ~EbmlUnicodeString() {}
|
virtual ~EbmlUnicodeString() {}
|
||||||
|
|
||||||
virtual bool ValidateSize() const {return IsFiniteSize();} // any size is possible
|
virtual bool ValidateSize() const {return IsFiniteSize();} // any size is possible
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||||
|
|
||||||
EbmlUnicodeString & operator=(const UTFstring &); ///< platform dependant code
|
EbmlUnicodeString & operator=(const UTFstring &); ///< platform dependant code
|
||||||
operator const UTFstring &() const;
|
operator const UTFstring &() const;
|
||||||
|
|
||||||
EbmlUnicodeString &SetValue(UTFstring const &NewValue);
|
EbmlUnicodeString &SetValue(UTFstring const &NewValue);
|
||||||
EbmlUnicodeString &SetValueUTF8(std::string const &NewValue);
|
EbmlUnicodeString &SetValueUTF8(std::string const &NewValue);
|
||||||
UTFstring GetValue() const;
|
UTFstring GetValue() const;
|
||||||
std::string GetValueUTF8() const;
|
std::string GetValueUTF8() const;
|
||||||
|
|
||||||
void SetDefaultValue(UTFstring &);
|
void SetDefaultValue(UTFstring &);
|
||||||
|
|
||||||
const UTFstring & DefaultVal() const;
|
const UTFstring & DefaultVal() const;
|
||||||
|
|
||||||
bool IsDefaultValue() const {
|
bool IsDefaultValue() const {
|
||||||
return (DefaultISset() && Value == DefaultValue);
|
return (DefaultISset() && Value == DefaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(EBML_STRICT_API)
|
#if defined(EBML_STRICT_API)
|
||||||
private:
|
private:
|
||||||
#else
|
#else
|
||||||
protected:
|
protected:
|
||||||
#endif
|
#endif
|
||||||
UTFstring Value; /// The actual value of the element
|
UTFstring Value; /// The actual value of the element
|
||||||
UTFstring DefaultValue;
|
UTFstring DefaultValue;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_VERSION_H
|
#ifndef LIBEBML_VERSION_H
|
||||||
#define LIBEBML_VERSION_H
|
#define LIBEBML_VERSION_H
|
||||||
@ -48,7 +48,7 @@ extern const std::string EbmlCodeVersion;
|
|||||||
extern const std::string EbmlCodeDate;
|
extern const std::string EbmlCodeDate;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo Closer relation between an element and the context it comes from (context is an element attribute ?)
|
\todo Closer relation between an element and the context it comes from (context is an element attribute ?)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlVoid.h 1079 2005-03-03 13:18:14Z robux4 $
|
\version \$Id: EbmlVoid.h 1079 2005-03-03 13:18:14Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_VOID_H
|
#ifndef LIBEBML_VOID_H
|
||||||
#define LIBEBML_VOID_H
|
#define LIBEBML_VOID_H
|
||||||
@ -42,28 +42,28 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
DECLARE_EBML_BINARY(EbmlVoid)
|
DECLARE_EBML_BINARY(EbmlVoid)
|
||||||
public:
|
public:
|
||||||
EbmlVoid(const EbmlVoid & ElementToClone) :EbmlBinary(ElementToClone){}
|
EbmlVoid(const EbmlVoid & ElementToClone) :EbmlBinary(ElementToClone){}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Set the size of the data (not the complete size of the element)
|
\brief Set the size of the data (not the complete size of the element)
|
||||||
*/
|
*/
|
||||||
void SetSize(uint64 aSize) {SetSize_(aSize);}
|
void SetSize(uint64 aSize) {SetSize_(aSize);}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\note overwrite to write fake data
|
\note overwrite to write fake data
|
||||||
*/
|
*/
|
||||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Replace the void element content (written) with this one
|
\brief Replace the void element content (written) with this one
|
||||||
*/
|
*/
|
||||||
uint64 ReplaceWith(EbmlElement & EltToReplaceWith, IOCallback & output, bool ComeBackAfterward = true, bool bWithDefault = false);
|
uint64 ReplaceWith(EbmlElement & EltToReplaceWith, IOCallback & output, bool ComeBackAfterward = true, bool bWithDefault = false);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Void the content of an element
|
\brief Void the content of an element
|
||||||
*/
|
*/
|
||||||
uint64 Overwrite(const EbmlElement & EltToVoid, IOCallback & output, bool ComeBackAfterward = true, bool bWithDefault = false);
|
uint64 Overwrite(const EbmlElement & EltToVoid, IOCallback & output, bool ComeBackAfterward = true, bool bWithDefault = false);
|
||||||
|
|
||||||
EBML_CONCRETE_CLASS(EbmlVoid)
|
EBML_CONCRETE_CLASS(EbmlVoid)
|
||||||
};
|
};
|
||||||
|
@ -27,8 +27,8 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: IOCallback.h 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: IOCallback.h 639 2004-07-09 20:59:14Z mosu $
|
||||||
*/
|
*/
|
||||||
#ifndef MATROSKA_IOCALLBACK_H
|
#ifndef MATROSKA_IOCALLBACK_H
|
||||||
#define MATROSKA_IOCALLBACK_H
|
#define MATROSKA_IOCALLBACK_H
|
||||||
@ -45,70 +45,70 @@ START_LIBEBML_NAMESPACE
|
|||||||
|
|
||||||
enum seek_mode
|
enum seek_mode
|
||||||
{
|
{
|
||||||
seek_beginning=SEEK_SET
|
seek_beginning=SEEK_SET
|
||||||
,seek_end=SEEK_END
|
,seek_end=SEEK_END
|
||||||
,seek_current=SEEK_CUR
|
,seek_current=SEEK_CUR
|
||||||
};
|
};
|
||||||
|
|
||||||
class EBML_DLL_API IOCallback
|
class EBML_DLL_API IOCallback
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual ~IOCallback(){}
|
virtual ~IOCallback(){}
|
||||||
|
|
||||||
// The read callback works like most other read functions. You specify the
|
// The read callback works like most other read functions. You specify the
|
||||||
// file, the buffer and the size and the function returns the bytes read.
|
// file, the buffer and the size and the function returns the bytes read.
|
||||||
// If an error occurs or the file pointer points to the end of the file 0 is returned.
|
// If an error occurs or the file pointer points to the end of the file 0 is returned.
|
||||||
// Users are encouraged to throw a descriptive exception, when an error occurs.
|
// Users are encouraged to throw a descriptive exception, when an error occurs.
|
||||||
virtual uint32 read(void*Buffer,size_t Size)=0;
|
virtual uint32 read(void*Buffer,size_t Size)=0;
|
||||||
|
|
||||||
// Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
// Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
||||||
// or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
// or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
||||||
// or false (0), when the seek fails.
|
// or false (0), when the seek fails.
|
||||||
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning)=0;
|
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning)=0;
|
||||||
|
|
||||||
// This callback just works like its read pendant. It returns the number of bytes written.
|
// This callback just works like its read pendant. It returns the number of bytes written.
|
||||||
virtual size_t write(const void*Buffer,size_t Size)=0;
|
virtual size_t write(const void*Buffer,size_t Size)=0;
|
||||||
|
|
||||||
// Although the position is always positive, the return value of this callback is signed to
|
// Although the position is always positive, the return value of this callback is signed to
|
||||||
// easily allow negative values for returning errors. When an error occurs, the implementor
|
// easily allow negative values for returning errors. When an error occurs, the implementor
|
||||||
// should return -1 and the file pointer otherwise.
|
// should return -1 and the file pointer otherwise.
|
||||||
//
|
//
|
||||||
// If an error occurs, an exception should be thrown.
|
// If an error occurs, an exception should be thrown.
|
||||||
virtual uint64 getFilePointer()=0;
|
virtual uint64 getFilePointer()=0;
|
||||||
|
|
||||||
// The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
// The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
||||||
// library, this is equivalent to calling fclose. When the close is not successful, an exception
|
// library, this is equivalent to calling fclose. When the close is not successful, an exception
|
||||||
// should be thrown.
|
// should be thrown.
|
||||||
virtual void close()=0;
|
virtual void close()=0;
|
||||||
|
|
||||||
|
|
||||||
// The readFully is made virtual to allow derived classes to use another
|
// The readFully is made virtual to allow derived classes to use another
|
||||||
// implementation for this method, which e.g. does not read any data
|
// implementation for this method, which e.g. does not read any data
|
||||||
// unlike this does
|
// unlike this does
|
||||||
void readFully(void*Buffer,size_t Size);
|
void readFully(void*Buffer,size_t Size);
|
||||||
|
|
||||||
template<class STRUCT> void readStruct(STRUCT&Struct){readFully(&Struct,sizeof(Struct));}
|
template<class STRUCT> void readStruct(STRUCT&Struct){readFully(&Struct,sizeof(Struct));}
|
||||||
|
|
||||||
void writeFully(const void*Buffer,size_t Size);
|
void writeFully(const void*Buffer,size_t Size);
|
||||||
|
|
||||||
template<class STRUCT> void writeStruct(const STRUCT&Struct){writeFully(&Struct,sizeof(Struct));}
|
template<class STRUCT> void writeStruct(const STRUCT&Struct){writeFully(&Struct,sizeof(Struct));}
|
||||||
};
|
};
|
||||||
|
|
||||||
/* cygwin incompatible
|
/* cygwin incompatible
|
||||||
template<class TRAITS> std::basic_ostream<char,TRAITS>&operator<<(std::basic_ostream<char,TRAITS>&Stream,seek_mode Mode)
|
template<class TRAITS> std::basic_ostream<char,TRAITS>&operator<<(std::basic_ostream<char,TRAITS>&Stream,seek_mode Mode)
|
||||||
{
|
{
|
||||||
switch(Mode)
|
switch(Mode)
|
||||||
{
|
{
|
||||||
#define x(y) case seek_##y: Stream<<"seek_" #y; break
|
#define x(y) case seek_##y: Stream<<"seek_" #y; break
|
||||||
x(beginning);
|
x(beginning);
|
||||||
x(current);
|
x(current);
|
||||||
x(end);
|
x(end);
|
||||||
#undef x
|
#undef x
|
||||||
default:
|
default:
|
||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Stream;
|
return Stream;
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -27,9 +27,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: MemIOCallback.h 1298 2008-02-21 22:14:18Z mosu $
|
\version \$Id: MemIOCallback.h 1298 2008-02-21 22:14:18Z mosu $
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_MEMIOCALLBACK_H
|
#ifndef LIBEBML_MEMIOCALLBACK_H
|
||||||
#define LIBEBML_MEMIOCALLBACK_H
|
#define LIBEBML_MEMIOCALLBACK_H
|
||||||
@ -48,69 +48,69 @@ START_LIBEBML_NAMESPACE
|
|||||||
class EBML_DLL_API MemIOCallback : public IOCallback
|
class EBML_DLL_API MemIOCallback : public IOCallback
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
MemIOCallback(uint64 DefaultSize = 128);
|
MemIOCallback(uint64 DefaultSize = 128);
|
||||||
~MemIOCallback();
|
~MemIOCallback();
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Use this to copy some data to the Buffer from this classes data
|
Use this to copy some data to the Buffer from this classes data
|
||||||
*/
|
*/
|
||||||
uint32 read(void *Buffer, size_t Size);
|
uint32 read(void *Buffer, size_t Size);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
||||||
or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
||||||
or false (0), when the seek fails.
|
or false (0), when the seek fails.
|
||||||
*/
|
*/
|
||||||
void setFilePointer(int64 Offset, seek_mode Mode=seek_beginning);
|
void setFilePointer(int64 Offset, seek_mode Mode=seek_beginning);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
This callback just works like its read pendant. It returns the number of bytes written.
|
This callback just works like its read pendant. It returns the number of bytes written.
|
||||||
*/
|
*/
|
||||||
size_t write(const void *Buffer, size_t Size);
|
size_t write(const void *Buffer, size_t Size);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Although the position is always positive, the return value of this callback is signed to
|
Although the position is always positive, the return value of this callback is signed to
|
||||||
easily allow negative values for returning errors. When an error occurs, the implementor
|
easily allow negative values for returning errors. When an error occurs, the implementor
|
||||||
should return -1 and the file pointer otherwise.
|
should return -1 and the file pointer otherwise.
|
||||||
|
|
||||||
If an error occurs, an exception should be thrown.
|
If an error occurs, an exception should be thrown.
|
||||||
*/
|
*/
|
||||||
virtual uint64 getFilePointer() {return dataBufferPos;};
|
virtual uint64 getFilePointer() {return dataBufferPos;};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
||||||
library, this is equivalent to calling fclose. When the close is not successful, an exception
|
library, this is equivalent to calling fclose. When the close is not successful, an exception
|
||||||
should be thrown.
|
should be thrown.
|
||||||
*/
|
*/
|
||||||
void close() {};
|
void close() {};
|
||||||
|
|
||||||
binary *GetDataBuffer() const {return dataBuffer;};
|
binary *GetDataBuffer() const {return dataBuffer;};
|
||||||
uint64 GetDataBufferSize() {return dataBufferTotalSize;};
|
uint64 GetDataBufferSize() {return dataBufferTotalSize;};
|
||||||
void SetDataBufferSize(uint64 newDataBufferSize) {dataBufferTotalSize = newDataBufferSize;};
|
void SetDataBufferSize(uint64 newDataBufferSize) {dataBufferTotalSize = newDataBufferSize;};
|
||||||
/*!
|
/*!
|
||||||
Use this to write some data from another IOCallback
|
Use this to write some data from another IOCallback
|
||||||
*/
|
*/
|
||||||
uint32 write(IOCallback & IOToRead, size_t Size);
|
uint32 write(IOCallback & IOToRead, size_t Size);
|
||||||
|
|
||||||
bool IsOk() { return mOk; };
|
bool IsOk() { return mOk; };
|
||||||
const std::string &GetLastErrorStr() { return mLastErrorStr; };
|
const std::string &GetLastErrorStr() { return mLastErrorStr; };
|
||||||
protected:
|
protected:
|
||||||
bool mOk;
|
bool mOk;
|
||||||
std::string mLastErrorStr;
|
std::string mLastErrorStr;
|
||||||
|
|
||||||
binary *dataBuffer;
|
binary *dataBuffer;
|
||||||
/*!
|
/*!
|
||||||
Postion where we start 'writing' to the dataBuffer
|
Postion where we start 'writing' to the dataBuffer
|
||||||
*/
|
*/
|
||||||
uint64 dataBufferPos;
|
uint64 dataBufferPos;
|
||||||
/*!
|
/*!
|
||||||
Size of the data in the dataBuffer
|
Size of the data in the dataBuffer
|
||||||
*/
|
*/
|
||||||
uint64 dataBufferTotalSize;
|
uint64 dataBufferTotalSize;
|
||||||
/*!
|
/*!
|
||||||
Size of the memory malloc()/realloc()
|
Size of the memory malloc()/realloc()
|
||||||
*/
|
*/
|
||||||
uint64 dataBufferMemorySize;
|
uint64 dataBufferMemorySize;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,8 +27,8 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: StdIOCallback.h 1090 2005-03-16 12:47:59Z robux4 $
|
\version \$Id: StdIOCallback.h 1090 2005-03-16 12:47:59Z robux4 $
|
||||||
*/
|
*/
|
||||||
#ifndef LIBEBML_STDIOCALLBACK_H
|
#ifndef LIBEBML_STDIOCALLBACK_H
|
||||||
#define LIBEBML_STDIOCALLBACK_H
|
#define LIBEBML_STDIOCALLBACK_H
|
||||||
@ -51,49 +51,49 @@ class EBML_DLL_API CRTError:public std::runtime_error
|
|||||||
{
|
{
|
||||||
// Variablen...
|
// Variablen...
|
||||||
private:
|
private:
|
||||||
int Error;
|
int Error;
|
||||||
|
|
||||||
// Methoden...
|
// Methoden...
|
||||||
public:
|
public:
|
||||||
CRTError(int Error,const std::string&Description);
|
CRTError(int Error,const std::string&Description);
|
||||||
CRTError(const std::string&Description,int Error=errno);
|
CRTError(const std::string&Description,int Error=errno);
|
||||||
|
|
||||||
int getError()const throw(){return Error;}
|
int getError()const throw(){return Error;}
|
||||||
};
|
};
|
||||||
|
|
||||||
// This class is currently private to the library, so there's no MATROSKA_EXPORT.
|
// This class is currently private to the library, so there's no MATROSKA_EXPORT.
|
||||||
class EBML_DLL_API StdIOCallback:public IOCallback
|
class EBML_DLL_API StdIOCallback:public IOCallback
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
FILE*File;
|
FILE*File;
|
||||||
uint64 mCurrentPosition;
|
uint64 mCurrentPosition;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// StdIOCallback(const char*Path,const char*Mode);
|
// StdIOCallback(const char*Path,const char*Mode);
|
||||||
StdIOCallback(const char*Path, const open_mode Mode);
|
StdIOCallback(const char*Path, const open_mode Mode);
|
||||||
virtual ~StdIOCallback()throw();
|
virtual ~StdIOCallback()throw();
|
||||||
|
|
||||||
virtual uint32 read(void*Buffer,size_t Size);
|
virtual uint32 read(void*Buffer,size_t Size);
|
||||||
|
|
||||||
// Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
// Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
||||||
// or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
// or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
||||||
// or false (0), when the seek fails.
|
// or false (0), when the seek fails.
|
||||||
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning);
|
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning);
|
||||||
|
|
||||||
// This callback just works like its read pendant. It returns the number of bytes written.
|
// This callback just works like its read pendant. It returns the number of bytes written.
|
||||||
virtual size_t write(const void*Buffer,size_t Size);
|
virtual size_t write(const void*Buffer,size_t Size);
|
||||||
|
|
||||||
// Although the position is always positive, the return value of this callback is signed to
|
// Although the position is always positive, the return value of this callback is signed to
|
||||||
// easily allow negative values for returning errors. When an error occurs, the implementor
|
// easily allow negative values for returning errors. When an error occurs, the implementor
|
||||||
// should return -1 and the file pointer otherwise.
|
// should return -1 and the file pointer otherwise.
|
||||||
//
|
//
|
||||||
// If an error occurs, an exception should be thrown.
|
// If an error occurs, an exception should be thrown.
|
||||||
virtual uint64 getFilePointer();
|
virtual uint64 getFilePointer();
|
||||||
|
|
||||||
// The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
// The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
||||||
// library, this is equivalent to calling fclose. When the close is not successful, an exception
|
// library, this is equivalent to calling fclose. When the close is not successful, an exception
|
||||||
// should be thrown.
|
// should be thrown.
|
||||||
virtual void close();
|
virtual void close();
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -50,7 +50,7 @@ extern "C" {
|
|||||||
|
|
||||||
// Changed char is unsigned now (signedness was causing trouble in endil)
|
// Changed char is unsigned now (signedness was causing trouble in endil)
|
||||||
#if defined(_WIN32)
|
#if defined(_WIN32)
|
||||||
# if !defined(__GNUC__) // Microsoft Visual C++
|
# if !defined(__GNUC__) // Microsoft Visual C++
|
||||||
typedef signed __int64 int64;
|
typedef signed __int64 int64;
|
||||||
typedef signed __int32 int32;
|
typedef signed __int32 int32;
|
||||||
typedef signed __int16 int16;
|
typedef signed __int16 int16;
|
||||||
@ -74,7 +74,7 @@ extern "C" {
|
|||||||
# endif // __GNUC__
|
# endif // __GNUC__
|
||||||
#elif defined(__BEOS__)
|
#elif defined(__BEOS__)
|
||||||
#include <SupportDefs.h>
|
#include <SupportDefs.h>
|
||||||
#elif defined(DJGPP) /* SL : DJGPP doesn't support POSIX types ???? */
|
#elif defined(DJGPP) /* SL : DJGPP doesn't support POSIX types ???? */
|
||||||
typedef signed long long int64;
|
typedef signed long long int64;
|
||||||
typedef signed long int32;
|
typedef signed long int32;
|
||||||
typedef signed short int16;
|
typedef signed short int16;
|
||||||
|
232
src/Debug.cpp
232
src/Debug.cpp
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: Debug.cpp 1268 2007-01-19 10:15:08Z robux4 $
|
\version \$Id: Debug.cpp 1268 2007-01-19 10:15:08Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
@ -62,174 +62,174 @@ ADbg::ADbg(int level)
|
|||||||
,my_debug_output(true)
|
,my_debug_output(true)
|
||||||
,hFile(NULL)
|
,hFile(NULL)
|
||||||
{
|
{
|
||||||
prefix[0] = '\0';
|
prefix[0] = '\0';
|
||||||
OutPut(-1,"ADbg Creation at debug level = %d (0x%08X)",my_level,this);
|
OutPut(-1,"ADbg Creation at debug level = %d (0x%08X)",my_level,this);
|
||||||
}
|
}
|
||||||
|
|
||||||
ADbg::~ADbg()
|
ADbg::~ADbg()
|
||||||
{
|
{
|
||||||
unsetDebugFile();
|
unsetDebugFile();
|
||||||
OutPut(-1,"ADbg Deletion (0x%08X)",this);
|
OutPut(-1,"ADbg Deletion (0x%08X)",this);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int ADbg::_OutPut(const char * format,va_list params) const
|
inline int ADbg::_OutPut(const char * format,va_list params) const
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
char tst[1000];
|
char tst[1000];
|
||||||
char myformat[256];
|
char myformat[256];
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (my_time_included) {
|
if (my_time_included) {
|
||||||
SYSTEMTIME time;
|
SYSTEMTIME time;
|
||||||
GetSystemTime(&time);
|
GetSystemTime(&time);
|
||||||
if (prefix[0] == '\0')
|
if (prefix[0] == '\0')
|
||||||
wsprintfA(myformat,"%04d/%02d/%02d %02d:%02d:%02d.%03d UTC : %s\r\n",
|
wsprintfA(myformat,"%04d/%02d/%02d %02d:%02d:%02d.%03d UTC : %s\r\n",
|
||||||
time.wYear,
|
time.wYear,
|
||||||
time.wMonth,
|
time.wMonth,
|
||||||
time.wDay,
|
time.wDay,
|
||||||
time.wHour,
|
time.wHour,
|
||||||
time.wMinute,
|
time.wMinute,
|
||||||
time.wSecond,
|
time.wSecond,
|
||||||
time.wMilliseconds,
|
time.wMilliseconds,
|
||||||
format);
|
format);
|
||||||
else
|
else
|
||||||
wsprintfA(myformat,"%04d/%02d/%02d %02d:%02d:%02d.%03d UTC : %s - %s\r\n",
|
wsprintfA(myformat,"%04d/%02d/%02d %02d:%02d:%02d.%03d UTC : %s - %s\r\n",
|
||||||
time.wYear,
|
time.wYear,
|
||||||
time.wMonth,
|
time.wMonth,
|
||||||
time.wDay,
|
time.wDay,
|
||||||
time.wHour,
|
time.wHour,
|
||||||
time.wMinute,
|
time.wMinute,
|
||||||
time.wSecond,
|
time.wSecond,
|
||||||
time.wMilliseconds,
|
time.wMilliseconds,
|
||||||
prefix,
|
prefix,
|
||||||
format);
|
format);
|
||||||
} else {
|
} else {
|
||||||
if (prefix[0] == '\0')
|
if (prefix[0] == '\0')
|
||||||
wsprintfA( myformat, "%s\r\n", format);
|
wsprintfA( myformat, "%s\r\n", format);
|
||||||
else
|
else
|
||||||
wsprintfA( myformat, "%s - %s\r\n", prefix, format);
|
wsprintfA( myformat, "%s - %s\r\n", prefix, format);
|
||||||
}
|
}
|
||||||
result = vsprintf(tst,myformat,params);
|
result = vsprintf(tst,myformat,params);
|
||||||
|
|
||||||
if (my_debug_output)
|
if (my_debug_output)
|
||||||
OutputDebugStringA(tst);
|
OutputDebugStringA(tst);
|
||||||
|
|
||||||
if (my_use_file && (hFile != NULL)) {
|
if (my_use_file && (hFile != NULL)) {
|
||||||
SetFilePointer( hFile, 0, 0, FILE_END );
|
SetFilePointer( hFile, 0, 0, FILE_END );
|
||||||
DWORD written;
|
DWORD written;
|
||||||
WriteFile( hFile, tst, lstrlenA(tst), &written, NULL );
|
WriteFile( hFile, tst, lstrlenA(tst), &written, NULL );
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if (my_time_included) {
|
if (my_time_included) {
|
||||||
time_t nowSecs;
|
time_t nowSecs;
|
||||||
struct tm *now;
|
struct tm *now;
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
|
|
||||||
nowSecs = time(NULL);
|
nowSecs = time(NULL);
|
||||||
gettimeofday(&tv, NULL);
|
gettimeofday(&tv, NULL);
|
||||||
now = gmtime(&nowSecs);
|
now = gmtime(&nowSecs);
|
||||||
if (prefix[0] == '\0')
|
if (prefix[0] == '\0')
|
||||||
sprintf(myformat,"%04d/%02d/%02d %02d:%02d:%02ld.%03ld UTC : %s\r\n",
|
sprintf(myformat,"%04d/%02d/%02d %02d:%02d:%02ld.%03ld UTC : %s\r\n",
|
||||||
now->tm_year, now->tm_mon, now->tm_mday,
|
now->tm_year, now->tm_mon, now->tm_mday,
|
||||||
now->tm_hour, now->tm_min, tv.tv_sec,
|
now->tm_hour, now->tm_min, tv.tv_sec,
|
||||||
(long)tv.tv_usec / 1000, format);
|
(long)tv.tv_usec / 1000, format);
|
||||||
else
|
else
|
||||||
sprintf(myformat,"%04d/%02d/%02d %02d:%02d:%02ld.%03ld UTC : %s - %s\r\n",
|
sprintf(myformat,"%04d/%02d/%02d %02d:%02d:%02ld.%03ld UTC : %s - %s\r\n",
|
||||||
now->tm_year, now->tm_mon, now->tm_mday,
|
now->tm_year, now->tm_mon, now->tm_mday,
|
||||||
now->tm_hour, now->tm_min, tv.tv_sec,
|
now->tm_hour, now->tm_min, tv.tv_sec,
|
||||||
(long)tv.tv_usec / 1000, prefix, format);
|
(long)tv.tv_usec / 1000, prefix, format);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (prefix[0] == '\0')
|
if (prefix[0] == '\0')
|
||||||
sprintf( myformat, "%s\r\n", format);
|
sprintf( myformat, "%s\r\n", format);
|
||||||
else
|
else
|
||||||
sprintf( myformat, "%s - %s\r\n", prefix, format);
|
sprintf( myformat, "%s - %s\r\n", prefix, format);
|
||||||
}
|
}
|
||||||
|
|
||||||
result = vsprintf(tst,myformat,params);
|
result = vsprintf(tst,myformat,params);
|
||||||
|
|
||||||
if (my_debug_output)
|
if (my_debug_output)
|
||||||
fputs(tst, stderr);
|
fputs(tst, stderr);
|
||||||
|
|
||||||
if (my_use_file && (hFile != NULL))
|
if (my_use_file && (hFile != NULL))
|
||||||
fputs(tst, hFile);
|
fputs(tst, hFile);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
int ADbg::OutPut(int forLevel, const char * format,...) const
|
int ADbg::OutPut(int forLevel, const char * format,...) const
|
||||||
{
|
{
|
||||||
int result=0;
|
int result=0;
|
||||||
|
|
||||||
if (forLevel >= my_level) {
|
if (forLevel >= my_level) {
|
||||||
va_list tstlist;
|
va_list tstlist;
|
||||||
|
|
||||||
va_start(tstlist, format);
|
va_start(tstlist, format);
|
||||||
|
|
||||||
result = _OutPut(format,tstlist);
|
result = _OutPut(format,tstlist);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
int ADbg::OutPut(const char * format,...) const
|
int ADbg::OutPut(const char * format,...) const
|
||||||
{
|
{
|
||||||
va_list tstlist;
|
va_list tstlist;
|
||||||
|
|
||||||
va_start(tstlist, format);
|
va_start(tstlist, format);
|
||||||
|
|
||||||
return _OutPut(format,tstlist);
|
return _OutPut(format,tstlist);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ADbg::setDebugFile(const char * NewFilename) {
|
bool ADbg::setDebugFile(const char * NewFilename) {
|
||||||
bool result;
|
bool result;
|
||||||
result = unsetDebugFile();
|
result = unsetDebugFile();
|
||||||
|
|
||||||
if (result) {
|
if (result) {
|
||||||
result = false;
|
result = false;
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
hFile = CreateFileA(NewFilename, GENERIC_WRITE, FILE_SHARE_WRITE|FILE_SHARE_READ, NULL, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL );
|
hFile = CreateFileA(NewFilename, GENERIC_WRITE, FILE_SHARE_WRITE|FILE_SHARE_READ, NULL, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL );
|
||||||
|
|
||||||
if (hFile != INVALID_HANDLE_VALUE) {
|
if (hFile != INVALID_HANDLE_VALUE) {
|
||||||
SetFilePointer( hFile, 0, 0, FILE_END );
|
SetFilePointer( hFile, 0, 0, FILE_END );
|
||||||
|
|
||||||
result = true;
|
result = true;
|
||||||
#else
|
#else
|
||||||
hFile = fopen(NewFilename, "w+");
|
hFile = fopen(NewFilename, "w+");
|
||||||
if (hFile != NULL) {
|
if (hFile != NULL) {
|
||||||
fseek(hFile, 0, SEEK_END);
|
fseek(hFile, 0, SEEK_END);
|
||||||
#endif
|
#endif
|
||||||
OutPut(-1,"Debug hFile Opening succeeded");
|
OutPut(-1,"Debug hFile Opening succeeded");
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
OutPut(-1,"Debug hFile %s Opening failed",NewFilename);
|
OutPut(-1,"Debug hFile %s Opening failed",NewFilename);
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ADbg::unsetDebugFile() {
|
bool ADbg::unsetDebugFile() {
|
||||||
bool result = (hFile == NULL);
|
bool result = (hFile == NULL);
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (hFile != NULL) {
|
if (hFile != NULL) {
|
||||||
result = (CloseHandle(hFile) != 0);
|
result = (CloseHandle(hFile) != 0);
|
||||||
#else
|
#else
|
||||||
if (hFile != NULL) {
|
if (hFile != NULL) {
|
||||||
result = (fclose(hFile) == 0);
|
result = (fclose(hFile) == 0);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (result) {
|
if (result) {
|
||||||
OutPut(-1,"Debug hFile Closing succeeded");
|
OutPut(-1,"Debug hFile Closing succeeded");
|
||||||
hFile = NULL;
|
hFile = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // defined(LIBEBML_DEBUG)
|
#endif // defined(LIBEBML_DEBUG)
|
||||||
|
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Julien Coloos <suiryc @ users.sf.net>
|
\author Julien Coloos <suiryc @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
#include <string>
|
#include <string>
|
||||||
@ -49,18 +49,18 @@ EbmlBinary::EbmlBinary()
|
|||||||
EbmlBinary::EbmlBinary(const EbmlBinary & ElementToClone)
|
EbmlBinary::EbmlBinary(const EbmlBinary & ElementToClone)
|
||||||
:EbmlElement(ElementToClone)
|
:EbmlElement(ElementToClone)
|
||||||
{
|
{
|
||||||
if (ElementToClone.Data == NULL)
|
if (ElementToClone.Data == NULL)
|
||||||
Data = NULL;
|
Data = NULL;
|
||||||
else {
|
else {
|
||||||
Data = (binary *)malloc(GetSize() * sizeof(binary));
|
Data = (binary *)malloc(GetSize() * sizeof(binary));
|
||||||
assert(Data != NULL);
|
assert(Data != NULL);
|
||||||
memcpy(Data, ElementToClone.Data, GetSize());
|
memcpy(Data, ElementToClone.Data, GetSize());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlBinary::~EbmlBinary(void) {
|
EbmlBinary::~EbmlBinary(void) {
|
||||||
if(Data)
|
if(Data)
|
||||||
free(Data);
|
free(Data);
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlBinary::operator const binary &() const {return *Data;}
|
EbmlBinary::operator const binary &() const {return *Data;}
|
||||||
@ -68,40 +68,40 @@ EbmlBinary::operator const binary &() const {return *Data;}
|
|||||||
|
|
||||||
filepos_t EbmlBinary::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlBinary::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
output.writeFully(Data,GetSize());
|
output.writeFully(Data,GetSize());
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\note no Default binary value handled
|
\note no Default binary value handled
|
||||||
*/
|
*/
|
||||||
uint64 EbmlBinary::UpdateSize(bool /* bWithDefault */, bool /* bForceRender */)
|
uint64 EbmlBinary::UpdateSize(bool /* bWithDefault */, bool /* bForceRender */)
|
||||||
{
|
{
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlBinary::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlBinary::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (Data != NULL)
|
if (Data != NULL)
|
||||||
free(Data);
|
free(Data);
|
||||||
|
|
||||||
if (ReadFully == SCOPE_NO_DATA || !GetSize())
|
if (ReadFully == SCOPE_NO_DATA || !GetSize())
|
||||||
{
|
{
|
||||||
Data = NULL;
|
Data = NULL;
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
Data = (binary *)malloc(GetSize());
|
Data = (binary *)malloc(GetSize());
|
||||||
if (Data == NULL)
|
if (Data == NULL)
|
||||||
throw CRTError(std::string("Error allocating data"));
|
throw CRTError(std::string("Error allocating data"));
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
return input.read(Data, GetSize());
|
return input.read(Data, GetSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlBinary::operator==(const EbmlBinary & ElementToCompare) const
|
bool EbmlBinary::operator==(const EbmlBinary & ElementToCompare) const
|
||||||
{
|
{
|
||||||
return ((GetSize() == ElementToCompare.GetSize()) && !memcmp(Data, ElementToCompare.Data, GetSize()));
|
return ((GetSize() == ElementToCompare.GetSize()) && !memcmp(Data, ElementToCompare.Data, GetSize()));
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlContexts.cpp 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: EbmlContexts.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlContexts.h"
|
#include "ebml/EbmlContexts.h"
|
||||||
#include "ebml/EbmlCrc32.h"
|
#include "ebml/EbmlCrc32.h"
|
||||||
@ -41,8 +41,8 @@ START_LIBEBML_NAMESPACE
|
|||||||
|
|
||||||
static const EbmlSemantic EbmlGlobal_ContextList[2] =
|
static const EbmlSemantic EbmlGlobal_ContextList[2] =
|
||||||
{
|
{
|
||||||
EbmlSemantic(false, false, EBML_INFO(EbmlCrc32)), ///< EbmlCrc32
|
EbmlSemantic(false, false, EBML_INFO(EbmlCrc32)), ///< EbmlCrc32
|
||||||
EbmlSemantic(false, false, EBML_INFO(EbmlVoid)), ///< EbmlVoid
|
EbmlSemantic(false, false, EBML_INFO(EbmlVoid)), ///< EbmlVoid
|
||||||
};
|
};
|
||||||
|
|
||||||
const EbmlSemanticContext Context_EbmlGlobal = EbmlSemanticContext(0, NULL, NULL, *GetEbmlGlobal_Context, NULL);
|
const EbmlSemanticContext Context_EbmlGlobal = EbmlSemanticContext(0, NULL, NULL, *GetEbmlGlobal_Context, NULL);
|
||||||
@ -51,7 +51,7 @@ static const EbmlSemanticContext EbmlGlobal_Context = EbmlSemanticContext(counto
|
|||||||
|
|
||||||
const EbmlSemanticContext & GetEbmlGlobal_Context()
|
const EbmlSemanticContext & GetEbmlGlobal_Context()
|
||||||
{
|
{
|
||||||
return EbmlGlobal_Context;
|
return EbmlGlobal_Context;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlCrc32.cpp 1155 2005-05-06 11:43:38Z robux4 $
|
\version \$Id: EbmlCrc32.cpp 1155 2005-05-06 11:43:38Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlCrc32.h"
|
#include "ebml/EbmlCrc32.h"
|
||||||
#include "ebml/EbmlContexts.h"
|
#include "ebml/EbmlContexts.h"
|
||||||
@ -54,129 +54,129 @@ DEFINE_EBML_CLASS_GLOBAL(EbmlCrc32, 0xBF, 1, "EBMLCrc32\0ratamadabapa");
|
|||||||
|
|
||||||
const uint32 EbmlCrc32::m_tab[] = {
|
const uint32 EbmlCrc32::m_tab[] = {
|
||||||
#ifdef WORDS_BIGENDIAN
|
#ifdef WORDS_BIGENDIAN
|
||||||
0x00000000L, 0x96300777L, 0x2c610eeeL, 0xba510999L, 0x19c46d07L,
|
0x00000000L, 0x96300777L, 0x2c610eeeL, 0xba510999L, 0x19c46d07L,
|
||||||
0x8ff46a70L, 0x35a563e9L, 0xa395649eL, 0x3288db0eL, 0xa4b8dc79L,
|
0x8ff46a70L, 0x35a563e9L, 0xa395649eL, 0x3288db0eL, 0xa4b8dc79L,
|
||||||
0x1ee9d5e0L, 0x88d9d297L, 0x2b4cb609L, 0xbd7cb17eL, 0x072db8e7L,
|
0x1ee9d5e0L, 0x88d9d297L, 0x2b4cb609L, 0xbd7cb17eL, 0x072db8e7L,
|
||||||
0x911dbf90L, 0x6410b71dL, 0xf220b06aL, 0x4871b9f3L, 0xde41be84L,
|
0x911dbf90L, 0x6410b71dL, 0xf220b06aL, 0x4871b9f3L, 0xde41be84L,
|
||||||
0x7dd4da1aL, 0xebe4dd6dL, 0x51b5d4f4L, 0xc785d383L, 0x56986c13L,
|
0x7dd4da1aL, 0xebe4dd6dL, 0x51b5d4f4L, 0xc785d383L, 0x56986c13L,
|
||||||
0xc0a86b64L, 0x7af962fdL, 0xecc9658aL, 0x4f5c0114L, 0xd96c0663L,
|
0xc0a86b64L, 0x7af962fdL, 0xecc9658aL, 0x4f5c0114L, 0xd96c0663L,
|
||||||
0x633d0ffaL, 0xf50d088dL, 0xc8206e3bL, 0x5e10694cL, 0xe44160d5L,
|
0x633d0ffaL, 0xf50d088dL, 0xc8206e3bL, 0x5e10694cL, 0xe44160d5L,
|
||||||
0x727167a2L, 0xd1e4033cL, 0x47d4044bL, 0xfd850dd2L, 0x6bb50aa5L,
|
0x727167a2L, 0xd1e4033cL, 0x47d4044bL, 0xfd850dd2L, 0x6bb50aa5L,
|
||||||
0xfaa8b535L, 0x6c98b242L, 0xd6c9bbdbL, 0x40f9bcacL, 0xe36cd832L,
|
0xfaa8b535L, 0x6c98b242L, 0xd6c9bbdbL, 0x40f9bcacL, 0xe36cd832L,
|
||||||
0x755cdf45L, 0xcf0dd6dcL, 0x593dd1abL, 0xac30d926L, 0x3a00de51L,
|
0x755cdf45L, 0xcf0dd6dcL, 0x593dd1abL, 0xac30d926L, 0x3a00de51L,
|
||||||
0x8051d7c8L, 0x1661d0bfL, 0xb5f4b421L, 0x23c4b356L, 0x9995bacfL,
|
0x8051d7c8L, 0x1661d0bfL, 0xb5f4b421L, 0x23c4b356L, 0x9995bacfL,
|
||||||
0x0fa5bdb8L, 0x9eb80228L, 0x0888055fL, 0xb2d90cc6L, 0x24e90bb1L,
|
0x0fa5bdb8L, 0x9eb80228L, 0x0888055fL, 0xb2d90cc6L, 0x24e90bb1L,
|
||||||
0x877c6f2fL, 0x114c6858L, 0xab1d61c1L, 0x3d2d66b6L, 0x9041dc76L,
|
0x877c6f2fL, 0x114c6858L, 0xab1d61c1L, 0x3d2d66b6L, 0x9041dc76L,
|
||||||
0x0671db01L, 0xbc20d298L, 0x2a10d5efL, 0x8985b171L, 0x1fb5b606L,
|
0x0671db01L, 0xbc20d298L, 0x2a10d5efL, 0x8985b171L, 0x1fb5b606L,
|
||||||
0xa5e4bf9fL, 0x33d4b8e8L, 0xa2c90778L, 0x34f9000fL, 0x8ea80996L,
|
0xa5e4bf9fL, 0x33d4b8e8L, 0xa2c90778L, 0x34f9000fL, 0x8ea80996L,
|
||||||
0x18980ee1L, 0xbb0d6a7fL, 0x2d3d6d08L, 0x976c6491L, 0x015c63e6L,
|
0x18980ee1L, 0xbb0d6a7fL, 0x2d3d6d08L, 0x976c6491L, 0x015c63e6L,
|
||||||
0xf4516b6bL, 0x62616c1cL, 0xd8306585L, 0x4e0062f2L, 0xed95066cL,
|
0xf4516b6bL, 0x62616c1cL, 0xd8306585L, 0x4e0062f2L, 0xed95066cL,
|
||||||
0x7ba5011bL, 0xc1f40882L, 0x57c40ff5L, 0xc6d9b065L, 0x50e9b712L,
|
0x7ba5011bL, 0xc1f40882L, 0x57c40ff5L, 0xc6d9b065L, 0x50e9b712L,
|
||||||
0xeab8be8bL, 0x7c88b9fcL, 0xdf1ddd62L, 0x492dda15L, 0xf37cd38cL,
|
0xeab8be8bL, 0x7c88b9fcL, 0xdf1ddd62L, 0x492dda15L, 0xf37cd38cL,
|
||||||
0x654cd4fbL, 0x5861b24dL, 0xce51b53aL, 0x7400bca3L, 0xe230bbd4L,
|
0x654cd4fbL, 0x5861b24dL, 0xce51b53aL, 0x7400bca3L, 0xe230bbd4L,
|
||||||
0x41a5df4aL, 0xd795d83dL, 0x6dc4d1a4L, 0xfbf4d6d3L, 0x6ae96943L,
|
0x41a5df4aL, 0xd795d83dL, 0x6dc4d1a4L, 0xfbf4d6d3L, 0x6ae96943L,
|
||||||
0xfcd96e34L, 0x468867adL, 0xd0b860daL, 0x732d0444L, 0xe51d0333L,
|
0xfcd96e34L, 0x468867adL, 0xd0b860daL, 0x732d0444L, 0xe51d0333L,
|
||||||
0x5f4c0aaaL, 0xc97c0dddL, 0x3c710550L, 0xaa410227L, 0x10100bbeL,
|
0x5f4c0aaaL, 0xc97c0dddL, 0x3c710550L, 0xaa410227L, 0x10100bbeL,
|
||||||
0x86200cc9L, 0x25b56857L, 0xb3856f20L, 0x09d466b9L, 0x9fe461ceL,
|
0x86200cc9L, 0x25b56857L, 0xb3856f20L, 0x09d466b9L, 0x9fe461ceL,
|
||||||
0x0ef9de5eL, 0x98c9d929L, 0x2298d0b0L, 0xb4a8d7c7L, 0x173db359L,
|
0x0ef9de5eL, 0x98c9d929L, 0x2298d0b0L, 0xb4a8d7c7L, 0x173db359L,
|
||||||
0x810db42eL, 0x3b5cbdb7L, 0xad6cbac0L, 0x2083b8edL, 0xb6b3bf9aL,
|
0x810db42eL, 0x3b5cbdb7L, 0xad6cbac0L, 0x2083b8edL, 0xb6b3bf9aL,
|
||||||
0x0ce2b603L, 0x9ad2b174L, 0x3947d5eaL, 0xaf77d29dL, 0x1526db04L,
|
0x0ce2b603L, 0x9ad2b174L, 0x3947d5eaL, 0xaf77d29dL, 0x1526db04L,
|
||||||
0x8316dc73L, 0x120b63e3L, 0x843b6494L, 0x3e6a6d0dL, 0xa85a6a7aL,
|
0x8316dc73L, 0x120b63e3L, 0x843b6494L, 0x3e6a6d0dL, 0xa85a6a7aL,
|
||||||
0x0bcf0ee4L, 0x9dff0993L, 0x27ae000aL, 0xb19e077dL, 0x44930ff0L,
|
0x0bcf0ee4L, 0x9dff0993L, 0x27ae000aL, 0xb19e077dL, 0x44930ff0L,
|
||||||
0xd2a30887L, 0x68f2011eL, 0xfec20669L, 0x5d5762f7L, 0xcb676580L,
|
0xd2a30887L, 0x68f2011eL, 0xfec20669L, 0x5d5762f7L, 0xcb676580L,
|
||||||
0x71366c19L, 0xe7066b6eL, 0x761bd4feL, 0xe02bd389L, 0x5a7ada10L,
|
0x71366c19L, 0xe7066b6eL, 0x761bd4feL, 0xe02bd389L, 0x5a7ada10L,
|
||||||
0xcc4add67L, 0x6fdfb9f9L, 0xf9efbe8eL, 0x43beb717L, 0xd58eb060L,
|
0xcc4add67L, 0x6fdfb9f9L, 0xf9efbe8eL, 0x43beb717L, 0xd58eb060L,
|
||||||
0xe8a3d6d6L, 0x7e93d1a1L, 0xc4c2d838L, 0x52f2df4fL, 0xf167bbd1L,
|
0xe8a3d6d6L, 0x7e93d1a1L, 0xc4c2d838L, 0x52f2df4fL, 0xf167bbd1L,
|
||||||
0x6757bca6L, 0xdd06b53fL, 0x4b36b248L, 0xda2b0dd8L, 0x4c1b0aafL,
|
0x6757bca6L, 0xdd06b53fL, 0x4b36b248L, 0xda2b0dd8L, 0x4c1b0aafL,
|
||||||
0xf64a0336L, 0x607a0441L, 0xc3ef60dfL, 0x55df67a8L, 0xef8e6e31L,
|
0xf64a0336L, 0x607a0441L, 0xc3ef60dfL, 0x55df67a8L, 0xef8e6e31L,
|
||||||
0x79be6946L, 0x8cb361cbL, 0x1a8366bcL, 0xa0d26f25L, 0x36e26852L,
|
0x79be6946L, 0x8cb361cbL, 0x1a8366bcL, 0xa0d26f25L, 0x36e26852L,
|
||||||
0x95770cccL, 0x03470bbbL, 0xb9160222L, 0x2f260555L, 0xbe3bbac5L,
|
0x95770cccL, 0x03470bbbL, 0xb9160222L, 0x2f260555L, 0xbe3bbac5L,
|
||||||
0x280bbdb2L, 0x925ab42bL, 0x046ab35cL, 0xa7ffd7c2L, 0x31cfd0b5L,
|
0x280bbdb2L, 0x925ab42bL, 0x046ab35cL, 0xa7ffd7c2L, 0x31cfd0b5L,
|
||||||
0x8b9ed92cL, 0x1daede5bL, 0xb0c2649bL, 0x26f263ecL, 0x9ca36a75L,
|
0x8b9ed92cL, 0x1daede5bL, 0xb0c2649bL, 0x26f263ecL, 0x9ca36a75L,
|
||||||
0x0a936d02L, 0xa906099cL, 0x3f360eebL, 0x85670772L, 0x13570005L,
|
0x0a936d02L, 0xa906099cL, 0x3f360eebL, 0x85670772L, 0x13570005L,
|
||||||
0x824abf95L, 0x147ab8e2L, 0xae2bb17bL, 0x381bb60cL, 0x9b8ed292L,
|
0x824abf95L, 0x147ab8e2L, 0xae2bb17bL, 0x381bb60cL, 0x9b8ed292L,
|
||||||
0x0dbed5e5L, 0xb7efdc7cL, 0x21dfdb0bL, 0xd4d2d386L, 0x42e2d4f1L,
|
0x0dbed5e5L, 0xb7efdc7cL, 0x21dfdb0bL, 0xd4d2d386L, 0x42e2d4f1L,
|
||||||
0xf8b3dd68L, 0x6e83da1fL, 0xcd16be81L, 0x5b26b9f6L, 0xe177b06fL,
|
0xf8b3dd68L, 0x6e83da1fL, 0xcd16be81L, 0x5b26b9f6L, 0xe177b06fL,
|
||||||
0x7747b718L, 0xe65a0888L, 0x706a0fffL, 0xca3b0666L, 0x5c0b0111L,
|
0x7747b718L, 0xe65a0888L, 0x706a0fffL, 0xca3b0666L, 0x5c0b0111L,
|
||||||
0xff9e658fL, 0x69ae62f8L, 0xd3ff6b61L, 0x45cf6c16L, 0x78e20aa0L,
|
0xff9e658fL, 0x69ae62f8L, 0xd3ff6b61L, 0x45cf6c16L, 0x78e20aa0L,
|
||||||
0xeed20dd7L, 0x5483044eL, 0xc2b30339L, 0x612667a7L, 0xf71660d0L,
|
0xeed20dd7L, 0x5483044eL, 0xc2b30339L, 0x612667a7L, 0xf71660d0L,
|
||||||
0x4d476949L, 0xdb776e3eL, 0x4a6ad1aeL, 0xdc5ad6d9L, 0x660bdf40L,
|
0x4d476949L, 0xdb776e3eL, 0x4a6ad1aeL, 0xdc5ad6d9L, 0x660bdf40L,
|
||||||
0xf03bd837L, 0x53aebca9L, 0xc59ebbdeL, 0x7fcfb247L, 0xe9ffb530L,
|
0xf03bd837L, 0x53aebca9L, 0xc59ebbdeL, 0x7fcfb247L, 0xe9ffb530L,
|
||||||
0x1cf2bdbdL, 0x8ac2bacaL, 0x3093b353L, 0xa6a3b424L, 0x0536d0baL,
|
0x1cf2bdbdL, 0x8ac2bacaL, 0x3093b353L, 0xa6a3b424L, 0x0536d0baL,
|
||||||
0x9306d7cdL, 0x2957de54L, 0xbf67d923L, 0x2e7a66b3L, 0xb84a61c4L,
|
0x9306d7cdL, 0x2957de54L, 0xbf67d923L, 0x2e7a66b3L, 0xb84a61c4L,
|
||||||
0x021b685dL, 0x942b6f2aL, 0x37be0bb4L, 0xa18e0cc3L, 0x1bdf055aL,
|
0x021b685dL, 0x942b6f2aL, 0x37be0bb4L, 0xa18e0cc3L, 0x1bdf055aL,
|
||||||
0x8def022dL
|
0x8def022dL
|
||||||
#else
|
#else
|
||||||
0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L,
|
0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L,
|
||||||
0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L,
|
0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L,
|
||||||
0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L,
|
0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L,
|
||||||
0x90bf1d91L, 0x1db71064L, 0x6ab020f2L, 0xf3b97148L, 0x84be41deL,
|
0x90bf1d91L, 0x1db71064L, 0x6ab020f2L, 0xf3b97148L, 0x84be41deL,
|
||||||
0x1adad47dL, 0x6ddde4ebL, 0xf4d4b551L, 0x83d385c7L, 0x136c9856L,
|
0x1adad47dL, 0x6ddde4ebL, 0xf4d4b551L, 0x83d385c7L, 0x136c9856L,
|
||||||
0x646ba8c0L, 0xfd62f97aL, 0x8a65c9ecL, 0x14015c4fL, 0x63066cd9L,
|
0x646ba8c0L, 0xfd62f97aL, 0x8a65c9ecL, 0x14015c4fL, 0x63066cd9L,
|
||||||
0xfa0f3d63L, 0x8d080df5L, 0x3b6e20c8L, 0x4c69105eL, 0xd56041e4L,
|
0xfa0f3d63L, 0x8d080df5L, 0x3b6e20c8L, 0x4c69105eL, 0xd56041e4L,
|
||||||
0xa2677172L, 0x3c03e4d1L, 0x4b04d447L, 0xd20d85fdL, 0xa50ab56bL,
|
0xa2677172L, 0x3c03e4d1L, 0x4b04d447L, 0xd20d85fdL, 0xa50ab56bL,
|
||||||
0x35b5a8faL, 0x42b2986cL, 0xdbbbc9d6L, 0xacbcf940L, 0x32d86ce3L,
|
0x35b5a8faL, 0x42b2986cL, 0xdbbbc9d6L, 0xacbcf940L, 0x32d86ce3L,
|
||||||
0x45df5c75L, 0xdcd60dcfL, 0xabd13d59L, 0x26d930acL, 0x51de003aL,
|
0x45df5c75L, 0xdcd60dcfL, 0xabd13d59L, 0x26d930acL, 0x51de003aL,
|
||||||
0xc8d75180L, 0xbfd06116L, 0x21b4f4b5L, 0x56b3c423L, 0xcfba9599L,
|
0xc8d75180L, 0xbfd06116L, 0x21b4f4b5L, 0x56b3c423L, 0xcfba9599L,
|
||||||
0xb8bda50fL, 0x2802b89eL, 0x5f058808L, 0xc60cd9b2L, 0xb10be924L,
|
0xb8bda50fL, 0x2802b89eL, 0x5f058808L, 0xc60cd9b2L, 0xb10be924L,
|
||||||
0x2f6f7c87L, 0x58684c11L, 0xc1611dabL, 0xb6662d3dL, 0x76dc4190L,
|
0x2f6f7c87L, 0x58684c11L, 0xc1611dabL, 0xb6662d3dL, 0x76dc4190L,
|
||||||
0x01db7106L, 0x98d220bcL, 0xefd5102aL, 0x71b18589L, 0x06b6b51fL,
|
0x01db7106L, 0x98d220bcL, 0xefd5102aL, 0x71b18589L, 0x06b6b51fL,
|
||||||
0x9fbfe4a5L, 0xe8b8d433L, 0x7807c9a2L, 0x0f00f934L, 0x9609a88eL,
|
0x9fbfe4a5L, 0xe8b8d433L, 0x7807c9a2L, 0x0f00f934L, 0x9609a88eL,
|
||||||
0xe10e9818L, 0x7f6a0dbbL, 0x086d3d2dL, 0x91646c97L, 0xe6635c01L,
|
0xe10e9818L, 0x7f6a0dbbL, 0x086d3d2dL, 0x91646c97L, 0xe6635c01L,
|
||||||
0x6b6b51f4L, 0x1c6c6162L, 0x856530d8L, 0xf262004eL, 0x6c0695edL,
|
0x6b6b51f4L, 0x1c6c6162L, 0x856530d8L, 0xf262004eL, 0x6c0695edL,
|
||||||
0x1b01a57bL, 0x8208f4c1L, 0xf50fc457L, 0x65b0d9c6L, 0x12b7e950L,
|
0x1b01a57bL, 0x8208f4c1L, 0xf50fc457L, 0x65b0d9c6L, 0x12b7e950L,
|
||||||
0x8bbeb8eaL, 0xfcb9887cL, 0x62dd1ddfL, 0x15da2d49L, 0x8cd37cf3L,
|
0x8bbeb8eaL, 0xfcb9887cL, 0x62dd1ddfL, 0x15da2d49L, 0x8cd37cf3L,
|
||||||
0xfbd44c65L, 0x4db26158L, 0x3ab551ceL, 0xa3bc0074L, 0xd4bb30e2L,
|
0xfbd44c65L, 0x4db26158L, 0x3ab551ceL, 0xa3bc0074L, 0xd4bb30e2L,
|
||||||
0x4adfa541L, 0x3dd895d7L, 0xa4d1c46dL, 0xd3d6f4fbL, 0x4369e96aL,
|
0x4adfa541L, 0x3dd895d7L, 0xa4d1c46dL, 0xd3d6f4fbL, 0x4369e96aL,
|
||||||
0x346ed9fcL, 0xad678846L, 0xda60b8d0L, 0x44042d73L, 0x33031de5L,
|
0x346ed9fcL, 0xad678846L, 0xda60b8d0L, 0x44042d73L, 0x33031de5L,
|
||||||
0xaa0a4c5fL, 0xdd0d7cc9L, 0x5005713cL, 0x270241aaL, 0xbe0b1010L,
|
0xaa0a4c5fL, 0xdd0d7cc9L, 0x5005713cL, 0x270241aaL, 0xbe0b1010L,
|
||||||
0xc90c2086L, 0x5768b525L, 0x206f85b3L, 0xb966d409L, 0xce61e49fL,
|
0xc90c2086L, 0x5768b525L, 0x206f85b3L, 0xb966d409L, 0xce61e49fL,
|
||||||
0x5edef90eL, 0x29d9c998L, 0xb0d09822L, 0xc7d7a8b4L, 0x59b33d17L,
|
0x5edef90eL, 0x29d9c998L, 0xb0d09822L, 0xc7d7a8b4L, 0x59b33d17L,
|
||||||
0x2eb40d81L, 0xb7bd5c3bL, 0xc0ba6cadL, 0xedb88320L, 0x9abfb3b6L,
|
0x2eb40d81L, 0xb7bd5c3bL, 0xc0ba6cadL, 0xedb88320L, 0x9abfb3b6L,
|
||||||
0x03b6e20cL, 0x74b1d29aL, 0xead54739L, 0x9dd277afL, 0x04db2615L,
|
0x03b6e20cL, 0x74b1d29aL, 0xead54739L, 0x9dd277afL, 0x04db2615L,
|
||||||
0x73dc1683L, 0xe3630b12L, 0x94643b84L, 0x0d6d6a3eL, 0x7a6a5aa8L,
|
0x73dc1683L, 0xe3630b12L, 0x94643b84L, 0x0d6d6a3eL, 0x7a6a5aa8L,
|
||||||
0xe40ecf0bL, 0x9309ff9dL, 0x0a00ae27L, 0x7d079eb1L, 0xf00f9344L,
|
0xe40ecf0bL, 0x9309ff9dL, 0x0a00ae27L, 0x7d079eb1L, 0xf00f9344L,
|
||||||
0x8708a3d2L, 0x1e01f268L, 0x6906c2feL, 0xf762575dL, 0x806567cbL,
|
0x8708a3d2L, 0x1e01f268L, 0x6906c2feL, 0xf762575dL, 0x806567cbL,
|
||||||
0x196c3671L, 0x6e6b06e7L, 0xfed41b76L, 0x89d32be0L, 0x10da7a5aL,
|
0x196c3671L, 0x6e6b06e7L, 0xfed41b76L, 0x89d32be0L, 0x10da7a5aL,
|
||||||
0x67dd4accL, 0xf9b9df6fL, 0x8ebeeff9L, 0x17b7be43L, 0x60b08ed5L,
|
0x67dd4accL, 0xf9b9df6fL, 0x8ebeeff9L, 0x17b7be43L, 0x60b08ed5L,
|
||||||
0xd6d6a3e8L, 0xa1d1937eL, 0x38d8c2c4L, 0x4fdff252L, 0xd1bb67f1L,
|
0xd6d6a3e8L, 0xa1d1937eL, 0x38d8c2c4L, 0x4fdff252L, 0xd1bb67f1L,
|
||||||
0xa6bc5767L, 0x3fb506ddL, 0x48b2364bL, 0xd80d2bdaL, 0xaf0a1b4cL,
|
0xa6bc5767L, 0x3fb506ddL, 0x48b2364bL, 0xd80d2bdaL, 0xaf0a1b4cL,
|
||||||
0x36034af6L, 0x41047a60L, 0xdf60efc3L, 0xa867df55L, 0x316e8eefL,
|
0x36034af6L, 0x41047a60L, 0xdf60efc3L, 0xa867df55L, 0x316e8eefL,
|
||||||
0x4669be79L, 0xcb61b38cL, 0xbc66831aL, 0x256fd2a0L, 0x5268e236L,
|
0x4669be79L, 0xcb61b38cL, 0xbc66831aL, 0x256fd2a0L, 0x5268e236L,
|
||||||
0xcc0c7795L, 0xbb0b4703L, 0x220216b9L, 0x5505262fL, 0xc5ba3bbeL,
|
0xcc0c7795L, 0xbb0b4703L, 0x220216b9L, 0x5505262fL, 0xc5ba3bbeL,
|
||||||
0xb2bd0b28L, 0x2bb45a92L, 0x5cb36a04L, 0xc2d7ffa7L, 0xb5d0cf31L,
|
0xb2bd0b28L, 0x2bb45a92L, 0x5cb36a04L, 0xc2d7ffa7L, 0xb5d0cf31L,
|
||||||
0x2cd99e8bL, 0x5bdeae1dL, 0x9b64c2b0L, 0xec63f226L, 0x756aa39cL,
|
0x2cd99e8bL, 0x5bdeae1dL, 0x9b64c2b0L, 0xec63f226L, 0x756aa39cL,
|
||||||
0x026d930aL, 0x9c0906a9L, 0xeb0e363fL, 0x72076785L, 0x05005713L,
|
0x026d930aL, 0x9c0906a9L, 0xeb0e363fL, 0x72076785L, 0x05005713L,
|
||||||
0x95bf4a82L, 0xe2b87a14L, 0x7bb12baeL, 0x0cb61b38L, 0x92d28e9bL,
|
0x95bf4a82L, 0xe2b87a14L, 0x7bb12baeL, 0x0cb61b38L, 0x92d28e9bL,
|
||||||
0xe5d5be0dL, 0x7cdcefb7L, 0x0bdbdf21L, 0x86d3d2d4L, 0xf1d4e242L,
|
0xe5d5be0dL, 0x7cdcefb7L, 0x0bdbdf21L, 0x86d3d2d4L, 0xf1d4e242L,
|
||||||
0x68ddb3f8L, 0x1fda836eL, 0x81be16cdL, 0xf6b9265bL, 0x6fb077e1L,
|
0x68ddb3f8L, 0x1fda836eL, 0x81be16cdL, 0xf6b9265bL, 0x6fb077e1L,
|
||||||
0x18b74777L, 0x88085ae6L, 0xff0f6a70L, 0x66063bcaL, 0x11010b5cL,
|
0x18b74777L, 0x88085ae6L, 0xff0f6a70L, 0x66063bcaL, 0x11010b5cL,
|
||||||
0x8f659effL, 0xf862ae69L, 0x616bffd3L, 0x166ccf45L, 0xa00ae278L,
|
0x8f659effL, 0xf862ae69L, 0x616bffd3L, 0x166ccf45L, 0xa00ae278L,
|
||||||
0xd70dd2eeL, 0x4e048354L, 0x3903b3c2L, 0xa7672661L, 0xd06016f7L,
|
0xd70dd2eeL, 0x4e048354L, 0x3903b3c2L, 0xa7672661L, 0xd06016f7L,
|
||||||
0x4969474dL, 0x3e6e77dbL, 0xaed16a4aL, 0xd9d65adcL, 0x40df0b66L,
|
0x4969474dL, 0x3e6e77dbL, 0xaed16a4aL, 0xd9d65adcL, 0x40df0b66L,
|
||||||
0x37d83bf0L, 0xa9bcae53L, 0xdebb9ec5L, 0x47b2cf7fL, 0x30b5ffe9L,
|
0x37d83bf0L, 0xa9bcae53L, 0xdebb9ec5L, 0x47b2cf7fL, 0x30b5ffe9L,
|
||||||
0xbdbdf21cL, 0xcabac28aL, 0x53b39330L, 0x24b4a3a6L, 0xbad03605L,
|
0xbdbdf21cL, 0xcabac28aL, 0x53b39330L, 0x24b4a3a6L, 0xbad03605L,
|
||||||
0xcdd70693L, 0x54de5729L, 0x23d967bfL, 0xb3667a2eL, 0xc4614ab8L,
|
0xcdd70693L, 0x54de5729L, 0x23d967bfL, 0xb3667a2eL, 0xc4614ab8L,
|
||||||
0x5d681b02L, 0x2a6f2b94L, 0xb40bbe37L, 0xc30c8ea1L, 0x5a05df1bL,
|
0x5d681b02L, 0x2a6f2b94L, 0xb40bbe37L, 0xc30c8ea1L, 0x5a05df1bL,
|
||||||
0x2d02ef8dL
|
0x2d02ef8dL
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
EbmlCrc32::EbmlCrc32()
|
EbmlCrc32::EbmlCrc32()
|
||||||
{
|
{
|
||||||
ResetCRC();
|
ResetCRC();
|
||||||
SetDefaultSize(4);
|
SetDefaultSize(4);
|
||||||
m_crc_final = 0;
|
m_crc_final = 0;
|
||||||
SetSize_(4);
|
SetSize_(4);
|
||||||
//This EbmlElement has been set
|
//This EbmlElement has been set
|
||||||
// SetValueIsSet();
|
// SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlCrc32::EbmlCrc32(const EbmlCrc32 & ElementToClone)
|
EbmlCrc32::EbmlCrc32(const EbmlCrc32 & ElementToClone)
|
||||||
:EbmlBinary(ElementToClone)
|
:EbmlBinary(ElementToClone)
|
||||||
{
|
{
|
||||||
m_crc = ElementToClone.m_crc;
|
m_crc = ElementToClone.m_crc;
|
||||||
m_crc_final = ElementToClone.m_crc_final;
|
m_crc_final = ElementToClone.m_crc_final;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlCrc32::ResetCRC()
|
void EbmlCrc32::ResetCRC()
|
||||||
@ -191,163 +191,163 @@ void EbmlCrc32::UpdateByte(binary b)
|
|||||||
|
|
||||||
void EbmlCrc32::AddElementCRC32(EbmlElement &ElementToCRC)
|
void EbmlCrc32::AddElementCRC32(EbmlElement &ElementToCRC)
|
||||||
{
|
{
|
||||||
// Use a special IOCallback class that Render's to memory instead of to disk
|
// Use a special IOCallback class that Render's to memory instead of to disk
|
||||||
MemIOCallback memoryBuffer;
|
MemIOCallback memoryBuffer;
|
||||||
ElementToCRC.Render(memoryBuffer, true, true);
|
ElementToCRC.Render(memoryBuffer, true, true);
|
||||||
|
|
||||||
Update(memoryBuffer.GetDataBuffer(), memoryBuffer.GetDataBufferSize());
|
Update(memoryBuffer.GetDataBuffer(), memoryBuffer.GetDataBufferSize());
|
||||||
// Finalize();
|
// Finalize();
|
||||||
};
|
};
|
||||||
|
|
||||||
bool EbmlCrc32::CheckElementCRC32(EbmlElement &ElementToCRC)
|
bool EbmlCrc32::CheckElementCRC32(EbmlElement &ElementToCRC)
|
||||||
{
|
{
|
||||||
MemIOCallback memoryBuffer;
|
MemIOCallback memoryBuffer;
|
||||||
ElementToCRC.Render(memoryBuffer);
|
ElementToCRC.Render(memoryBuffer);
|
||||||
|
|
||||||
return CheckCRC(m_crc_final, memoryBuffer.GetDataBuffer(), memoryBuffer.GetDataBufferSize());
|
return CheckCRC(m_crc_final, memoryBuffer.GetDataBuffer(), memoryBuffer.GetDataBufferSize());
|
||||||
};
|
};
|
||||||
|
|
||||||
filepos_t EbmlCrc32::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlCrc32::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
filepos_t Result = 4;
|
filepos_t Result = 4;
|
||||||
|
|
||||||
if (Result != 0) {
|
if (Result != 0) {
|
||||||
output.writeFully(&m_crc_final, Result);
|
output.writeFully(&m_crc_final, Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Result < GetDefaultSize()) {
|
if (Result < GetDefaultSize()) {
|
||||||
// pad the rest with 0
|
// pad the rest with 0
|
||||||
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
||||||
if (Pad != NULL) {
|
if (Pad != NULL) {
|
||||||
memset(Pad, 0x00, GetDefaultSize() - Result);
|
memset(Pad, 0x00, GetDefaultSize() - Result);
|
||||||
output.writeFully(Pad, GetDefaultSize() - Result);
|
output.writeFully(Pad, GetDefaultSize() - Result);
|
||||||
|
|
||||||
Result = GetDefaultSize();
|
Result = GetDefaultSize();
|
||||||
delete [] Pad;
|
delete [] Pad;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlCrc32::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlCrc32::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
binary *Buffer = new (std::nothrow) binary[GetSize()];
|
binary *Buffer = new (std::nothrow) binary[GetSize()];
|
||||||
if (Buffer == NULL) {
|
if (Buffer == NULL) {
|
||||||
// impossible to read, skip it
|
// impossible to read, skip it
|
||||||
input.setFilePointer(GetSize(), seek_current);
|
input.setFilePointer(GetSize(), seek_current);
|
||||||
} else {
|
} else {
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
|
|
||||||
memcpy((void *)&m_crc_final, Buffer, 4);
|
memcpy((void *)&m_crc_final, Buffer, 4);
|
||||||
delete [] Buffer;
|
delete [] Buffer;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlCrc32::CheckCRC(uint32 inputCRC, const binary *input, uint32 length)
|
bool EbmlCrc32::CheckCRC(uint32 inputCRC, const binary *input, uint32 length)
|
||||||
{
|
{
|
||||||
uint32 crc = CRC32_NEGL;
|
uint32 crc = CRC32_NEGL;
|
||||||
|
|
||||||
for(; !IsAligned<uint32>(input) && length > 0; length--)
|
for(; !IsAligned<uint32>(input) && length > 0; length--)
|
||||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||||
|
|
||||||
while (length >= 4)
|
while (length >= 4)
|
||||||
{
|
{
|
||||||
crc ^= *(const uint32 *)input;
|
crc ^= *(const uint32 *)input;
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
length -= 4;
|
length -= 4;
|
||||||
input += 4;
|
input += 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (length--)
|
while (length--)
|
||||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||||
|
|
||||||
//Now we finalize the CRC32
|
//Now we finalize the CRC32
|
||||||
crc ^= CRC32_NEGL;
|
crc ^= CRC32_NEGL;
|
||||||
|
|
||||||
if (crc == inputCRC)
|
if (crc == inputCRC)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
|
||||||
void EbmlCrc32::FillCRC32(const binary *s, uint32 n)
|
void EbmlCrc32::FillCRC32(const binary *s, uint32 n)
|
||||||
{
|
{
|
||||||
ResetCRC();
|
ResetCRC();
|
||||||
Update(s, n);
|
Update(s, n);
|
||||||
Finalize();
|
Finalize();
|
||||||
|
|
||||||
/*uint32 crc = CRC32_NEGL;
|
/*uint32 crc = CRC32_NEGL;
|
||||||
|
|
||||||
for(; !IsAligned<uint32>(s) && n > 0; n--)
|
for(; !IsAligned<uint32>(s) && n > 0; n--)
|
||||||
crc = m_tab[CRC32_INDEX(crc) ^ *s++] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc) ^ *s++] ^ CRC32_SHIFTED(crc);
|
||||||
|
|
||||||
while (n >= 4)
|
while (n >= 4)
|
||||||
{
|
{
|
||||||
crc ^= *(const uint32 *)s;
|
crc ^= *(const uint32 *)s;
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
n -= 4;
|
n -= 4;
|
||||||
s += 4;
|
s += 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (n--)
|
while (n--)
|
||||||
crc = m_tab[CRC32_INDEX(crc) ^ *s++] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc) ^ *s++] ^ CRC32_SHIFTED(crc);
|
||||||
|
|
||||||
m_crc = crc;
|
m_crc = crc;
|
||||||
|
|
||||||
//Now we finalize the CRC32
|
//Now we finalize the CRC32
|
||||||
m_crc ^= CRC32_NEGL;
|
m_crc ^= CRC32_NEGL;
|
||||||
//for (unsigned int i = 0; i < 4; i++)
|
//for (unsigned int i = 0; i < 4; i++)
|
||||||
// (&last_crc32)[i] = GetCrcByte(i);*/
|
// (&last_crc32)[i] = GetCrcByte(i);*/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlCrc32::Update(const binary *input, uint32 length)
|
void EbmlCrc32::Update(const binary *input, uint32 length)
|
||||||
{
|
{
|
||||||
uint32 crc = m_crc;
|
uint32 crc = m_crc;
|
||||||
|
|
||||||
for(; !IsAligned<uint32>(input) && length > 0; length--)
|
for(; !IsAligned<uint32>(input) && length > 0; length--)
|
||||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||||
|
|
||||||
while (length >= 4)
|
while (length >= 4)
|
||||||
{
|
{
|
||||||
crc ^= *(const uint32 *)input;
|
crc ^= *(const uint32 *)input;
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||||
length -= 4;
|
length -= 4;
|
||||||
input += 4;
|
input += 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (length--)
|
while (length--)
|
||||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||||
|
|
||||||
m_crc = crc;
|
m_crc = crc;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlCrc32::Finalize()
|
void EbmlCrc32::Finalize()
|
||||||
{
|
{
|
||||||
//Finalize the CRC32
|
//Finalize the CRC32
|
||||||
m_crc ^= CRC32_NEGL;
|
m_crc ^= CRC32_NEGL;
|
||||||
//Copy it over to completed CRC32 memeber
|
//Copy it over to completed CRC32 memeber
|
||||||
m_crc_final = m_crc;
|
m_crc_final = m_crc;
|
||||||
//Reset the holding CRC member (m_crc)
|
//Reset the holding CRC member (m_crc)
|
||||||
ResetCRC();
|
ResetCRC();
|
||||||
//This EbmlElement has been set
|
//This EbmlElement has been set
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,9 +27,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlDate.cpp 1079 2005-03-03 13:18:14Z robux4 $
|
\version \$Id: EbmlDate.cpp 1079 2005-03-03 13:18:14Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
@ -42,47 +42,47 @@ const uint64 EbmlDate::UnixEpochDelay = 978307200; // 2001/01/01 00:00:00 UTC
|
|||||||
EbmlDate::EbmlDate(const EbmlDate & ElementToClone)
|
EbmlDate::EbmlDate(const EbmlDate & ElementToClone)
|
||||||
:EbmlElement(ElementToClone)
|
:EbmlElement(ElementToClone)
|
||||||
{
|
{
|
||||||
myDate = ElementToClone.myDate;
|
myDate = ElementToClone.myDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlDate::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlDate::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
if (GetSize() != 0) {
|
if (GetSize() != 0) {
|
||||||
assert(GetSize() == 8);
|
assert(GetSize() == 8);
|
||||||
binary Buffer[8];
|
binary Buffer[8];
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
|
|
||||||
big_int64 b64;
|
big_int64 b64;
|
||||||
b64.Eval(Buffer);
|
b64.Eval(Buffer);
|
||||||
|
|
||||||
myDate = b64;
|
myDate = b64;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlDate::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlDate::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
if (GetSize() != 0) {
|
if (GetSize() != 0) {
|
||||||
assert(GetSize() == 8);
|
assert(GetSize() == 8);
|
||||||
big_int64 b64(myDate);
|
big_int64 b64(myDate);
|
||||||
|
|
||||||
output.writeFully(&b64.endian(),GetSize());
|
output.writeFully(&b64.endian(),GetSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlDate::IsSmallerThan(const EbmlElement *Cmp) const
|
bool EbmlDate::IsSmallerThan(const EbmlElement *Cmp) const
|
||||||
{
|
{
|
||||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||||
return this->myDate < static_cast<const EbmlDate *>(Cmp)->myDate;
|
return this->myDate < static_cast<const EbmlDate *>(Cmp)->myDate;
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlDummy.h"
|
#include "ebml/EbmlDummy.h"
|
||||||
#include "ebml/EbmlContexts.h"
|
#include "ebml/EbmlContexts.h"
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
@ -43,14 +43,14 @@ START_LIBEBML_NAMESPACE
|
|||||||
EbmlFloat::EbmlFloat(const EbmlFloat::Precision prec)
|
EbmlFloat::EbmlFloat(const EbmlFloat::Precision prec)
|
||||||
:EbmlElement(0, false)
|
:EbmlElement(0, false)
|
||||||
{
|
{
|
||||||
SetPrecision(prec);
|
SetPrecision(prec);
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlFloat::EbmlFloat(const double aDefaultValue, const EbmlFloat::Precision prec)
|
EbmlFloat::EbmlFloat(const double aDefaultValue, const EbmlFloat::Precision prec)
|
||||||
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||||
{
|
{
|
||||||
SetDefaultIsSet();
|
SetDefaultIsSet();
|
||||||
SetPrecision(prec);
|
SetPrecision(prec);
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlFloat::EbmlFloat(const EbmlFloat & ElementToClone)
|
EbmlFloat::EbmlFloat(const EbmlFloat & ElementToClone)
|
||||||
@ -83,76 +83,76 @@ EbmlFloat & EbmlFloat::SetValue(double NewValue) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo handle exception on errors
|
\todo handle exception on errors
|
||||||
\todo handle 10 bits precision
|
\todo handle 10 bits precision
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlFloat::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlFloat::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
assert(GetSize() == 4 || GetSize() == 8);
|
assert(GetSize() == 4 || GetSize() == 8);
|
||||||
|
|
||||||
if (GetSize() == 4) {
|
if (GetSize() == 4) {
|
||||||
float val = Value;
|
float val = Value;
|
||||||
int Tmp;
|
int Tmp;
|
||||||
memcpy(&Tmp, &val, 4);
|
memcpy(&Tmp, &val, 4);
|
||||||
big_int32 TmpToWrite(Tmp);
|
big_int32 TmpToWrite(Tmp);
|
||||||
output.writeFully(&TmpToWrite.endian(), GetSize());
|
output.writeFully(&TmpToWrite.endian(), GetSize());
|
||||||
} else if (GetSize() == 8) {
|
} else if (GetSize() == 8) {
|
||||||
double val = Value;
|
double val = Value;
|
||||||
int64 Tmp;
|
int64 Tmp;
|
||||||
memcpy(&Tmp, &val, 8);
|
memcpy(&Tmp, &val, 8);
|
||||||
big_int64 TmpToWrite(Tmp);
|
big_int64 TmpToWrite(Tmp);
|
||||||
output.writeFully(&TmpToWrite.endian(), GetSize());
|
output.writeFully(&TmpToWrite.endian(), GetSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 EbmlFloat::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
uint64 EbmlFloat::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||||
{
|
{
|
||||||
if (!bWithDefault && IsDefaultValue())
|
if (!bWithDefault && IsDefaultValue())
|
||||||
return 0;
|
return 0;
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo remove the hack for possible endianess pb (test on little & big endian)
|
\todo remove the hack for possible endianess pb (test on little & big endian)
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlFloat::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlFloat::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
binary Buffer[20];
|
binary Buffer[20];
|
||||||
assert(GetSize() <= 20);
|
assert(GetSize() <= 20);
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
|
|
||||||
if (GetSize() == 4) {
|
if (GetSize() == 4) {
|
||||||
big_int32 TmpRead;
|
big_int32 TmpRead;
|
||||||
TmpRead.Eval(Buffer);
|
TmpRead.Eval(Buffer);
|
||||||
int32 tmpp = int32(TmpRead);
|
int32 tmpp = int32(TmpRead);
|
||||||
float val;
|
float val;
|
||||||
memcpy(&val, &tmpp, 4);
|
memcpy(&val, &tmpp, 4);
|
||||||
Value = val;
|
Value = val;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
} else if (GetSize() == 8) {
|
} else if (GetSize() == 8) {
|
||||||
big_int64 TmpRead;
|
big_int64 TmpRead;
|
||||||
TmpRead.Eval(Buffer);
|
TmpRead.Eval(Buffer);
|
||||||
int64 tmpp = int64(TmpRead);
|
int64 tmpp = int64(TmpRead);
|
||||||
double val;
|
double val;
|
||||||
memcpy(&val, &tmpp, 8);
|
memcpy(&val, &tmpp, 8);
|
||||||
Value = val;
|
Value = val;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlFloat::IsSmallerThan(const EbmlElement *Cmp) const
|
bool EbmlFloat::IsSmallerThan(const EbmlElement *Cmp) const
|
||||||
{
|
{
|
||||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||||
return this->Value < static_cast<const EbmlFloat *>(Cmp)->Value;
|
return this->Value < static_cast<const EbmlFloat *>(Cmp)->Value;
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlHead.cpp 1096 2005-03-17 09:14:52Z robux4 $
|
\version \$Id: EbmlHead.cpp 1096 2005-03-17 09:14:52Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlHead.h"
|
#include "ebml/EbmlHead.h"
|
||||||
#include "ebml/EbmlSubHead.h"
|
#include "ebml/EbmlSubHead.h"
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
@ -47,9 +47,9 @@ START_LIBEBML_NAMESPACE
|
|||||||
EbmlMaster::EbmlMaster(const EbmlSemanticContext & aContext, bool bSizeIsknown)
|
EbmlMaster::EbmlMaster(const EbmlSemanticContext & aContext, bool bSizeIsknown)
|
||||||
:EbmlElement(0), Context(aContext), bChecksumUsed(bChecksumUsedByDefault)
|
:EbmlElement(0), Context(aContext), bChecksumUsed(bChecksumUsedByDefault)
|
||||||
{
|
{
|
||||||
SetSizeIsFinite(bSizeIsknown);
|
SetSizeIsFinite(bSizeIsknown);
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
ProcessMandatory();
|
ProcessMandatory();
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlMaster::EbmlMaster(const EbmlMaster & ElementToClone)
|
EbmlMaster::EbmlMaster(const EbmlMaster & ElementToClone)
|
||||||
@ -59,500 +59,500 @@ EbmlMaster::EbmlMaster(const EbmlMaster & ElementToClone)
|
|||||||
,bChecksumUsed(ElementToClone.bChecksumUsed)
|
,bChecksumUsed(ElementToClone.bChecksumUsed)
|
||||||
,Checksum(ElementToClone.Checksum)
|
,Checksum(ElementToClone.Checksum)
|
||||||
{
|
{
|
||||||
// add a clone of the list
|
// add a clone of the list
|
||||||
std::vector<EbmlElement *>::const_iterator Itr = ElementToClone.ElementList.begin();
|
std::vector<EbmlElement *>::const_iterator Itr = ElementToClone.ElementList.begin();
|
||||||
std::vector<EbmlElement *>::iterator myItr = ElementList.begin();
|
std::vector<EbmlElement *>::iterator myItr = ElementList.begin();
|
||||||
while (Itr != ElementToClone.ElementList.end())
|
while (Itr != ElementToClone.ElementList.end())
|
||||||
{
|
{
|
||||||
*myItr = (*Itr)->Clone();
|
*myItr = (*Itr)->Clone();
|
||||||
++Itr; ++myItr;
|
++Itr; ++myItr;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlMaster::~EbmlMaster()
|
EbmlMaster::~EbmlMaster()
|
||||||
{
|
{
|
||||||
assert(!IsLocked()); // you're trying to delete a locked element !!!
|
assert(!IsLocked()); // you're trying to delete a locked element !!!
|
||||||
|
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if (!(*ElementList[Index]).IsLocked()) {
|
if (!(*ElementList[Index]).IsLocked()) {
|
||||||
delete ElementList[Index];
|
delete ElementList[Index];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo handle exception on errors
|
\todo handle exception on errors
|
||||||
\todo write all the Mandatory elements in the Context, otherwise assert
|
\todo write all the Mandatory elements in the Context, otherwise assert
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlMaster::RenderData(IOCallback & output, bool bForceRender, bool bWithDefault)
|
filepos_t EbmlMaster::RenderData(IOCallback & output, bool bForceRender, bool bWithDefault)
|
||||||
{
|
{
|
||||||
filepos_t Result = 0;
|
filepos_t Result = 0;
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
if (!bForceRender) {
|
if (!bForceRender) {
|
||||||
assert(CheckMandatory());
|
assert(CheckMandatory());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!bChecksumUsed) { // old school
|
if (!bChecksumUsed) { // old school
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
||||||
continue;
|
continue;
|
||||||
Result += (ElementList[Index])->Render(output, bWithDefault, false ,bForceRender);
|
Result += (ElementList[Index])->Render(output, bWithDefault, false ,bForceRender);
|
||||||
}
|
}
|
||||||
} else { // new school
|
} else { // new school
|
||||||
MemIOCallback TmpBuf(GetSize() - 6);
|
MemIOCallback TmpBuf(GetSize() - 6);
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
||||||
continue;
|
continue;
|
||||||
(ElementList[Index])->Render(TmpBuf, bWithDefault, false ,bForceRender);
|
(ElementList[Index])->Render(TmpBuf, bWithDefault, false ,bForceRender);
|
||||||
}
|
}
|
||||||
Checksum.FillCRC32(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
Checksum.FillCRC32(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
||||||
Result += Checksum.Render(output, true, false ,bForceRender);
|
Result += Checksum.Render(output, true, false ,bForceRender);
|
||||||
output.writeFully(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
output.writeFully(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
||||||
Result += TmpBuf.GetDataBufferSize();
|
Result += TmpBuf.GetDataBufferSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo We might be able to forbid elements that don't exist in the context
|
\todo We might be able to forbid elements that don't exist in the context
|
||||||
*/
|
*/
|
||||||
bool EbmlMaster::PushElement(EbmlElement & element)
|
bool EbmlMaster::PushElement(EbmlElement & element)
|
||||||
{
|
{
|
||||||
ElementList.push_back(&element);
|
ElementList.push_back(&element);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 EbmlMaster::UpdateSize(bool bWithDefault, bool bForceRender)
|
uint64 EbmlMaster::UpdateSize(bool bWithDefault, bool bForceRender)
|
||||||
{
|
{
|
||||||
SetSize_(0);
|
SetSize_(0);
|
||||||
|
|
||||||
if (!IsFiniteSize())
|
if (!IsFiniteSize())
|
||||||
return (0-1);
|
return (0-1);
|
||||||
|
|
||||||
if (!bForceRender) {
|
if (!bForceRender) {
|
||||||
assert(CheckMandatory());
|
assert(CheckMandatory());
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
||||||
continue;
|
continue;
|
||||||
(ElementList[Index])->UpdateSize(bWithDefault, bForceRender);
|
(ElementList[Index])->UpdateSize(bWithDefault, bForceRender);
|
||||||
uint64 SizeToAdd = (ElementList[Index])->ElementSize(bWithDefault);
|
uint64 SizeToAdd = (ElementList[Index])->ElementSize(bWithDefault);
|
||||||
#if defined(LIBEBML_DEBUG)
|
#if defined(LIBEBML_DEBUG)
|
||||||
if (static_cast<int64>(SizeToAdd) == (0-1))
|
if (static_cast<int64>(SizeToAdd) == (0-1))
|
||||||
return (0-1);
|
return (0-1);
|
||||||
#endif // LIBEBML_DEBUG
|
#endif // LIBEBML_DEBUG
|
||||||
SetSize_(GetSize() + SizeToAdd);
|
SetSize_(GetSize() + SizeToAdd);
|
||||||
}
|
}
|
||||||
if (bChecksumUsed) {
|
if (bChecksumUsed) {
|
||||||
SetSize_(GetSize() + Checksum.ElementSize());
|
SetSize_(GetSize() + Checksum.ElementSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlMaster::WriteHead(IOCallback & output, int nSizeLength, bool bWithDefault)
|
filepos_t EbmlMaster::WriteHead(IOCallback & output, int nSizeLength, bool bWithDefault)
|
||||||
{
|
{
|
||||||
SetSizeLength(nSizeLength);
|
SetSizeLength(nSizeLength);
|
||||||
return RenderHead(output, false, bWithDefault);
|
return RenderHead(output, false, bWithDefault);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo this code is very suspicious !
|
\todo this code is very suspicious !
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlMaster::ReadData(IOCallback & input, ScopeMode /* ReadFully */)
|
filepos_t EbmlMaster::ReadData(IOCallback & input, ScopeMode /* ReadFully */)
|
||||||
{
|
{
|
||||||
input.setFilePointer(GetSize(), seek_current);
|
input.setFilePointer(GetSize(), seek_current);
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\note Hopefully no global element is mandatory
|
\note Hopefully no global element is mandatory
|
||||||
\todo should be called for ALL EbmlMaster element on construction
|
\todo should be called for ALL EbmlMaster element on construction
|
||||||
*/
|
*/
|
||||||
bool EbmlMaster::ProcessMandatory()
|
bool EbmlMaster::ProcessMandatory()
|
||||||
{
|
{
|
||||||
if (EBML_CTX_SIZE(Context) == 0)
|
if (EBML_CTX_SIZE(Context) == 0)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(Context.GetSize() != 0);
|
assert(Context.GetSize() != 0);
|
||||||
|
|
||||||
unsigned int EltIdx;
|
unsigned int EltIdx;
|
||||||
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
||||||
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory() && EBML_CTX_IDX(Context,EltIdx).IsUnique()) {
|
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory() && EBML_CTX_IDX(Context,EltIdx).IsUnique()) {
|
||||||
// assert(EBML_CTX_IDX(Context,EltIdx).Create != NULL);
|
// assert(EBML_CTX_IDX(Context,EltIdx).Create != NULL);
|
||||||
PushElement(EBML_SEM_CREATE(EBML_CTX_IDX(Context,EltIdx)));
|
PushElement(EBML_SEM_CREATE(EBML_CTX_IDX(Context,EltIdx)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlMaster::CheckMandatory() const
|
bool EbmlMaster::CheckMandatory() const
|
||||||
{
|
{
|
||||||
assert(Context.GetSize() != 0);
|
assert(Context.GetSize() != 0);
|
||||||
|
|
||||||
unsigned int EltIdx;
|
unsigned int EltIdx;
|
||||||
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
||||||
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory()) {
|
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory()) {
|
||||||
if (FindElt(EBML_CTX_IDX_INFO(Context,EltIdx)) == NULL) {
|
if (FindElt(EBML_CTX_IDX_INFO(Context,EltIdx)) == NULL) {
|
||||||
#if defined(LIBEBML_DEBUG)
|
#if defined(LIBEBML_DEBUG)
|
||||||
// you are missing this Mandatory element
|
// you are missing this Mandatory element
|
||||||
// const char * MissingName = EBML_INFO_NAME(EBML_CTX_IDX_INFO(Context,EltIdx));
|
// const char * MissingName = EBML_INFO_NAME(EBML_CTX_IDX_INFO(Context,EltIdx));
|
||||||
#endif // LIBEBML_DEBUG
|
#endif // LIBEBML_DEBUG
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> EbmlMaster::FindAllMissingElements()
|
std::vector<std::string> EbmlMaster::FindAllMissingElements()
|
||||||
{
|
{
|
||||||
assert(Context.GetSize() != 0);
|
assert(Context.GetSize() != 0);
|
||||||
|
|
||||||
std::vector<std::string> missingElements;
|
std::vector<std::string> missingElements;
|
||||||
|
|
||||||
for (size_t ChildElementNo = 0; ChildElementNo < ElementList.size(); ChildElementNo++) {
|
for (size_t ChildElementNo = 0; ChildElementNo < ElementList.size(); ChildElementNo++) {
|
||||||
EbmlElement *childElement = ElementList[ChildElementNo];
|
EbmlElement *childElement = ElementList[ChildElementNo];
|
||||||
if (!childElement->ValueIsSet()) {
|
if (!childElement->ValueIsSet()) {
|
||||||
std::string missingValue;
|
std::string missingValue;
|
||||||
missingValue = "The Child Element \"";
|
missingValue = "The Child Element \"";
|
||||||
missingValue.append(EBML_NAME(childElement));
|
missingValue.append(EBML_NAME(childElement));
|
||||||
missingValue.append("\" of EbmlMaster \"");
|
missingValue.append("\" of EbmlMaster \"");
|
||||||
missingValue.append(EBML_NAME(this));
|
missingValue.append(EBML_NAME(this));
|
||||||
missingValue.append("\", does not have a value set.");
|
missingValue.append("\", does not have a value set.");
|
||||||
missingElements.push_back(missingValue);
|
missingElements.push_back(missingValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (childElement->IsMaster()) {
|
if (childElement->IsMaster()) {
|
||||||
EbmlMaster *childMaster = (EbmlMaster *)childElement;
|
EbmlMaster *childMaster = (EbmlMaster *)childElement;
|
||||||
|
|
||||||
std::vector<std::string> childMissingElements = childMaster->FindAllMissingElements();
|
std::vector<std::string> childMissingElements = childMaster->FindAllMissingElements();
|
||||||
for (size_t s = 0; s < childMissingElements.size(); s++)
|
for (size_t s = 0; s < childMissingElements.size(); s++)
|
||||||
missingElements.push_back(childMissingElements[s]);
|
missingElements.push_back(childMissingElements[s]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
unsigned int EltIdx;
|
unsigned int EltIdx;
|
||||||
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
||||||
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory()) {
|
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory()) {
|
||||||
if (FindElt(EBML_CTX_IDX_INFO(Context,EltIdx)) == NULL) {
|
if (FindElt(EBML_CTX_IDX_INFO(Context,EltIdx)) == NULL) {
|
||||||
std::string missingElement;
|
std::string missingElement;
|
||||||
missingElement = "Missing element \"";
|
missingElement = "Missing element \"";
|
||||||
missingElement.append(EBML_INFO_NAME(EBML_CTX_IDX_INFO(Context,EltIdx)));
|
missingElement.append(EBML_INFO_NAME(EBML_CTX_IDX_INFO(Context,EltIdx)));
|
||||||
missingElement.append("\" in EbmlMaster \"");
|
missingElement.append("\" in EbmlMaster \"");
|
||||||
missingElement.append(EBML_INFO_NAME(*EBML_CTX_MASTER(Context)));
|
missingElement.append(EBML_INFO_NAME(*EBML_CTX_MASTER(Context)));
|
||||||
missingElement.append("\"");
|
missingElement.append("\"");
|
||||||
missingElements.push_back(missingElement);
|
missingElements.push_back(missingElement);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return missingElements;
|
return missingElements;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlElement *EbmlMaster::FindElt(const EbmlCallbacks & Callbacks) const
|
EbmlElement *EbmlMaster::FindElt(const EbmlCallbacks & Callbacks) const
|
||||||
{
|
{
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
EbmlElement * tmp = ElementList[Index];
|
EbmlElement * tmp = ElementList[Index];
|
||||||
if (EbmlId(*tmp) == EBML_INFO_ID(Callbacks))
|
if (EbmlId(*tmp) == EBML_INFO_ID(Callbacks))
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlElement *EbmlMaster::FindFirstElt(const EbmlCallbacks & Callbacks, bool bCreateIfNull)
|
EbmlElement *EbmlMaster::FindFirstElt(const EbmlCallbacks & Callbacks, bool bCreateIfNull)
|
||||||
{
|
{
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if (ElementList[Index] && EbmlId(*(ElementList[Index])) == EBML_INFO_ID(Callbacks))
|
if (ElementList[Index] && EbmlId(*(ElementList[Index])) == EBML_INFO_ID(Callbacks))
|
||||||
return ElementList[Index];
|
return ElementList[Index];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bCreateIfNull) {
|
if (bCreateIfNull) {
|
||||||
// add the element
|
// add the element
|
||||||
EbmlElement *NewElt = &EBML_INFO_CREATE(Callbacks);
|
EbmlElement *NewElt = &EBML_INFO_CREATE(Callbacks);
|
||||||
if (NewElt == NULL)
|
if (NewElt == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!PushElement(*NewElt)) {
|
if (!PushElement(*NewElt)) {
|
||||||
delete NewElt;
|
delete NewElt;
|
||||||
NewElt = NULL;
|
NewElt = NULL;
|
||||||
}
|
}
|
||||||
return NewElt;
|
return NewElt;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlElement *EbmlMaster::FindFirstElt(const EbmlCallbacks & Callbacks) const
|
EbmlElement *EbmlMaster::FindFirstElt(const EbmlCallbacks & Callbacks) const
|
||||||
{
|
{
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if (EbmlId(*(ElementList[Index])) == EBML_INFO_ID(Callbacks))
|
if (EbmlId(*(ElementList[Index])) == EBML_INFO_ID(Callbacks))
|
||||||
return ElementList[Index];
|
return ElementList[Index];
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo only return elements that are from the same type !
|
\todo only return elements that are from the same type !
|
||||||
\todo the element might be the unique in the context !
|
\todo the element might be the unique in the context !
|
||||||
*/
|
*/
|
||||||
EbmlElement *EbmlMaster::FindNextElt(const EbmlElement & PastElt, bool bCreateIfNull)
|
EbmlElement *EbmlMaster::FindNextElt(const EbmlElement & PastElt, bool bCreateIfNull)
|
||||||
{
|
{
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if ((ElementList[Index]) == &PastElt) {
|
if ((ElementList[Index]) == &PastElt) {
|
||||||
// found past element, new one is :
|
// found past element, new one is :
|
||||||
Index++;
|
Index++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while (Index < ElementList.size()) {
|
while (Index < ElementList.size()) {
|
||||||
if ((EbmlId)PastElt == (EbmlId)(*ElementList[Index]))
|
if ((EbmlId)PastElt == (EbmlId)(*ElementList[Index]))
|
||||||
break;
|
break;
|
||||||
Index++;
|
Index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Index != ElementList.size())
|
if (Index != ElementList.size())
|
||||||
return ElementList[Index];
|
return ElementList[Index];
|
||||||
|
|
||||||
if (bCreateIfNull) {
|
if (bCreateIfNull) {
|
||||||
// add the element
|
// add the element
|
||||||
EbmlElement *NewElt = &(PastElt.CreateElement());
|
EbmlElement *NewElt = &(PastElt.CreateElement());
|
||||||
if (NewElt == NULL)
|
if (NewElt == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!PushElement(*NewElt)) {
|
if (!PushElement(*NewElt)) {
|
||||||
delete NewElt;
|
delete NewElt;
|
||||||
NewElt = NULL;
|
NewElt = NULL;
|
||||||
}
|
}
|
||||||
return NewElt;
|
return NewElt;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlElement *EbmlMaster::FindNextElt(const EbmlElement & PastElt) const
|
EbmlElement *EbmlMaster::FindNextElt(const EbmlElement & PastElt) const
|
||||||
{
|
{
|
||||||
size_t Index;
|
size_t Index;
|
||||||
|
|
||||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||||
if ((ElementList[Index]) == &PastElt) {
|
if ((ElementList[Index]) == &PastElt) {
|
||||||
// found past element, new one is :
|
// found past element, new one is :
|
||||||
Index++;
|
Index++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while (Index < ElementList.size()) {
|
while (Index < ElementList.size()) {
|
||||||
if ((EbmlId)PastElt == (EbmlId)(*ElementList[Index]))
|
if ((EbmlId)PastElt == (EbmlId)(*ElementList[Index]))
|
||||||
return ElementList[Index];
|
return ElementList[Index];
|
||||||
Index++;
|
Index++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlElement *EbmlMaster::AddNewElt(const EbmlCallbacks & Callbacks)
|
EbmlElement *EbmlMaster::AddNewElt(const EbmlCallbacks & Callbacks)
|
||||||
{
|
{
|
||||||
// add the element
|
// add the element
|
||||||
EbmlElement *NewElt = &EBML_INFO_CREATE(Callbacks);
|
EbmlElement *NewElt = &EBML_INFO_CREATE(Callbacks);
|
||||||
if (NewElt == NULL)
|
if (NewElt == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (!PushElement(*NewElt)) {
|
if (!PushElement(*NewElt)) {
|
||||||
delete NewElt;
|
delete NewElt;
|
||||||
NewElt = NULL;
|
NewElt = NULL;
|
||||||
}
|
}
|
||||||
return NewElt;
|
return NewElt;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlMaster::Sort()
|
void EbmlMaster::Sort()
|
||||||
{
|
{
|
||||||
std::sort(ElementList.begin(), ElementList.end(), EbmlElement::CompareElements);
|
std::sort(ElementList.begin(), ElementList.end(), EbmlElement::CompareElements);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\brief Method to help reading a Master element and all subsequent children quickly
|
\brief Method to help reading a Master element and all subsequent children quickly
|
||||||
\todo add an option to discard even unknown elements
|
\todo add an option to discard even unknown elements
|
||||||
\todo handle when a mandatory element is not found
|
\todo handle when a mandatory element is not found
|
||||||
*/
|
*/
|
||||||
void EbmlMaster::Read(EbmlStream & inDataStream, const EbmlSemanticContext & sContext, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt, ScopeMode ReadFully)
|
void EbmlMaster::Read(EbmlStream & inDataStream, const EbmlSemanticContext & sContext, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
EbmlElement * ElementLevelA;
|
EbmlElement * ElementLevelA;
|
||||||
// remove all existing elements, including the mandatory ones...
|
// remove all existing elements, including the mandatory ones...
|
||||||
size_t Index;
|
size_t Index;
|
||||||
for (Index=0; Index<ElementList.size(); Index++) {
|
for (Index=0; Index<ElementList.size(); Index++) {
|
||||||
if (!(*ElementList[Index]).IsLocked()) {
|
if (!(*ElementList[Index]).IsLocked()) {
|
||||||
delete ElementList[Index];
|
delete ElementList[Index];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ElementList.clear();
|
ElementList.clear();
|
||||||
uint64 MaxSizeToRead;
|
uint64 MaxSizeToRead;
|
||||||
|
|
||||||
if (IsFiniteSize())
|
if (IsFiniteSize())
|
||||||
MaxSizeToRead = GetSize();
|
MaxSizeToRead = GetSize();
|
||||||
else
|
else
|
||||||
MaxSizeToRead = 0x7FFFFFFF;
|
MaxSizeToRead = 0x7FFFFFFF;
|
||||||
|
|
||||||
// read blocks and discard the ones we don't care about
|
// read blocks and discard the ones we don't care about
|
||||||
if (MaxSizeToRead > 0)
|
if (MaxSizeToRead > 0)
|
||||||
{
|
{
|
||||||
inDataStream.I_O().setFilePointer(GetSizePosition() + GetSizeLength(), seek_beginning);
|
inDataStream.I_O().setFilePointer(GetSizePosition() + GetSizeLength(), seek_beginning);
|
||||||
ElementLevelA = inDataStream.FindNextElement(sContext, UpperEltFound, MaxSizeToRead, AllowDummyElt);
|
ElementLevelA = inDataStream.FindNextElement(sContext, UpperEltFound, MaxSizeToRead, AllowDummyElt);
|
||||||
while (ElementLevelA != NULL && UpperEltFound <= 0 && MaxSizeToRead > 0) {
|
while (ElementLevelA != NULL && UpperEltFound <= 0 && MaxSizeToRead > 0) {
|
||||||
if (IsFiniteSize() && ElementLevelA->IsFiniteSize())
|
if (IsFiniteSize() && ElementLevelA->IsFiniteSize())
|
||||||
MaxSizeToRead = GetEndPosition() - ElementLevelA->GetEndPosition(); // even if it's the default value
|
MaxSizeToRead = GetEndPosition() - ElementLevelA->GetEndPosition(); // even if it's the default value
|
||||||
if (!AllowDummyElt && ElementLevelA->IsDummy()) {
|
if (!AllowDummyElt && ElementLevelA->IsDummy()) {
|
||||||
if (ElementLevelA->IsFiniteSize()) {
|
if (ElementLevelA->IsFiniteSize()) {
|
||||||
ElementLevelA->SkipData(inDataStream, sContext);
|
ElementLevelA->SkipData(inDataStream, sContext);
|
||||||
delete ElementLevelA; // forget this unknown element
|
delete ElementLevelA; // forget this unknown element
|
||||||
} else {
|
} else {
|
||||||
delete ElementLevelA; // forget this unknown element
|
delete ElementLevelA; // forget this unknown element
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// more logical to do it afterward
|
// more logical to do it afterward
|
||||||
ElementList.push_back(ElementLevelA);
|
ElementList.push_back(ElementLevelA);
|
||||||
|
|
||||||
ElementLevelA->Read(inDataStream, EBML_CONTEXT(ElementLevelA), UpperEltFound, FoundElt, AllowDummyElt, ReadFully);
|
ElementLevelA->Read(inDataStream, EBML_CONTEXT(ElementLevelA), UpperEltFound, FoundElt, AllowDummyElt, ReadFully);
|
||||||
|
|
||||||
// just in case
|
// just in case
|
||||||
if (ElementLevelA->IsFiniteSize())
|
if (ElementLevelA->IsFiniteSize())
|
||||||
ElementLevelA->SkipData(inDataStream, EBML_CONTEXT(ElementLevelA));
|
ElementLevelA->SkipData(inDataStream, EBML_CONTEXT(ElementLevelA));
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (UpperEltFound > 0) {
|
if (UpperEltFound > 0) {
|
||||||
UpperEltFound--;
|
UpperEltFound--;
|
||||||
if (UpperEltFound > 0 || MaxSizeToRead <= 0)
|
if (UpperEltFound > 0 || MaxSizeToRead <= 0)
|
||||||
goto processCrc;
|
goto processCrc;
|
||||||
ElementLevelA = FoundElt;
|
ElementLevelA = FoundElt;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (UpperEltFound < 0) {
|
if (UpperEltFound < 0) {
|
||||||
UpperEltFound++;
|
UpperEltFound++;
|
||||||
if (UpperEltFound < 0)
|
if (UpperEltFound < 0)
|
||||||
goto processCrc;
|
goto processCrc;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MaxSizeToRead <= 0)
|
if (MaxSizeToRead <= 0)
|
||||||
goto processCrc;// this level is finished
|
goto processCrc;// this level is finished
|
||||||
|
|
||||||
ElementLevelA = inDataStream.FindNextElement(sContext, UpperEltFound, MaxSizeToRead, AllowDummyElt);
|
ElementLevelA = inDataStream.FindNextElement(sContext, UpperEltFound, MaxSizeToRead, AllowDummyElt);
|
||||||
}
|
}
|
||||||
if (UpperEltFound > 0) {
|
if (UpperEltFound > 0) {
|
||||||
FoundElt = ElementLevelA;
|
FoundElt = ElementLevelA;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
processCrc:
|
processCrc:
|
||||||
EBML_MASTER_ITERATOR Itr, CrcItr;
|
EBML_MASTER_ITERATOR Itr, CrcItr;
|
||||||
for (Itr = ElementList.begin(); Itr != ElementList.end();) {
|
for (Itr = ElementList.begin(); Itr != ElementList.end();) {
|
||||||
if ((EbmlId)(*(*Itr)) == EBML_ID(EbmlCrc32)) {
|
if ((EbmlId)(*(*Itr)) == EBML_ID(EbmlCrc32)) {
|
||||||
bChecksumUsed = true;
|
bChecksumUsed = true;
|
||||||
// remove the element
|
// remove the element
|
||||||
Checksum = *(static_cast<EbmlCrc32*>(*Itr));
|
Checksum = *(static_cast<EbmlCrc32*>(*Itr));
|
||||||
CrcItr = Itr;
|
CrcItr = Itr;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
++Itr;
|
++Itr;
|
||||||
}
|
}
|
||||||
if (bChecksumUsed)
|
if (bChecksumUsed)
|
||||||
{
|
{
|
||||||
delete *CrcItr;
|
delete *CrcItr;
|
||||||
Remove(CrcItr);
|
Remove(CrcItr);
|
||||||
}
|
}
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlMaster::Remove(size_t Index)
|
void EbmlMaster::Remove(size_t Index)
|
||||||
{
|
{
|
||||||
if (Index < ElementList.size()) {
|
if (Index < ElementList.size()) {
|
||||||
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
||||||
while (Index-- > 0) {
|
while (Index-- > 0) {
|
||||||
++Itr;
|
++Itr;
|
||||||
}
|
}
|
||||||
|
|
||||||
ElementList.erase(Itr);
|
ElementList.erase(Itr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlMaster::Remove(EBML_MASTER_ITERATOR & Itr)
|
void EbmlMaster::Remove(EBML_MASTER_ITERATOR & Itr)
|
||||||
{
|
{
|
||||||
ElementList.erase(Itr);
|
ElementList.erase(Itr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EbmlMaster::Remove(EBML_MASTER_RITERATOR & Itr)
|
void EbmlMaster::Remove(EBML_MASTER_RITERATOR & Itr)
|
||||||
{
|
{
|
||||||
ElementList.erase(Itr.base());
|
ElementList.erase(Itr.base());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlMaster::VerifyChecksum() const
|
bool EbmlMaster::VerifyChecksum() const
|
||||||
{
|
{
|
||||||
if (!bChecksumUsed)
|
if (!bChecksumUsed)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
EbmlCrc32 aChecksum;
|
EbmlCrc32 aChecksum;
|
||||||
/// \todo remove the Checksum if it's in the list
|
/// \todo remove the Checksum if it's in the list
|
||||||
/// \todo find another way when not all default values are saved or (unknown from the reader !!!)
|
/// \todo find another way when not all default values are saved or (unknown from the reader !!!)
|
||||||
MemIOCallback TmpBuf(GetSize() - 6);
|
MemIOCallback TmpBuf(GetSize() - 6);
|
||||||
for (size_t Index = 0; Index < ElementList.size(); Index++) {
|
for (size_t Index = 0; Index < ElementList.size(); Index++) {
|
||||||
(ElementList[Index])->Render(TmpBuf, true, false, true);
|
(ElementList[Index])->Render(TmpBuf, true, false, true);
|
||||||
}
|
}
|
||||||
aChecksum.FillCRC32(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
aChecksum.FillCRC32(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
||||||
return (aChecksum.GetCrc32() == Checksum.GetCrc32());
|
return (aChecksum.GetCrc32() == Checksum.GetCrc32());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlMaster::InsertElement(EbmlElement & element, size_t position)
|
bool EbmlMaster::InsertElement(EbmlElement & element, size_t position)
|
||||||
{
|
{
|
||||||
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
||||||
while (Itr != ElementList.end() && position--)
|
while (Itr != ElementList.end() && position--)
|
||||||
{
|
{
|
||||||
++Itr;
|
++Itr;
|
||||||
}
|
}
|
||||||
if ((Itr == ElementList.end()) && position)
|
if ((Itr == ElementList.end()) && position)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
ElementList.insert(Itr, &element);
|
ElementList.insert(Itr, &element);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlMaster::InsertElement(EbmlElement & element, const EbmlElement & before)
|
bool EbmlMaster::InsertElement(EbmlElement & element, const EbmlElement & before)
|
||||||
{
|
{
|
||||||
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
||||||
while (Itr != ElementList.end() && *Itr != &before)
|
while (Itr != ElementList.end() && *Itr != &before)
|
||||||
{
|
{
|
||||||
++Itr;
|
++Itr;
|
||||||
}
|
}
|
||||||
if (Itr == ElementList.end())
|
if (Itr == ElementList.end())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
ElementList.insert(Itr, &element);
|
ElementList.insert(Itr, &element);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,10 +27,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
@ -45,7 +45,7 @@ EbmlSInteger::EbmlSInteger()
|
|||||||
EbmlSInteger::EbmlSInteger(int64 aDefaultValue)
|
EbmlSInteger::EbmlSInteger(int64 aDefaultValue)
|
||||||
:EbmlElement(DEFAULT_INT_SIZE, true), Value(aDefaultValue)
|
:EbmlElement(DEFAULT_INT_SIZE, true), Value(aDefaultValue)
|
||||||
{
|
{
|
||||||
SetDefaultIsSet();
|
SetDefaultIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlSInteger::EbmlSInteger(const EbmlSInteger & ElementToClone)
|
EbmlSInteger::EbmlSInteger(const EbmlSInteger & ElementToClone)
|
||||||
@ -67,89 +67,89 @@ EbmlSInteger & EbmlSInteger::SetValue(int64 NewValue) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo handle exception on errors
|
\todo handle exception on errors
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlSInteger::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlSInteger::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
binary FinalData[8]; // we don't handle more than 64 bits integers
|
binary FinalData[8]; // we don't handle more than 64 bits integers
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
if (GetSizeLength() > 8)
|
if (GetSizeLength() > 8)
|
||||||
return 0; // integer bigger coded on more than 64 bits are not supported
|
return 0; // integer bigger coded on more than 64 bits are not supported
|
||||||
|
|
||||||
int64 TempValue = Value;
|
int64 TempValue = Value;
|
||||||
for (i=0; i<GetSize();i++) {
|
for (i=0; i<GetSize();i++) {
|
||||||
FinalData[GetSize()-i-1] = binary(TempValue & 0xFF);
|
FinalData[GetSize()-i-1] = binary(TempValue & 0xFF);
|
||||||
TempValue >>= 8;
|
TempValue >>= 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
output.writeFully(FinalData,GetSize());
|
output.writeFully(FinalData,GetSize());
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 EbmlSInteger::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
uint64 EbmlSInteger::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||||
{
|
{
|
||||||
if (!bWithDefault && IsDefaultValue())
|
if (!bWithDefault && IsDefaultValue())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (Value <= 0x7F && Value >= (-0x80)) {
|
if (Value <= 0x7F && Value >= (-0x80)) {
|
||||||
SetSize_(1);
|
SetSize_(1);
|
||||||
} else if (Value <= 0x7FFF && Value >= (-0x8000)) {
|
} else if (Value <= 0x7FFF && Value >= (-0x8000)) {
|
||||||
SetSize_(2);
|
SetSize_(2);
|
||||||
} else if (Value <= 0x7FFFFF && Value >= (-0x800000)) {
|
} else if (Value <= 0x7FFFFF && Value >= (-0x800000)) {
|
||||||
SetSize_(3);
|
SetSize_(3);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFF) && Value >= (EBML_PRETTYLONGINT(-0x80000000))) {
|
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFF) && Value >= (EBML_PRETTYLONGINT(-0x80000000))) {
|
||||||
SetSize_(4);
|
SetSize_(4);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFF) &&
|
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFF) &&
|
||||||
Value >= EBML_PRETTYLONGINT(-0x8000000000)) {
|
Value >= EBML_PRETTYLONGINT(-0x8000000000)) {
|
||||||
SetSize_(5);
|
SetSize_(5);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFFFF) &&
|
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFFFF) &&
|
||||||
Value >= EBML_PRETTYLONGINT(-0x800000000000)) {
|
Value >= EBML_PRETTYLONGINT(-0x800000000000)) {
|
||||||
SetSize_(6);
|
SetSize_(6);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFFFFFF) &&
|
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFFFFFF) &&
|
||||||
Value >= EBML_PRETTYLONGINT(-0x80000000000000)) {
|
Value >= EBML_PRETTYLONGINT(-0x80000000000000)) {
|
||||||
SetSize_(7);
|
SetSize_(7);
|
||||||
} else {
|
} else {
|
||||||
SetSize_(8);
|
SetSize_(8);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GetDefaultSize() > GetSize()) {
|
if (GetDefaultSize() > GetSize()) {
|
||||||
SetSize_(GetDefaultSize());
|
SetSize_(GetDefaultSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlSInteger::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlSInteger::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
binary Buffer[8];
|
binary Buffer[8];
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
|
|
||||||
if (Buffer[0] & 0x80)
|
if (Buffer[0] & 0x80)
|
||||||
Value = -1; // this is a negative value
|
Value = -1; // this is a negative value
|
||||||
else
|
else
|
||||||
Value = 0; // this is a positive value
|
Value = 0; // this is a positive value
|
||||||
|
|
||||||
for (unsigned int i=0; i<GetSize(); i++)
|
for (unsigned int i=0; i<GetSize(); i++)
|
||||||
{
|
{
|
||||||
Value <<= 8;
|
Value <<= 8;
|
||||||
Value |= Buffer[i];
|
Value |= Buffer[i];
|
||||||
}
|
}
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlSInteger::IsSmallerThan(const EbmlElement *Cmp) const
|
bool EbmlSInteger::IsSmallerThan(const EbmlElement *Cmp) const
|
||||||
{
|
{
|
||||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||||
return this->Value < static_cast<const EbmlSInteger *>(Cmp)->Value;
|
return this->Value < static_cast<const EbmlSInteger *>(Cmp)->Value;
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlStream.h"
|
#include "ebml/EbmlStream.h"
|
||||||
|
|
||||||
@ -46,12 +46,12 @@ EbmlStream::~EbmlStream()
|
|||||||
|
|
||||||
EbmlElement * EbmlStream::FindNextID(const EbmlCallbacks & ClassInfos, uint64 MaxDataSize)
|
EbmlElement * EbmlStream::FindNextID(const EbmlCallbacks & ClassInfos, uint64 MaxDataSize)
|
||||||
{
|
{
|
||||||
return EbmlElement::FindNextID(Stream, ClassInfos, MaxDataSize);
|
return EbmlElement::FindNextID(Stream, ClassInfos, MaxDataSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlElement * EbmlStream::FindNextElement(const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel)
|
EbmlElement * EbmlStream::FindNextElement(const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel)
|
||||||
{
|
{
|
||||||
return EbmlElement::FindNextElement(Stream, Context, UpperLevel, MaxDataSize, AllowDummyElt, MaxLowerLevel);
|
return EbmlElement::FindNextElement(Stream, Context, UpperLevel, MaxDataSize, AllowDummyElt, MaxLowerLevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
@ -42,26 +42,26 @@ START_LIBEBML_NAMESPACE
|
|||||||
EbmlString::EbmlString()
|
EbmlString::EbmlString()
|
||||||
:EbmlElement(0, false)
|
:EbmlElement(0, false)
|
||||||
{
|
{
|
||||||
SetDefaultSize(0);
|
SetDefaultSize(0);
|
||||||
/* done automatically
|
/* done automatically
|
||||||
SetSize_(Value.length());
|
SetSize_(Value.length());
|
||||||
if (GetDefaultSize() > GetSize())
|
if (GetDefaultSize() > GetSize())
|
||||||
SetSize_(GetDefaultSize());*/
|
SetSize_(GetDefaultSize());*/
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlString::EbmlString(const std::string & aDefaultValue)
|
EbmlString::EbmlString(const std::string & aDefaultValue)
|
||||||
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||||
{
|
{
|
||||||
SetDefaultSize(0);
|
SetDefaultSize(0);
|
||||||
SetDefaultIsSet();
|
SetDefaultIsSet();
|
||||||
/* done automatically
|
/* done automatically
|
||||||
SetSize_(Value.length());
|
SetSize_(Value.length());
|
||||||
if (GetDefaultSize() > GetSize())
|
if (GetDefaultSize() > GetSize())
|
||||||
SetSize_(GetDefaultSize());*/
|
SetSize_(GetDefaultSize());*/
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo Cloning should be on the same exact type !
|
\todo Cloning should be on the same exact type !
|
||||||
*/
|
*/
|
||||||
EbmlString::EbmlString(const EbmlString & ElementToClone)
|
EbmlString::EbmlString(const EbmlString & ElementToClone)
|
||||||
:EbmlElement(ElementToClone)
|
:EbmlElement(ElementToClone)
|
||||||
@ -85,41 +85,41 @@ const std::string & EbmlString::DefaultVal() const
|
|||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo handle exception on errors
|
\todo handle exception on errors
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlString::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlString::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
filepos_t Result;
|
filepos_t Result;
|
||||||
output.writeFully(Value.c_str(), Value.length());
|
output.writeFully(Value.c_str(), Value.length());
|
||||||
Result = Value.length();
|
Result = Value.length();
|
||||||
|
|
||||||
if (Result < GetDefaultSize()) {
|
if (Result < GetDefaultSize()) {
|
||||||
// pad the rest with 0
|
// pad the rest with 0
|
||||||
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
||||||
if (Pad == NULL)
|
if (Pad == NULL)
|
||||||
{
|
{
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
memset(Pad, 0x00, GetDefaultSize() - Result);
|
memset(Pad, 0x00, GetDefaultSize() - Result);
|
||||||
output.writeFully(Pad, GetDefaultSize() - Result);
|
output.writeFully(Pad, GetDefaultSize() - Result);
|
||||||
Result = GetDefaultSize();
|
Result = GetDefaultSize();
|
||||||
delete [] Pad;
|
delete [] Pad;
|
||||||
}
|
}
|
||||||
|
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlString::operator const std::string &() const {return Value;}
|
EbmlString::operator const std::string &() const {return Value;}
|
||||||
|
|
||||||
EbmlString & EbmlString::operator=(const std::string & NewString)
|
EbmlString & EbmlString::operator=(const std::string & NewString)
|
||||||
{
|
{
|
||||||
Value = NewString;
|
Value = NewString;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
/* done automatically
|
/* done automatically
|
||||||
SetSize_(Value.length());
|
SetSize_(Value.length());
|
||||||
if (GetDefaultSize() > GetSize())
|
if (GetDefaultSize() > GetSize())
|
||||||
SetSize_(GetDefaultSize());*/
|
SetSize_(GetDefaultSize());*/
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlString &EbmlString::SetValue(std::string const &NewValue) {
|
EbmlString &EbmlString::SetValue(std::string const &NewValue) {
|
||||||
@ -132,42 +132,42 @@ std::string EbmlString::GetValue() const {
|
|||||||
|
|
||||||
uint64 EbmlString::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
uint64 EbmlString::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||||
{
|
{
|
||||||
if (!bWithDefault && IsDefaultValue())
|
if (!bWithDefault && IsDefaultValue())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (Value.length() < GetDefaultSize()) {
|
if (Value.length() < GetDefaultSize()) {
|
||||||
SetSize_(GetDefaultSize());
|
SetSize_(GetDefaultSize());
|
||||||
} else {
|
} else {
|
||||||
SetSize_(Value.length());
|
SetSize_(Value.length());
|
||||||
}
|
}
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlString::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlString::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
if (GetSize() == 0) {
|
if (GetSize() == 0) {
|
||||||
Value = "";
|
Value = "";
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
} else {
|
} else {
|
||||||
char *Buffer = new (std::nothrow) char[GetSize() + 1];
|
char *Buffer = new (std::nothrow) char[GetSize() + 1];
|
||||||
if (Buffer == NULL) {
|
if (Buffer == NULL) {
|
||||||
// unable to store the data, skip it
|
// unable to store the data, skip it
|
||||||
input.setFilePointer(GetSize(), seek_current);
|
input.setFilePointer(GetSize(), seek_current);
|
||||||
} else {
|
} else {
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
if (Buffer[GetSize()-1] != '\0') {
|
if (Buffer[GetSize()-1] != '\0') {
|
||||||
Buffer[GetSize()] = '\0';
|
Buffer[GetSize()] = '\0';
|
||||||
}
|
}
|
||||||
Value = Buffer;
|
Value = Buffer;
|
||||||
delete [] Buffer;
|
delete [] Buffer;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlSubHead.cpp 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: EbmlSubHead.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlSubHead.h"
|
#include "ebml/EbmlSubHead.h"
|
||||||
#include "ebml/EbmlContexts.h"
|
#include "ebml/EbmlContexts.h"
|
||||||
|
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ EbmlUInteger::EbmlUInteger()
|
|||||||
EbmlUInteger::EbmlUInteger(uint64 aDefaultValue)
|
EbmlUInteger::EbmlUInteger(uint64 aDefaultValue)
|
||||||
:EbmlElement(DEFAULT_UINT_SIZE, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
:EbmlElement(DEFAULT_UINT_SIZE, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||||
{
|
{
|
||||||
SetDefaultIsSet();
|
SetDefaultIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlUInteger::EbmlUInteger(const EbmlUInteger & ElementToClone)
|
EbmlUInteger::EbmlUInteger(const EbmlUInteger & ElementToClone)
|
||||||
@ -82,81 +82,81 @@ EbmlUInteger & EbmlUInteger::SetValue(uint64 NewValue) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\todo handle exception on errors
|
\todo handle exception on errors
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlUInteger::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlUInteger::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
binary FinalData[8]; // we don't handle more than 64 bits integers
|
binary FinalData[8]; // we don't handle more than 64 bits integers
|
||||||
|
|
||||||
if (GetSizeLength() > 8)
|
if (GetSizeLength() > 8)
|
||||||
return 0; // integer bigger coded on more than 64 bits are not supported
|
return 0; // integer bigger coded on more than 64 bits are not supported
|
||||||
|
|
||||||
uint64 TempValue = Value;
|
uint64 TempValue = Value;
|
||||||
for (unsigned int i=0; i<GetSize();i++) {
|
for (unsigned int i=0; i<GetSize();i++) {
|
||||||
FinalData[GetSize()-i-1] = TempValue & 0xFF;
|
FinalData[GetSize()-i-1] = TempValue & 0xFF;
|
||||||
TempValue >>= 8;
|
TempValue >>= 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
output.writeFully(FinalData,GetSize());
|
output.writeFully(FinalData,GetSize());
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 EbmlUInteger::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
uint64 EbmlUInteger::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||||
{
|
{
|
||||||
if (!bWithDefault && IsDefaultValue())
|
if (!bWithDefault && IsDefaultValue())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (Value <= 0xFF) {
|
if (Value <= 0xFF) {
|
||||||
SetSize_(1);
|
SetSize_(1);
|
||||||
} else if (Value <= 0xFFFF) {
|
} else if (Value <= 0xFFFF) {
|
||||||
SetSize_(2);
|
SetSize_(2);
|
||||||
} else if (Value <= 0xFFFFFF) {
|
} else if (Value <= 0xFFFFFF) {
|
||||||
SetSize_(3);
|
SetSize_(3);
|
||||||
} else if (Value <= 0xFFFFFFFF) {
|
} else if (Value <= 0xFFFFFFFF) {
|
||||||
SetSize_(4);
|
SetSize_(4);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFF)) {
|
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFF)) {
|
||||||
SetSize_(5);
|
SetSize_(5);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFFFF)) {
|
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFFFF)) {
|
||||||
SetSize_(6);
|
SetSize_(6);
|
||||||
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFFFFFF)) {
|
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFFFFFF)) {
|
||||||
SetSize_(7);
|
SetSize_(7);
|
||||||
} else {
|
} else {
|
||||||
SetSize_(8);
|
SetSize_(8);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GetDefaultSize() > GetSize()) {
|
if (GetDefaultSize() > GetSize()) {
|
||||||
SetSize_(GetDefaultSize());
|
SetSize_(GetDefaultSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlUInteger::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlUInteger::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
binary Buffer[8];
|
binary Buffer[8];
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
Value = 0;
|
Value = 0;
|
||||||
|
|
||||||
for (unsigned int i=0; i<GetSize(); i++)
|
for (unsigned int i=0; i<GetSize(); i++)
|
||||||
{
|
{
|
||||||
Value <<= 8;
|
Value <<= 8;
|
||||||
Value |= Buffer[i];
|
Value |= Buffer[i];
|
||||||
}
|
}
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EbmlUInteger::IsSmallerThan(const EbmlElement *Cmp) const
|
bool EbmlUInteger::IsSmallerThan(const EbmlElement *Cmp) const
|
||||||
{
|
{
|
||||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||||
return this->Value < static_cast<const EbmlUInteger *>(Cmp)->Value;
|
return this->Value < static_cast<const EbmlUInteger *>(Cmp)->Value;
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,10 +29,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id$
|
\version \$Id$
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
@ -48,40 +48,40 @@ START_LIBEBML_NAMESPACE
|
|||||||
// ===================== UTFstring class ===================
|
// ===================== UTFstring class ===================
|
||||||
|
|
||||||
UTFstring::UTFstring()
|
UTFstring::UTFstring()
|
||||||
:_Length(0)
|
:_Length(0)
|
||||||
,_Data(NULL)
|
,_Data(NULL)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
UTFstring::UTFstring(const wchar_t * _aBuf)
|
UTFstring::UTFstring(const wchar_t * _aBuf)
|
||||||
:_Length(0)
|
:_Length(0)
|
||||||
,_Data(NULL)
|
,_Data(NULL)
|
||||||
{
|
{
|
||||||
*this = _aBuf;
|
*this = _aBuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
UTFstring::UTFstring(std::wstring const &_aBuf)
|
UTFstring::UTFstring(std::wstring const &_aBuf)
|
||||||
:_Length(0)
|
:_Length(0)
|
||||||
,_Data(NULL)
|
,_Data(NULL)
|
||||||
{
|
{
|
||||||
*this = _aBuf.c_str();
|
*this = _aBuf.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
UTFstring::~UTFstring()
|
UTFstring::~UTFstring()
|
||||||
{
|
{
|
||||||
delete [] _Data;
|
delete [] _Data;
|
||||||
}
|
}
|
||||||
|
|
||||||
UTFstring::UTFstring(const UTFstring & _aBuf)
|
UTFstring::UTFstring(const UTFstring & _aBuf)
|
||||||
:_Length(0)
|
:_Length(0)
|
||||||
,_Data(NULL)
|
,_Data(NULL)
|
||||||
{
|
{
|
||||||
*this = _aBuf.c_str();
|
*this = _aBuf.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
UTFstring & UTFstring::operator=(const UTFstring & _aBuf)
|
UTFstring & UTFstring::operator=(const UTFstring & _aBuf)
|
||||||
{
|
{
|
||||||
*this = _aBuf.c_str();
|
*this = _aBuf.c_str();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
UTFstring::operator const wchar_t*() const {return _Data;}
|
UTFstring::operator const wchar_t*() const {return _Data;}
|
||||||
@ -89,138 +89,138 @@ UTFstring::operator const wchar_t*() const {return _Data;}
|
|||||||
|
|
||||||
UTFstring & UTFstring::operator=(const wchar_t * _aBuf)
|
UTFstring & UTFstring::operator=(const wchar_t * _aBuf)
|
||||||
{
|
{
|
||||||
delete [] _Data;
|
delete [] _Data;
|
||||||
if (_aBuf == NULL) {
|
if (_aBuf == NULL) {
|
||||||
_Data = new wchar_t[1];
|
_Data = new wchar_t[1];
|
||||||
_Data[0] = 0;
|
_Data[0] = 0;
|
||||||
UpdateFromUCS2();
|
UpdateFromUCS2();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t aLen;
|
size_t aLen;
|
||||||
for (aLen=0; _aBuf[aLen] != 0; aLen++);
|
for (aLen=0; _aBuf[aLen] != 0; aLen++);
|
||||||
_Length = aLen;
|
_Length = aLen;
|
||||||
_Data = new wchar_t[_Length+1];
|
_Data = new wchar_t[_Length+1];
|
||||||
for (aLen=0; _aBuf[aLen] != 0; aLen++) {
|
for (aLen=0; _aBuf[aLen] != 0; aLen++) {
|
||||||
_Data[aLen] = _aBuf[aLen];
|
_Data[aLen] = _aBuf[aLen];
|
||||||
}
|
}
|
||||||
_Data[aLen] = 0;
|
_Data[aLen] = 0;
|
||||||
UpdateFromUCS2();
|
UpdateFromUCS2();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
UTFstring & UTFstring::operator=(wchar_t _aChar)
|
UTFstring & UTFstring::operator=(wchar_t _aChar)
|
||||||
{
|
{
|
||||||
delete [] _Data;
|
delete [] _Data;
|
||||||
_Data = new wchar_t[2];
|
_Data = new wchar_t[2];
|
||||||
_Length = 1;
|
_Length = 1;
|
||||||
_Data[0] = _aChar;
|
_Data[0] = _aChar;
|
||||||
_Data[1] = 0;
|
_Data[1] = 0;
|
||||||
UpdateFromUCS2();
|
UpdateFromUCS2();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool UTFstring::operator==(const UTFstring& _aStr) const
|
bool UTFstring::operator==(const UTFstring& _aStr) const
|
||||||
{
|
{
|
||||||
if ((_Data == NULL) && (_aStr._Data == NULL))
|
if ((_Data == NULL) && (_aStr._Data == NULL))
|
||||||
return true;
|
return true;
|
||||||
if ((_Data == NULL) || (_aStr._Data == NULL))
|
if ((_Data == NULL) || (_aStr._Data == NULL))
|
||||||
return false;
|
return false;
|
||||||
return wcscmp_internal(_Data, _aStr._Data);
|
return wcscmp_internal(_Data, _aStr._Data);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UTFstring::SetUTF8(const std::string & _aStr)
|
void UTFstring::SetUTF8(const std::string & _aStr)
|
||||||
{
|
{
|
||||||
UTF8string = _aStr;
|
UTF8string = _aStr;
|
||||||
UpdateFromUTF8();
|
UpdateFromUTF8();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\see RFC 2279
|
\see RFC 2279
|
||||||
*/
|
*/
|
||||||
void UTFstring::UpdateFromUTF8()
|
void UTFstring::UpdateFromUTF8()
|
||||||
{
|
{
|
||||||
delete [] _Data;
|
delete [] _Data;
|
||||||
// find the size of the final UCS-2 string
|
// find the size of the final UCS-2 string
|
||||||
size_t i;
|
size_t i;
|
||||||
for (_Length=0, i=0; i<UTF8string.length(); _Length++) {
|
for (_Length=0, i=0; i<UTF8string.length(); _Length++) {
|
||||||
uint8 lead = static_cast<uint8>(UTF8string[i]);
|
uint8 lead = static_cast<uint8>(UTF8string[i]);
|
||||||
if (lead < 0x80)
|
if (lead < 0x80)
|
||||||
i++;
|
i++;
|
||||||
else if ((lead >> 5) == 0x6)
|
else if ((lead >> 5) == 0x6)
|
||||||
i += 2;
|
i += 2;
|
||||||
else if ((lead >> 4) == 0xe)
|
else if ((lead >> 4) == 0xe)
|
||||||
i += 3;
|
i += 3;
|
||||||
else if ((lead >> 3) == 0x1e)
|
else if ((lead >> 3) == 0x1e)
|
||||||
i += 4;
|
i += 4;
|
||||||
else
|
else
|
||||||
// Invalid size?
|
// Invalid size?
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
_Data = new wchar_t[_Length+1];
|
_Data = new wchar_t[_Length+1];
|
||||||
size_t j;
|
size_t j;
|
||||||
for (j=0, i=0; i<UTF8string.length(); j++) {
|
for (j=0, i=0; i<UTF8string.length(); j++) {
|
||||||
uint8 lead = static_cast<uint8>(UTF8string[i]);
|
uint8 lead = static_cast<uint8>(UTF8string[i]);
|
||||||
if (lead < 0x80) {
|
if (lead < 0x80) {
|
||||||
_Data[j] = lead;
|
_Data[j] = lead;
|
||||||
i++;
|
i++;
|
||||||
} else if ((lead >> 5) == 0x6) {
|
} else if ((lead >> 5) == 0x6) {
|
||||||
_Data[j] = ((lead & 0x1F) << 6) + (UTF8string[i+1] & 0x3F);
|
_Data[j] = ((lead & 0x1F) << 6) + (UTF8string[i+1] & 0x3F);
|
||||||
i += 2;
|
i += 2;
|
||||||
} else if ((lead >> 4) == 0xe) {
|
} else if ((lead >> 4) == 0xe) {
|
||||||
_Data[j] = ((lead & 0x0F) << 12) + ((UTF8string[i+1] & 0x3F) << 6) + (UTF8string[i+2] & 0x3F);
|
_Data[j] = ((lead & 0x0F) << 12) + ((UTF8string[i+1] & 0x3F) << 6) + (UTF8string[i+2] & 0x3F);
|
||||||
i += 3;
|
i += 3;
|
||||||
} else if ((lead >> 3) == 0x1e) {
|
} else if ((lead >> 3) == 0x1e) {
|
||||||
_Data[j] = ((lead & 0x07) << 18) + ((UTF8string[i+1] & 0x3F) << 12) + ((UTF8string[i+2] & 0x3F) << 6) + (UTF8string[i+3] & 0x3F);
|
_Data[j] = ((lead & 0x07) << 18) + ((UTF8string[i+1] & 0x3F) << 12) + ((UTF8string[i+2] & 0x3F) << 6) + (UTF8string[i+3] & 0x3F);
|
||||||
i += 4;
|
i += 4;
|
||||||
} else
|
} else
|
||||||
// Invalid char?
|
// Invalid char?
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
_Data[j] = 0;
|
_Data[j] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UTFstring::UpdateFromUCS2()
|
void UTFstring::UpdateFromUCS2()
|
||||||
{
|
{
|
||||||
// find the size of the final UTF-8 string
|
// find the size of the final UTF-8 string
|
||||||
size_t i,Size=0;
|
size_t i,Size=0;
|
||||||
for (i=0; i<_Length; i++)
|
for (i=0; i<_Length; i++)
|
||||||
{
|
{
|
||||||
if (_Data[i] < 0x80) {
|
if (_Data[i] < 0x80) {
|
||||||
Size++;
|
Size++;
|
||||||
} else if (_Data[i] < 0x800) {
|
} else if (_Data[i] < 0x800) {
|
||||||
Size += 2;
|
Size += 2;
|
||||||
} else {
|
} else {
|
||||||
Size += 3;
|
Size += 3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
std::string::value_type *tmpStr = new std::string::value_type[Size+1];
|
std::string::value_type *tmpStr = new std::string::value_type[Size+1];
|
||||||
for (i=0, Size=0; i<_Length; i++)
|
for (i=0, Size=0; i<_Length; i++)
|
||||||
{
|
{
|
||||||
if (_Data[i] < 0x80) {
|
if (_Data[i] < 0x80) {
|
||||||
tmpStr[Size++] = _Data[i];
|
tmpStr[Size++] = _Data[i];
|
||||||
} else if (_Data[i] < 0x800) {
|
} else if (_Data[i] < 0x800) {
|
||||||
tmpStr[Size++] = 0xC0 | (_Data[i] >> 6);
|
tmpStr[Size++] = 0xC0 | (_Data[i] >> 6);
|
||||||
tmpStr[Size++] = 0x80 | (_Data[i] & 0x3F);
|
tmpStr[Size++] = 0x80 | (_Data[i] & 0x3F);
|
||||||
} else {
|
} else {
|
||||||
tmpStr[Size++] = 0xE0 | (_Data[i] >> 12);
|
tmpStr[Size++] = 0xE0 | (_Data[i] >> 12);
|
||||||
tmpStr[Size++] = 0x80 | ((_Data[i] >> 6) & 0x3F);
|
tmpStr[Size++] = 0x80 | ((_Data[i] >> 6) & 0x3F);
|
||||||
tmpStr[Size++] = 0x80 | (_Data[i] & 0x3F);
|
tmpStr[Size++] = 0x80 | (_Data[i] & 0x3F);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
tmpStr[Size] = 0;
|
tmpStr[Size] = 0;
|
||||||
UTF8string = tmpStr; // implicit conversion
|
UTF8string = tmpStr; // implicit conversion
|
||||||
delete [] tmpStr;
|
delete [] tmpStr;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool UTFstring::wcscmp_internal(const wchar_t *str1, const wchar_t *str2)
|
bool UTFstring::wcscmp_internal(const wchar_t *str1, const wchar_t *str2)
|
||||||
{
|
{
|
||||||
size_t Index=0;
|
size_t Index=0;
|
||||||
while (str1[Index] == str2[Index] && str1[Index] != 0) {
|
while (str1[Index] == str2[Index] && str1[Index] != 0) {
|
||||||
Index++;
|
Index++;
|
||||||
}
|
}
|
||||||
return (str1[Index] == str2[Index]);
|
return (str1[Index] == str2[Index]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ===================== EbmlUnicodeString class ===================
|
// ===================== EbmlUnicodeString class ===================
|
||||||
@ -228,14 +228,14 @@ bool UTFstring::wcscmp_internal(const wchar_t *str1, const wchar_t *str2)
|
|||||||
EbmlUnicodeString::EbmlUnicodeString()
|
EbmlUnicodeString::EbmlUnicodeString()
|
||||||
:EbmlElement(0, false)
|
:EbmlElement(0, false)
|
||||||
{
|
{
|
||||||
SetDefaultSize(0);
|
SetDefaultSize(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlUnicodeString::EbmlUnicodeString(const UTFstring & aDefaultValue)
|
EbmlUnicodeString::EbmlUnicodeString(const UTFstring & aDefaultValue)
|
||||||
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||||
{
|
{
|
||||||
SetDefaultSize(0);
|
SetDefaultSize(0);
|
||||||
SetDefaultIsSet();
|
SetDefaultIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlUnicodeString::EbmlUnicodeString(const EbmlUnicodeString & ElementToClone)
|
EbmlUnicodeString::EbmlUnicodeString(const EbmlUnicodeString & ElementToClone)
|
||||||
@ -265,34 +265,34 @@ const UTFstring & EbmlUnicodeString::DefaultVal() const
|
|||||||
*/
|
*/
|
||||||
filepos_t EbmlUnicodeString::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlUnicodeString::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
uint32 Result = Value.GetUTF8().length();
|
uint32 Result = Value.GetUTF8().length();
|
||||||
|
|
||||||
if (Result != 0) {
|
if (Result != 0) {
|
||||||
output.writeFully(Value.GetUTF8().c_str(), Result);
|
output.writeFully(Value.GetUTF8().c_str(), Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Result < GetDefaultSize()) {
|
if (Result < GetDefaultSize()) {
|
||||||
// pad the rest with 0
|
// pad the rest with 0
|
||||||
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
||||||
if (Pad != NULL) {
|
if (Pad != NULL) {
|
||||||
memset(Pad, 0x00, GetDefaultSize() - Result);
|
memset(Pad, 0x00, GetDefaultSize() - Result);
|
||||||
output.writeFully(Pad, GetDefaultSize() - Result);
|
output.writeFully(Pad, GetDefaultSize() - Result);
|
||||||
|
|
||||||
Result = GetDefaultSize();
|
Result = GetDefaultSize();
|
||||||
delete [] Pad;
|
delete [] Pad;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlUnicodeString::operator const UTFstring &() const {return Value;}
|
EbmlUnicodeString::operator const UTFstring &() const {return Value;}
|
||||||
|
|
||||||
EbmlUnicodeString & EbmlUnicodeString::operator=(const UTFstring & NewString)
|
EbmlUnicodeString & EbmlUnicodeString::operator=(const UTFstring & NewString)
|
||||||
{
|
{
|
||||||
Value = NewString;
|
Value = NewString;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
EbmlUnicodeString &EbmlUnicodeString::SetValue(UTFstring const &NewValue) {
|
EbmlUnicodeString &EbmlUnicodeString::SetValue(UTFstring const &NewValue) {
|
||||||
@ -318,45 +318,45 @@ std::string EbmlUnicodeString::GetValueUTF8() const {
|
|||||||
*/
|
*/
|
||||||
uint64 EbmlUnicodeString::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
uint64 EbmlUnicodeString::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||||
{
|
{
|
||||||
if (!bWithDefault && IsDefaultValue())
|
if (!bWithDefault && IsDefaultValue())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
SetSize_(Value.GetUTF8().length());
|
SetSize_(Value.GetUTF8().length());
|
||||||
if (GetSize() < GetDefaultSize())
|
if (GetSize() < GetDefaultSize())
|
||||||
SetSize_(GetDefaultSize());
|
SetSize_(GetDefaultSize());
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\note limited to UCS-2
|
\note limited to UCS-2
|
||||||
*/
|
*/
|
||||||
filepos_t EbmlUnicodeString::ReadData(IOCallback & input, ScopeMode ReadFully)
|
filepos_t EbmlUnicodeString::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||||
{
|
{
|
||||||
if (ReadFully != SCOPE_NO_DATA)
|
if (ReadFully != SCOPE_NO_DATA)
|
||||||
{
|
{
|
||||||
if (GetSize() == 0) {
|
if (GetSize() == 0) {
|
||||||
Value = UTFstring::value_type(0);
|
Value = UTFstring::value_type(0);
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
} else {
|
} else {
|
||||||
char *Buffer = new (std::nothrow) char[GetSize()+1];
|
char *Buffer = new (std::nothrow) char[GetSize()+1];
|
||||||
if (Buffer == NULL) {
|
if (Buffer == NULL) {
|
||||||
// impossible to read, skip it
|
// impossible to read, skip it
|
||||||
input.setFilePointer(GetSize(), seek_current);
|
input.setFilePointer(GetSize(), seek_current);
|
||||||
} else {
|
} else {
|
||||||
input.readFully(Buffer, GetSize());
|
input.readFully(Buffer, GetSize());
|
||||||
if (Buffer[GetSize()-1] != 0) {
|
if (Buffer[GetSize()-1] != 0) {
|
||||||
Buffer[GetSize()] = 0;
|
Buffer[GetSize()] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
Value.SetUTF8(Buffer); // implicit conversion to std::string
|
Value.SetUTF8(Buffer); // implicit conversion to std::string
|
||||||
delete [] Buffer;
|
delete [] Buffer;
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlVersion.cpp 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: EbmlVersion.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "ebml/EbmlVersion.h"
|
#include "ebml/EbmlVersion.h"
|
||||||
|
140
src/EbmlVoid.cpp
140
src/EbmlVoid.cpp
@ -29,9 +29,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: EbmlVoid.cpp 1232 2005-10-15 15:56:52Z robux4 $
|
\version \$Id: EbmlVoid.cpp 1232 2005-10-15 15:56:52Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
#include "ebml/EbmlVoid.h"
|
#include "ebml/EbmlVoid.h"
|
||||||
#include "ebml/EbmlContexts.h"
|
#include "ebml/EbmlContexts.h"
|
||||||
@ -42,97 +42,97 @@ DEFINE_EBML_CLASS_GLOBAL(EbmlVoid, 0xEC, 1, "EBMLVoid");
|
|||||||
|
|
||||||
EbmlVoid::EbmlVoid()
|
EbmlVoid::EbmlVoid()
|
||||||
{
|
{
|
||||||
SetValueIsSet();
|
SetValueIsSet();
|
||||||
}
|
}
|
||||||
|
|
||||||
filepos_t EbmlVoid::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
filepos_t EbmlVoid::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||||
{
|
{
|
||||||
// write dummy data by 4KB chunks
|
// write dummy data by 4KB chunks
|
||||||
static binary DummyBuf[4*1024];
|
static binary DummyBuf[4*1024];
|
||||||
|
|
||||||
uint64 SizeToWrite = GetSize();
|
uint64 SizeToWrite = GetSize();
|
||||||
while (SizeToWrite > 4*1024)
|
while (SizeToWrite > 4*1024)
|
||||||
{
|
{
|
||||||
output.writeFully(DummyBuf, 4*1024);
|
output.writeFully(DummyBuf, 4*1024);
|
||||||
SizeToWrite -= 4*1024;
|
SizeToWrite -= 4*1024;
|
||||||
}
|
}
|
||||||
output.writeFully(DummyBuf, SizeToWrite);
|
output.writeFully(DummyBuf, SizeToWrite);
|
||||||
return GetSize();
|
return GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 EbmlVoid::ReplaceWith(EbmlElement & EltToReplaceWith, IOCallback & output, bool ComeBackAfterward, bool bWithDefault)
|
uint64 EbmlVoid::ReplaceWith(EbmlElement & EltToReplaceWith, IOCallback & output, bool ComeBackAfterward, bool bWithDefault)
|
||||||
{
|
{
|
||||||
EltToReplaceWith.UpdateSize(bWithDefault);
|
EltToReplaceWith.UpdateSize(bWithDefault);
|
||||||
if (HeadSize() + GetSize() < EltToReplaceWith.GetSize() + EltToReplaceWith.HeadSize()) {
|
if (HeadSize() + GetSize() < EltToReplaceWith.GetSize() + EltToReplaceWith.HeadSize()) {
|
||||||
// the element can't be written here !
|
// the element can't be written here !
|
||||||
return INVALID_FILEPOS_T;
|
return INVALID_FILEPOS_T;
|
||||||
}
|
}
|
||||||
if (HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() == 1) {
|
if (HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() == 1) {
|
||||||
// there is not enough space to put a filling element
|
// there is not enough space to put a filling element
|
||||||
return INVALID_FILEPOS_T;
|
return INVALID_FILEPOS_T;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 CurrentPosition = output.getFilePointer();
|
uint64 CurrentPosition = output.getFilePointer();
|
||||||
|
|
||||||
output.setFilePointer(GetElementPosition());
|
output.setFilePointer(GetElementPosition());
|
||||||
EltToReplaceWith.Render(output, bWithDefault);
|
EltToReplaceWith.Render(output, bWithDefault);
|
||||||
|
|
||||||
if (HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() > 1) {
|
if (HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() > 1) {
|
||||||
// fill the rest with another void element
|
// fill the rest with another void element
|
||||||
EbmlVoid aTmp;
|
EbmlVoid aTmp;
|
||||||
aTmp.SetSize_(HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() - 1); // 1 is the length of the Void ID
|
aTmp.SetSize_(HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() - 1); // 1 is the length of the Void ID
|
||||||
int HeadBefore = aTmp.HeadSize();
|
int HeadBefore = aTmp.HeadSize();
|
||||||
aTmp.SetSize_(aTmp.GetSize() - CodedSizeLength(aTmp.GetSize(), aTmp.GetSizeLength(), aTmp.IsFiniteSize()));
|
aTmp.SetSize_(aTmp.GetSize() - CodedSizeLength(aTmp.GetSize(), aTmp.GetSizeLength(), aTmp.IsFiniteSize()));
|
||||||
int HeadAfter = aTmp.HeadSize();
|
int HeadAfter = aTmp.HeadSize();
|
||||||
if (HeadBefore != HeadAfter) {
|
if (HeadBefore != HeadAfter) {
|
||||||
aTmp.SetSizeLength(CodedSizeLength(aTmp.GetSize(), aTmp.GetSizeLength(), aTmp.IsFiniteSize()) - (HeadAfter - HeadBefore));
|
aTmp.SetSizeLength(CodedSizeLength(aTmp.GetSize(), aTmp.GetSizeLength(), aTmp.IsFiniteSize()) - (HeadAfter - HeadBefore));
|
||||||
}
|
}
|
||||||
aTmp.RenderHead(output, false, bWithDefault); // the rest of the data is not rewritten
|
aTmp.RenderHead(output, false, bWithDefault); // the rest of the data is not rewritten
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ComeBackAfterward) {
|
if (ComeBackAfterward) {
|
||||||
output.setFilePointer(CurrentPosition);
|
output.setFilePointer(CurrentPosition);
|
||||||
}
|
}
|
||||||
|
|
||||||
return GetSize() + HeadSize();
|
return GetSize() + HeadSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 EbmlVoid::Overwrite(const EbmlElement & EltToVoid, IOCallback & output, bool ComeBackAfterward, bool bWithDefault)
|
uint64 EbmlVoid::Overwrite(const EbmlElement & EltToVoid, IOCallback & output, bool ComeBackAfterward, bool bWithDefault)
|
||||||
{
|
{
|
||||||
// EltToVoid.UpdateSize(bWithDefault);
|
// EltToVoid.UpdateSize(bWithDefault);
|
||||||
if (EltToVoid.GetElementPosition() == 0) {
|
if (EltToVoid.GetElementPosition() == 0) {
|
||||||
// this element has never been written
|
// this element has never been written
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (EltToVoid.GetSize() + EltToVoid.HeadSize() <2) {
|
if (EltToVoid.GetSize() + EltToVoid.HeadSize() <2) {
|
||||||
// the element can't be written here !
|
// the element can't be written here !
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 CurrentPosition = output.getFilePointer();
|
uint64 CurrentPosition = output.getFilePointer();
|
||||||
|
|
||||||
output.setFilePointer(EltToVoid.GetElementPosition());
|
output.setFilePointer(EltToVoid.GetElementPosition());
|
||||||
|
|
||||||
// compute the size of the voided data based on the original one
|
// compute the size of the voided data based on the original one
|
||||||
SetSize(EltToVoid.GetSize() + EltToVoid.HeadSize() - 1); // 1 for the ID
|
SetSize(EltToVoid.GetSize() + EltToVoid.HeadSize() - 1); // 1 for the ID
|
||||||
SetSize(GetSize() - CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize()));
|
SetSize(GetSize() - CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize()));
|
||||||
// make sure we handle even the strange cases
|
// make sure we handle even the strange cases
|
||||||
//uint32 A1 = GetSize() + HeadSize();
|
//uint32 A1 = GetSize() + HeadSize();
|
||||||
//uint32 A2 = EltToVoid.GetSize() + EltToVoid.HeadSize();
|
//uint32 A2 = EltToVoid.GetSize() + EltToVoid.HeadSize();
|
||||||
if (GetSize() + HeadSize() != EltToVoid.GetSize() + EltToVoid.HeadSize()) {
|
if (GetSize() + HeadSize() != EltToVoid.GetSize() + EltToVoid.HeadSize()) {
|
||||||
SetSize(GetSize()-1);
|
SetSize(GetSize()-1);
|
||||||
SetSizeLength(CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize()) + 1);
|
SetSizeLength(CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize()) + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GetSize() != 0) {
|
if (GetSize() != 0) {
|
||||||
RenderHead(output, false, bWithDefault); // the rest of the data is not rewritten
|
RenderHead(output, false, bWithDefault); // the rest of the data is not rewritten
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ComeBackAfterward) {
|
if (ComeBackAfterward) {
|
||||||
output.setFilePointer(CurrentPosition);
|
output.setFilePointer(CurrentPosition);
|
||||||
}
|
}
|
||||||
|
|
||||||
return EltToVoid.GetSize() + EltToVoid.HeadSize();
|
return EltToVoid.GetSize() + EltToVoid.HeadSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,10 +27,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: IOCallback.cpp 639 2004-07-09 20:59:14Z mosu $
|
\version \$Id: IOCallback.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
@ -47,37 +47,37 @@ START_LIBEBML_NAMESPACE
|
|||||||
|
|
||||||
void IOCallback::writeFully(const void*Buffer,size_t Size)
|
void IOCallback::writeFully(const void*Buffer,size_t Size)
|
||||||
{
|
{
|
||||||
if (Size == 0)
|
if (Size == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (Buffer == NULL)
|
if (Buffer == NULL)
|
||||||
throw;
|
throw;
|
||||||
|
|
||||||
if(write(Buffer,Size) != Size)
|
if(write(Buffer,Size) != Size)
|
||||||
{
|
{
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
stringstream Msg;
|
stringstream Msg;
|
||||||
Msg<<"EOF in writeFully("<<Buffer<<","<<Size<<")";
|
Msg<<"EOF in writeFully("<<Buffer<<","<<Size<<")";
|
||||||
throw runtime_error(Msg.str());
|
throw runtime_error(Msg.str());
|
||||||
#endif // GCC2
|
#endif // GCC2
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void IOCallback::readFully(void*Buffer,size_t Size)
|
void IOCallback::readFully(void*Buffer,size_t Size)
|
||||||
{
|
{
|
||||||
if(Buffer == NULL)
|
if(Buffer == NULL)
|
||||||
throw;
|
throw;
|
||||||
|
|
||||||
if(read(Buffer,Size) != Size)
|
if(read(Buffer,Size) != Size)
|
||||||
{
|
{
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
stringstream Msg;
|
stringstream Msg;
|
||||||
Msg<<"EOF in readFully("<<Buffer<<","<<Size<<")";
|
Msg<<"EOF in readFully("<<Buffer<<","<<Size<<")";
|
||||||
throw runtime_error(Msg.str());
|
throw runtime_error(Msg.str());
|
||||||
#endif // GCC2
|
#endif // GCC2
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,9 +27,9 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: MemIOCallback.cpp 693 2004-07-31 08:56:28Z robux4 $
|
\version \$Id: MemIOCallback.cpp 693 2004-07-31 08:56:28Z robux4 $
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "ebml/MemIOCallback.h"
|
#include "ebml/MemIOCallback.h"
|
||||||
@ -40,85 +40,85 @@ START_LIBEBML_NAMESPACE
|
|||||||
|
|
||||||
MemIOCallback::MemIOCallback(uint64 DefaultSize)
|
MemIOCallback::MemIOCallback(uint64 DefaultSize)
|
||||||
{
|
{
|
||||||
//The default size of the buffer is 128 bytes
|
//The default size of the buffer is 128 bytes
|
||||||
dataBuffer = (binary *)malloc(DefaultSize);
|
dataBuffer = (binary *)malloc(DefaultSize);
|
||||||
if (dataBuffer == NULL) {
|
if (dataBuffer == NULL) {
|
||||||
mOk = false;
|
mOk = false;
|
||||||
std::stringstream Msg;
|
std::stringstream Msg;
|
||||||
Msg << "Failed to alloc memory block of size ";
|
Msg << "Failed to alloc memory block of size ";
|
||||||
// not working with VC6 Msg << DefaultSize;
|
// not working with VC6 Msg << DefaultSize;
|
||||||
mLastErrorStr = Msg.str();
|
mLastErrorStr = Msg.str();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
dataBufferMemorySize = DefaultSize;
|
dataBufferMemorySize = DefaultSize;
|
||||||
dataBufferPos = 0;
|
dataBufferPos = 0;
|
||||||
dataBufferTotalSize = 0;
|
dataBufferTotalSize = 0;
|
||||||
mOk = true;
|
mOk = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
MemIOCallback::~MemIOCallback()
|
MemIOCallback::~MemIOCallback()
|
||||||
{
|
{
|
||||||
if (dataBuffer != NULL)
|
if (dataBuffer != NULL)
|
||||||
free(dataBuffer);
|
free(dataBuffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 MemIOCallback::read(void *Buffer, size_t Size)
|
uint32 MemIOCallback::read(void *Buffer, size_t Size)
|
||||||
{
|
{
|
||||||
if (Buffer == NULL || Size < 1)
|
if (Buffer == NULL || Size < 1)
|
||||||
return 0;
|
return 0;
|
||||||
//If the size is larger than than the amount left in the buffer
|
//If the size is larger than than the amount left in the buffer
|
||||||
if (Size + dataBufferPos > dataBufferTotalSize)
|
if (Size + dataBufferPos > dataBufferTotalSize)
|
||||||
{
|
{
|
||||||
//We will only return the remaining data
|
//We will only return the remaining data
|
||||||
memcpy(Buffer, dataBuffer + dataBufferPos, dataBufferTotalSize - dataBufferPos);
|
memcpy(Buffer, dataBuffer + dataBufferPos, dataBufferTotalSize - dataBufferPos);
|
||||||
uint64 oldDataPos = dataBufferPos;
|
uint64 oldDataPos = dataBufferPos;
|
||||||
dataBufferPos = dataBufferTotalSize;
|
dataBufferPos = dataBufferTotalSize;
|
||||||
return dataBufferTotalSize - oldDataPos;
|
return dataBufferTotalSize - oldDataPos;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Well... We made it here, so do a quick and simple copy
|
//Well... We made it here, so do a quick and simple copy
|
||||||
memcpy(Buffer, dataBuffer+dataBufferPos, Size);
|
memcpy(Buffer, dataBuffer+dataBufferPos, Size);
|
||||||
dataBufferPos += Size;
|
dataBufferPos += Size;
|
||||||
|
|
||||||
return Size;
|
return Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MemIOCallback::setFilePointer(int64 Offset, seek_mode Mode)
|
void MemIOCallback::setFilePointer(int64 Offset, seek_mode Mode)
|
||||||
{
|
{
|
||||||
if (Mode == seek_beginning)
|
if (Mode == seek_beginning)
|
||||||
dataBufferPos = Offset;
|
dataBufferPos = Offset;
|
||||||
else if (Mode == seek_current)
|
else if (Mode == seek_current)
|
||||||
dataBufferPos = dataBufferPos + Offset;
|
dataBufferPos = dataBufferPos + Offset;
|
||||||
else if (Mode == seek_end)
|
else if (Mode == seek_end)
|
||||||
dataBufferPos = dataBufferTotalSize + Offset;
|
dataBufferPos = dataBufferTotalSize + Offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t MemIOCallback::write(const void *Buffer, size_t Size)
|
size_t MemIOCallback::write(const void *Buffer, size_t Size)
|
||||||
{
|
{
|
||||||
if (dataBufferMemorySize < dataBufferPos + Size)
|
if (dataBufferMemorySize < dataBufferPos + Size)
|
||||||
{
|
{
|
||||||
//We need more memory!
|
//We need more memory!
|
||||||
dataBuffer = (binary *)realloc((void *)dataBuffer, dataBufferPos + Size);
|
dataBuffer = (binary *)realloc((void *)dataBuffer, dataBufferPos + Size);
|
||||||
}
|
}
|
||||||
memcpy(dataBuffer+dataBufferPos, Buffer, Size);
|
memcpy(dataBuffer+dataBufferPos, Buffer, Size);
|
||||||
dataBufferPos += Size;
|
dataBufferPos += Size;
|
||||||
if (dataBufferPos > dataBufferTotalSize)
|
if (dataBufferPos > dataBufferTotalSize)
|
||||||
dataBufferTotalSize = dataBufferPos;
|
dataBufferTotalSize = dataBufferPos;
|
||||||
|
|
||||||
return Size;
|
return Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 MemIOCallback::write(IOCallback & IOToRead, size_t Size)
|
uint32 MemIOCallback::write(IOCallback & IOToRead, size_t Size)
|
||||||
{
|
{
|
||||||
if (dataBufferMemorySize < dataBufferPos + Size)
|
if (dataBufferMemorySize < dataBufferPos + Size)
|
||||||
{
|
{
|
||||||
//We need more memory!
|
//We need more memory!
|
||||||
dataBuffer = (binary *)realloc((void *)dataBuffer, dataBufferPos + Size);
|
dataBuffer = (binary *)realloc((void *)dataBuffer, dataBufferPos + Size);
|
||||||
}
|
}
|
||||||
IOToRead.readFully(&dataBuffer[dataBufferPos], Size);
|
IOToRead.readFully(&dataBuffer[dataBufferPos], Size);
|
||||||
dataBufferTotalSize = Size;
|
dataBufferTotalSize = Size;
|
||||||
return Size;
|
return Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,10 +27,10 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: StdIOCallback.cpp 1298 2008-02-21 22:14:18Z mosu $
|
\version \$Id: StdIOCallback.cpp 1298 2008-02-21 22:14:18Z mosu $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
@ -48,154 +48,154 @@ using namespace std;
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
CRTError::CRTError(int nError, const std::string & Description)
|
CRTError::CRTError(int nError, const std::string & Description)
|
||||||
:std::runtime_error(Description+": "+strerror(nError))
|
:std::runtime_error(Description+": "+strerror(nError))
|
||||||
,Error(nError)
|
,Error(nError)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
CRTError::CRTError(const std::string & Description,int nError)
|
CRTError::CRTError(const std::string & Description,int nError)
|
||||||
:std::runtime_error(Description+": "+strerror(nError))
|
:std::runtime_error(Description+": "+strerror(nError))
|
||||||
,Error(nError)
|
,Error(nError)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
StdIOCallback::StdIOCallback(const char*Path, const open_mode aMode)
|
StdIOCallback::StdIOCallback(const char*Path, const open_mode aMode)
|
||||||
{
|
{
|
||||||
assert(Path!=0);
|
assert(Path!=0);
|
||||||
|
|
||||||
const char *Mode;
|
const char *Mode;
|
||||||
switch (aMode)
|
switch (aMode)
|
||||||
{
|
{
|
||||||
case MODE_READ:
|
case MODE_READ:
|
||||||
Mode = "rb";
|
Mode = "rb";
|
||||||
break;
|
break;
|
||||||
case MODE_SAFE:
|
case MODE_SAFE:
|
||||||
Mode = "rb+";
|
Mode = "rb+";
|
||||||
break;
|
break;
|
||||||
case MODE_WRITE:
|
case MODE_WRITE:
|
||||||
Mode = "wb";
|
Mode = "wb";
|
||||||
break;
|
break;
|
||||||
case MODE_CREATE:
|
case MODE_CREATE:
|
||||||
Mode = "wb+";
|
Mode = "wb+";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw 0;
|
throw 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
File=fopen(Path,Mode);
|
File=fopen(Path,Mode);
|
||||||
if(File==0)
|
if(File==0)
|
||||||
{
|
{
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
stringstream Msg;
|
stringstream Msg;
|
||||||
Msg<<"Can't open stdio file \""<<Path<<"\" in mode \""<<Mode<<"\"";
|
Msg<<"Can't open stdio file \""<<Path<<"\" in mode \""<<Mode<<"\"";
|
||||||
throw CRTError(Msg.str());
|
throw CRTError(Msg.str());
|
||||||
#endif // GCC2
|
#endif // GCC2
|
||||||
}
|
}
|
||||||
mCurrentPosition = 0;
|
mCurrentPosition = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
StdIOCallback::~StdIOCallback()throw()
|
StdIOCallback::~StdIOCallback()throw()
|
||||||
{
|
{
|
||||||
close();
|
close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
uint32 StdIOCallback::read(void*Buffer,size_t Size)
|
uint32 StdIOCallback::read(void*Buffer,size_t Size)
|
||||||
{
|
{
|
||||||
assert(File!=0);
|
assert(File!=0);
|
||||||
|
|
||||||
size_t result = fread(Buffer, 1, Size, File);
|
size_t result = fread(Buffer, 1, Size, File);
|
||||||
mCurrentPosition += result;
|
mCurrentPosition += result;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void StdIOCallback::setFilePointer(int64 Offset,seek_mode Mode)
|
void StdIOCallback::setFilePointer(int64 Offset,seek_mode Mode)
|
||||||
{
|
{
|
||||||
assert(File!=0);
|
assert(File!=0);
|
||||||
|
|
||||||
// There is a numeric cast in the boost library, which would be quite nice for this checking
|
// There is a numeric cast in the boost library, which would be quite nice for this checking
|
||||||
/*
|
/*
|
||||||
SL : replaced because unknown class in cygwin
|
SL : replaced because unknown class in cygwin
|
||||||
assert(Offset <= numeric_limits<long>::max());
|
assert(Offset <= numeric_limits<long>::max());
|
||||||
assert(Offset >= numeric_limits<long>::min());
|
assert(Offset >= numeric_limits<long>::min());
|
||||||
*/
|
*/
|
||||||
|
|
||||||
assert(Offset <= LONG_MAX);
|
assert(Offset <= LONG_MAX);
|
||||||
assert(Offset >= LONG_MIN);
|
assert(Offset >= LONG_MIN);
|
||||||
|
|
||||||
assert(Mode==SEEK_CUR||Mode==SEEK_END||Mode==SEEK_SET);
|
assert(Mode==SEEK_CUR||Mode==SEEK_END||Mode==SEEK_SET);
|
||||||
|
|
||||||
if(fseek(File,Offset,Mode)!=0)
|
if(fseek(File,Offset,Mode)!=0)
|
||||||
{
|
{
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
ostringstream Msg;
|
ostringstream Msg;
|
||||||
Msg<<"Failed to seek file "<<File<<" to offset "<<(unsigned long)Offset<<" in mode "<<Mode;
|
Msg<<"Failed to seek file "<<File<<" to offset "<<(unsigned long)Offset<<" in mode "<<Mode;
|
||||||
throw CRTError(Msg.str());
|
throw CRTError(Msg.str());
|
||||||
#endif // GCC2
|
#endif // GCC2
|
||||||
mCurrentPosition = ftell(File);
|
mCurrentPosition = ftell(File);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
switch ( Mode )
|
switch ( Mode )
|
||||||
{
|
{
|
||||||
case SEEK_CUR:
|
case SEEK_CUR:
|
||||||
mCurrentPosition += Offset;
|
mCurrentPosition += Offset;
|
||||||
break;
|
break;
|
||||||
case SEEK_END:
|
case SEEK_END:
|
||||||
mCurrentPosition = ftell(File);
|
mCurrentPosition = ftell(File);
|
||||||
break;
|
break;
|
||||||
case SEEK_SET:
|
case SEEK_SET:
|
||||||
mCurrentPosition = Offset;
|
mCurrentPosition = Offset;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t StdIOCallback::write(const void*Buffer,size_t Size)
|
size_t StdIOCallback::write(const void*Buffer,size_t Size)
|
||||||
{
|
{
|
||||||
assert(File!=0);
|
assert(File!=0);
|
||||||
uint32 Result = fwrite(Buffer,1,Size,File);
|
uint32 Result = fwrite(Buffer,1,Size,File);
|
||||||
mCurrentPosition += Result;
|
mCurrentPosition += Result;
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 StdIOCallback::getFilePointer()
|
uint64 StdIOCallback::getFilePointer()
|
||||||
{
|
{
|
||||||
assert(File!=0);
|
assert(File!=0);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
long Result=ftell(File);
|
long Result=ftell(File);
|
||||||
if(Result<0)
|
if(Result<0)
|
||||||
{
|
{
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
stringstream Msg;
|
stringstream Msg;
|
||||||
Msg<<"Can't tell the current file pointer position for "<<File;
|
Msg<<"Can't tell the current file pointer position for "<<File;
|
||||||
throw CRTError(Msg.str());
|
throw CRTError(Msg.str());
|
||||||
#endif // GCC2
|
#endif // GCC2
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return mCurrentPosition;
|
return mCurrentPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
void StdIOCallback::close()
|
void StdIOCallback::close()
|
||||||
{
|
{
|
||||||
if(File==0)
|
if(File==0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if(fclose(File)!=0)
|
if(fclose(File)!=0)
|
||||||
{
|
{
|
||||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||||
stringstream Msg;
|
stringstream Msg;
|
||||||
Msg<<"Can't close file "<<File;
|
Msg<<"Can't close file "<<File;
|
||||||
throw CRTError(Msg.str());
|
throw CRTError(Msg.str());
|
||||||
#endif // GCC2
|
#endif // GCC2
|
||||||
}
|
}
|
||||||
|
|
||||||
File=0;
|
File=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -27,11 +27,11 @@
|
|||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: WinIOCallback.cpp 1092 2005-03-16 13:01:15Z robux4 $
|
\version \$Id: WinIOCallback.cpp 1092 2005-03-16 13:01:15Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
\author Cyrius <suiryc @ users.sf.net>
|
\author Cyrius <suiryc @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
@ -47,238 +47,238 @@
|
|||||||
START_LIBEBML_NAMESPACE
|
START_LIBEBML_NAMESPACE
|
||||||
|
|
||||||
WinIOCallback::WinIOCallback(const char* Path, const open_mode aMode, DWORD dwFlags)
|
WinIOCallback::WinIOCallback(const char* Path, const open_mode aMode, DWORD dwFlags)
|
||||||
:mFile(NULL), mOk(false)
|
:mFile(NULL), mOk(false)
|
||||||
{
|
{
|
||||||
mOk = open(Path, aMode, dwFlags);
|
mOk = open(Path, aMode, dwFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
WinIOCallback::WinIOCallback(const wchar_t* Path, const open_mode aMode, DWORD dwFlags)
|
WinIOCallback::WinIOCallback(const wchar_t* Path, const open_mode aMode, DWORD dwFlags)
|
||||||
:mFile(NULL), mOk(false)
|
:mFile(NULL), mOk(false)
|
||||||
{
|
{
|
||||||
mOk = open(Path, aMode, dwFlags);
|
mOk = open(Path, aMode, dwFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
WinIOCallback::~WinIOCallback()
|
WinIOCallback::~WinIOCallback()
|
||||||
{
|
{
|
||||||
close();
|
close();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WinIOCallback::open(const char* Path, const open_mode aMode, DWORD dwFlags)
|
bool WinIOCallback::open(const char* Path, const open_mode aMode, DWORD dwFlags)
|
||||||
{
|
{
|
||||||
assert(Path!=0);
|
assert(Path!=0);
|
||||||
|
|
||||||
DWORD AccessMode, ShareMode, Disposition;
|
DWORD AccessMode, ShareMode, Disposition;
|
||||||
|
|
||||||
switch (aMode)
|
switch (aMode)
|
||||||
{
|
{
|
||||||
case MODE_READ:
|
case MODE_READ:
|
||||||
AccessMode = GENERIC_READ;
|
AccessMode = GENERIC_READ;
|
||||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||||
Disposition = OPEN_EXISTING;
|
Disposition = OPEN_EXISTING;
|
||||||
break;
|
break;
|
||||||
case MODE_WRITE:
|
case MODE_WRITE:
|
||||||
AccessMode = GENERIC_WRITE;
|
AccessMode = GENERIC_WRITE;
|
||||||
ShareMode = 0;
|
ShareMode = 0;
|
||||||
Disposition = OPEN_ALWAYS;
|
Disposition = OPEN_ALWAYS;
|
||||||
break;
|
break;
|
||||||
case MODE_SAFE:
|
case MODE_SAFE:
|
||||||
AccessMode = GENERIC_WRITE|GENERIC_READ;
|
AccessMode = GENERIC_WRITE|GENERIC_READ;
|
||||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||||
Disposition = OPEN_ALWAYS;
|
Disposition = OPEN_ALWAYS;
|
||||||
break;
|
break;
|
||||||
case MODE_CREATE:
|
case MODE_CREATE:
|
||||||
AccessMode = GENERIC_WRITE;
|
AccessMode = GENERIC_WRITE;
|
||||||
ShareMode = 0;
|
ShareMode = 0;
|
||||||
Disposition = CREATE_ALWAYS;
|
Disposition = CREATE_ALWAYS;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
mFile = CreateFileA(Path, AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
mFile = CreateFileA(Path, AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
||||||
if ((mFile == INVALID_HANDLE_VALUE) || ((long)mFile == 0xffffffff))
|
if ((mFile == INVALID_HANDLE_VALUE) || ((long)mFile == 0xffffffff))
|
||||||
{
|
{
|
||||||
//File was not opened
|
//File was not opened
|
||||||
char err_msg[256];
|
char err_msg[256];
|
||||||
DWORD error_code = GetLastError();
|
DWORD error_code = GetLastError();
|
||||||
// An error message about the file already existing is not really an error message :P
|
// An error message about the file already existing is not really an error message :P
|
||||||
if (error_code != ERROR_ALREADY_EXISTS) {
|
if (error_code != ERROR_ALREADY_EXISTS) {
|
||||||
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, 0, error_code, 0, err_msg, 255, NULL);
|
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, 0, error_code, 0, err_msg, 255, NULL);
|
||||||
EBML_TRACE("Failed to open file \"%hs\" in mode %d.", Path, aMode);
|
EBML_TRACE("Failed to open file \"%hs\" in mode %d.", Path, aMode);
|
||||||
|
|
||||||
mLastErrorStr = err_msg;
|
mLastErrorStr = err_msg;
|
||||||
return mOk = false;
|
return mOk = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mCurrentPosition = 0;
|
mCurrentPosition = 0;
|
||||||
|
|
||||||
EBML_TRACE("Successfully opened file \"%hs\" in mode %d. The handle is %p\n", Path, aMode, mFile);
|
EBML_TRACE("Successfully opened file \"%hs\" in mode %d. The handle is %p\n", Path, aMode, mFile);
|
||||||
|
|
||||||
return mOk = true;
|
return mOk = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
bool WinIOCallback::open(const wchar_t* Path, const open_mode aMode, DWORD dwFlags)
|
bool WinIOCallback::open(const wchar_t* Path, const open_mode aMode, DWORD dwFlags)
|
||||||
{
|
{
|
||||||
assert(Path!=0);
|
assert(Path!=0);
|
||||||
|
|
||||||
DWORD AccessMode, ShareMode, Disposition;
|
DWORD AccessMode, ShareMode, Disposition;
|
||||||
|
|
||||||
switch (aMode)
|
switch (aMode)
|
||||||
{
|
{
|
||||||
case MODE_READ:
|
case MODE_READ:
|
||||||
AccessMode = GENERIC_READ;
|
AccessMode = GENERIC_READ;
|
||||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||||
Disposition = OPEN_EXISTING;
|
Disposition = OPEN_EXISTING;
|
||||||
break;
|
break;
|
||||||
case MODE_WRITE:
|
case MODE_WRITE:
|
||||||
AccessMode = GENERIC_WRITE;
|
AccessMode = GENERIC_WRITE;
|
||||||
ShareMode = 0;
|
ShareMode = 0;
|
||||||
Disposition = OPEN_ALWAYS;
|
Disposition = OPEN_ALWAYS;
|
||||||
break;
|
break;
|
||||||
case MODE_SAFE:
|
case MODE_SAFE:
|
||||||
AccessMode = GENERIC_WRITE|GENERIC_READ;
|
AccessMode = GENERIC_WRITE|GENERIC_READ;
|
||||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||||
Disposition = OPEN_ALWAYS;
|
Disposition = OPEN_ALWAYS;
|
||||||
break;
|
break;
|
||||||
case MODE_CREATE:
|
case MODE_CREATE:
|
||||||
AccessMode = GENERIC_WRITE;
|
AccessMode = GENERIC_WRITE;
|
||||||
ShareMode = 0;
|
ShareMode = 0;
|
||||||
Disposition = CREATE_ALWAYS;
|
Disposition = CREATE_ALWAYS;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((LONG)GetVersion() >= 0) {
|
if ((LONG)GetVersion() >= 0) {
|
||||||
mFile = CreateFileW(Path, AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
mFile = CreateFileW(Path, AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
||||||
} else {
|
} else {
|
||||||
int errCode;
|
int errCode;
|
||||||
int pathSize = wcslen(Path);
|
int pathSize = wcslen(Path);
|
||||||
unsigned int bufferSize = pathSize + sizeof(wchar_t) * 2;
|
unsigned int bufferSize = pathSize + sizeof(wchar_t) * 2;
|
||||||
std::string PathA;
|
std::string PathA;
|
||||||
PathA.resize(bufferSize);
|
PathA.resize(bufferSize);
|
||||||
errCode = WideCharToMultiByte(CP_ACP, 0, Path, pathSize, (char *)PathA.c_str(), bufferSize, NULL, NULL);
|
errCode = WideCharToMultiByte(CP_ACP, 0, Path, pathSize, (char *)PathA.c_str(), bufferSize, NULL, NULL);
|
||||||
if (errCode == 0)
|
if (errCode == 0)
|
||||||
errCode = GetLastError();
|
errCode = GetLastError();
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
if (errCode == ERROR_INSUFFICIENT_BUFFER) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INSUFFICIENT_BUFFER"));
|
if (errCode == ERROR_INSUFFICIENT_BUFFER) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INSUFFICIENT_BUFFER"));
|
||||||
if (errCode == ERROR_INVALID_FLAGS) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INVALID_FLAGS"));
|
if (errCode == ERROR_INVALID_FLAGS) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INVALID_FLAGS"));
|
||||||
if (errCode == ERROR_INVALID_PARAMETER) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INVALID_PARAMETER"));
|
if (errCode == ERROR_INVALID_PARAMETER) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INVALID_PARAMETER"));
|
||||||
#endif
|
#endif
|
||||||
while (errCode == ERROR_INSUFFICIENT_BUFFER) {
|
while (errCode == ERROR_INSUFFICIENT_BUFFER) {
|
||||||
// Increase the buffer size
|
// Increase the buffer size
|
||||||
bufferSize += MAX_PATH;
|
bufferSize += MAX_PATH;
|
||||||
PathA.resize(bufferSize);
|
PathA.resize(bufferSize);
|
||||||
errCode = WideCharToMultiByte(CP_ACP, WC_SEPCHARS, Path, pathSize, (char *)PathA.c_str(), bufferSize, NULL, NULL);
|
errCode = WideCharToMultiByte(CP_ACP, WC_SEPCHARS, Path, pathSize, (char *)PathA.c_str(), bufferSize, NULL, NULL);
|
||||||
if (errCode == 0)
|
if (errCode == 0)
|
||||||
errCode = GetLastError();
|
errCode = GetLastError();
|
||||||
}
|
}
|
||||||
if (errCode != 0) {
|
if (errCode != 0) {
|
||||||
mFile = CreateFileA(PathA.c_str(), AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
mFile = CreateFileA(PathA.c_str(), AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
||||||
} else {
|
} else {
|
||||||
mLastErrorStr = "Couldn't convert Unicode filename to ANSI.";
|
mLastErrorStr = "Couldn't convert Unicode filename to ANSI.";
|
||||||
return mOk = false;
|
return mOk = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ((mFile == INVALID_HANDLE_VALUE) || ((long)mFile == 0xffffffff))
|
if ((mFile == INVALID_HANDLE_VALUE) || ((long)mFile == 0xffffffff))
|
||||||
{
|
{
|
||||||
//File was not opened
|
//File was not opened
|
||||||
char err_msg[256];
|
char err_msg[256];
|
||||||
DWORD error_code = GetLastError();
|
DWORD error_code = GetLastError();
|
||||||
// An error message about the file already existing is not really an error message :P
|
// An error message about the file already existing is not really an error message :P
|
||||||
if (error_code != ERROR_ALREADY_EXISTS) {
|
if (error_code != ERROR_ALREADY_EXISTS) {
|
||||||
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, 0, error_code, 0, err_msg, 255, NULL);
|
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, 0, error_code, 0, err_msg, 255, NULL);
|
||||||
EBML_TRACE("Failed to open file \"%S\" in mode %d.", Path, aMode);
|
EBML_TRACE("Failed to open file \"%S\" in mode %d.", Path, aMode);
|
||||||
mLastErrorStr = err_msg;
|
mLastErrorStr = err_msg;
|
||||||
return mOk = false;
|
return mOk = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mCurrentPosition = 0;
|
mCurrentPosition = 0;
|
||||||
|
|
||||||
EBML_TRACE("Successfully opened file \"%S\" in mode %d. The handle is %p\n", Path, aMode, mFile);
|
EBML_TRACE("Successfully opened file \"%S\" in mode %d. The handle is %p\n", Path, aMode, mFile);
|
||||||
return mOk = true;
|
return mOk = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void WinIOCallback::close()
|
void WinIOCallback::close()
|
||||||
{
|
{
|
||||||
if (mFile) {
|
if (mFile) {
|
||||||
CloseHandle(mFile);
|
CloseHandle(mFile);
|
||||||
mFile = NULL;
|
mFile = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64 WinIOCallback::getFilePointer()
|
uint64 WinIOCallback::getFilePointer()
|
||||||
{
|
{
|
||||||
if (!mFile) {
|
if (!mFile) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return mCurrentPosition;
|
return mCurrentPosition;
|
||||||
#if 0
|
#if 0
|
||||||
LONG High = 0;
|
LONG High = 0;
|
||||||
DWORD Low = SetFilePointer(mFile, 0, &High, FILE_CURRENT);
|
DWORD Low = SetFilePointer(mFile, 0, &High, FILE_CURRENT);
|
||||||
if ( (Low==INVALID_SET_FILE_POINTER) && (GetLastError()!=NO_ERROR) )
|
if ( (Low==INVALID_SET_FILE_POINTER) && (GetLastError()!=NO_ERROR) )
|
||||||
return static_cast<uint64>(-1);
|
return static_cast<uint64>(-1);
|
||||||
return ((uint64(High)<<32) | Low);
|
return ((uint64(High)<<32) | Low);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void WinIOCallback::setFilePointer(int64 Offset, seek_mode Mode)
|
void WinIOCallback::setFilePointer(int64 Offset, seek_mode Mode)
|
||||||
{
|
{
|
||||||
DWORD Method;
|
DWORD Method;
|
||||||
switch(Mode)
|
switch(Mode)
|
||||||
{
|
{
|
||||||
case seek_beginning:
|
case seek_beginning:
|
||||||
Method=FILE_BEGIN;
|
Method=FILE_BEGIN;
|
||||||
break;
|
break;
|
||||||
case seek_current:
|
case seek_current:
|
||||||
Method=FILE_CURRENT;
|
Method=FILE_CURRENT;
|
||||||
break;
|
break;
|
||||||
case seek_end:
|
case seek_end:
|
||||||
Method=FILE_END;
|
Method=FILE_END;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
assert(false);
|
assert(false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
LONG High = LONG(Offset>>32);
|
LONG High = LONG(Offset>>32);
|
||||||
mCurrentPosition = SetFilePointer(mFile, LONG(Offset & 0xffffffff), &High, Method);
|
mCurrentPosition = SetFilePointer(mFile, LONG(Offset & 0xffffffff), &High, Method);
|
||||||
if ( mCurrentPosition == INVALID_SET_FILE_POINTER )
|
if ( mCurrentPosition == INVALID_SET_FILE_POINTER )
|
||||||
{
|
{
|
||||||
High = 0;
|
High = 0;
|
||||||
DWORD Low = SetFilePointer(mFile, 0, &High, FILE_CURRENT);
|
DWORD Low = SetFilePointer(mFile, 0, &High, FILE_CURRENT);
|
||||||
mCurrentPosition = ((uint64(High)<<32) | Low);
|
mCurrentPosition = ((uint64(High)<<32) | Low);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mCurrentPosition |= uint64(High)<<32;
|
mCurrentPosition |= uint64(High)<<32;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 WinIOCallback::read(void*Buffer,size_t Size)
|
uint32 WinIOCallback::read(void*Buffer,size_t Size)
|
||||||
{
|
{
|
||||||
DWORD BytesRead;
|
DWORD BytesRead;
|
||||||
if (!ReadFile(mFile, Buffer, Size, &BytesRead, NULL)) {
|
if (!ReadFile(mFile, Buffer, Size, &BytesRead, NULL)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
mCurrentPosition += BytesRead;
|
mCurrentPosition += BytesRead;
|
||||||
return BytesRead;
|
return BytesRead;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t WinIOCallback::write(const void*Buffer,size_t Size)
|
size_t WinIOCallback::write(const void*Buffer,size_t Size)
|
||||||
{
|
{
|
||||||
DWORD BytesWriten;
|
DWORD BytesWriten;
|
||||||
if (!WriteFile(mFile, Buffer, Size, &BytesWriten, NULL)) {
|
if (!WriteFile(mFile, Buffer, Size, &BytesWriten, NULL)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
mCurrentPosition += BytesWriten;
|
mCurrentPosition += BytesWriten;
|
||||||
return BytesWriten;
|
return BytesWriten;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WinIOCallback::SetEOF()
|
bool WinIOCallback::SetEOF()
|
||||||
{
|
{
|
||||||
return SetEndOfFile(mFile) != 0;
|
return SetEndOfFile(mFile) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
@ -26,11 +26,11 @@
|
|||||||
**
|
**
|
||||||
**********************************************************************/
|
**********************************************************************/
|
||||||
/*!
|
/*!
|
||||||
\file
|
\file
|
||||||
\version \$Id: WinIOCallback.h 1090 2005-03-16 12:47:59Z robux4 $
|
\version \$Id: WinIOCallback.h 1090 2005-03-16 12:47:59Z robux4 $
|
||||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||||
\author Jory Stone <jcsston @ toughguy.net>
|
\author Jory Stone <jcsston @ toughguy.net>
|
||||||
\author Cyrius <suiryc @ users.sf.net>
|
\author Cyrius <suiryc @ users.sf.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBEBML_WINIOCALLBACK_H
|
#ifndef LIBEBML_WINIOCALLBACK_H
|
||||||
@ -46,28 +46,28 @@ START_LIBEBML_NAMESPACE
|
|||||||
class WinIOCallback: public IOCallback
|
class WinIOCallback: public IOCallback
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
WinIOCallback(const wchar_t* Path, const open_mode aMode, DWORD dwFlags=0);
|
WinIOCallback(const wchar_t* Path, const open_mode aMode, DWORD dwFlags=0);
|
||||||
WinIOCallback(const char* Path, const open_mode aMode, DWORD dwFlags=0);
|
WinIOCallback(const char* Path, const open_mode aMode, DWORD dwFlags=0);
|
||||||
virtual ~WinIOCallback();
|
virtual ~WinIOCallback();
|
||||||
|
|
||||||
bool open(const wchar_t* Path, const open_mode Mode, DWORD dwFlags=0);
|
bool open(const wchar_t* Path, const open_mode Mode, DWORD dwFlags=0);
|
||||||
bool open(const char* Path, const open_mode Mode, DWORD dwFlags=0);
|
bool open(const char* Path, const open_mode Mode, DWORD dwFlags=0);
|
||||||
|
|
||||||
virtual uint32 read(void*Buffer,size_t Size);
|
virtual uint32 read(void*Buffer,size_t Size);
|
||||||
virtual size_t write(const void*Buffer,size_t Size);
|
virtual size_t write(const void*Buffer,size_t Size);
|
||||||
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning);
|
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning);
|
||||||
virtual uint64 getFilePointer();
|
virtual uint64 getFilePointer();
|
||||||
virtual void close();
|
virtual void close();
|
||||||
|
|
||||||
bool IsOk() { return mOk; };
|
bool IsOk() { return mOk; };
|
||||||
const std::string &GetLastErrorStr() { return mLastErrorStr; };
|
const std::string &GetLastErrorStr() { return mLastErrorStr; };
|
||||||
bool SetEOF();
|
bool SetEOF();
|
||||||
protected:
|
protected:
|
||||||
bool mOk;
|
bool mOk;
|
||||||
std::string mLastErrorStr;
|
std::string mLastErrorStr;
|
||||||
uint64 mCurrentPosition;
|
uint64 mCurrentPosition;
|
||||||
|
|
||||||
HANDLE mFile;
|
HANDLE mFile;
|
||||||
};
|
};
|
||||||
|
|
||||||
END_LIBEBML_NAMESPACE
|
END_LIBEBML_NAMESPACE
|
||||||
|
Loading…
Reference in New Issue
Block a user