Fix error in RtpDump::Start due to r1156.
- r1156 fixed a check on the _text member of FileWrapper. Turns out this was incompatibile with the RTP dumps, which want to write both binary and text data. Writing text data to a file open as "b" isn't actually an error, so I simply removed the check. - Also cleans up the interface, most notably removing all WebRtc types. TEST=vie_auto_test Review URL: http://webrtc-codereview.appspot.com/317005 git-svn-id: http://webrtc.googlecode.com/svn/trunk@1175 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
parent
832cacacff
commit
5ae19de3ec
@ -191,7 +191,7 @@ class AudioProcessing : public Module {
|
||||
// a NULL-terminated string. If there is an ongoing recording, the old file
|
||||
// will be closed, and recording will continue in the newly specified file.
|
||||
// An already existing file will be overwritten without warning.
|
||||
static const int kMaxFilenameSize = 1024;
|
||||
static const size_t kMaxFilenameSize = 1024;
|
||||
virtual int StartDebugRecording(const char filename[kMaxFilenameSize]) = 0;
|
||||
|
||||
// Stops recording debugging information, and closes the file. Recording
|
||||
|
@ -114,7 +114,12 @@ WebRtc_Word32 RtpDumpImpl::Start(const WebRtc_Word8* fileNameUTF8)
|
||||
// All rtp dump files start with #!rtpplay.
|
||||
WebRtc_Word8 magic[16];
|
||||
sprintf(magic, "#!rtpplay%s \n", RTPFILE_VERSION);
|
||||
_file.WriteText(magic);
|
||||
if (_file.WriteText(magic) == -1)
|
||||
{
|
||||
WEBRTC_TRACE(kTraceError, kTraceUtility, -1,
|
||||
"error writing to file");
|
||||
return -1;
|
||||
}
|
||||
|
||||
// The header according to the rtpdump documentation is sizeof(RD_hdr_t)
|
||||
// which is 8 + 4 + 2 = 14 bytes for 32-bit architecture (and 22 bytes on
|
||||
@ -125,7 +130,12 @@ WebRtc_Word32 RtpDumpImpl::Start(const WebRtc_Word8* fileNameUTF8)
|
||||
// of padding should be added to the header.
|
||||
WebRtc_Word8 dummyHdr[16];
|
||||
memset(dummyHdr, 0, 16);
|
||||
_file.Write(dummyHdr, sizeof(dummyHdr));
|
||||
if (!_file.Write(dummyHdr, sizeof(dummyHdr)))
|
||||
{
|
||||
WEBRTC_TRACE(kTraceError, kTraceUtility, -1,
|
||||
"error writing to file");
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -190,8 +200,20 @@ WebRtc_Word32 RtpDumpImpl::DumpPacket(const WebRtc_UWord8* packet,
|
||||
{
|
||||
hdr.plen = RtpDumpHtons((WebRtc_UWord16)packetLength);
|
||||
}
|
||||
_file.Write(&hdr, sizeof(hdr));
|
||||
_file.Write(packet, packetLength);
|
||||
|
||||
if (!_file.Write(&hdr, sizeof(hdr)))
|
||||
{
|
||||
WEBRTC_TRACE(kTraceError, kTraceUtility, -1,
|
||||
"error writing to file");
|
||||
return -1;
|
||||
}
|
||||
if (!_file.Write(packet, packetLength))
|
||||
{
|
||||
WEBRTC_TRACE(kTraceError, kTraceUtility, -1,
|
||||
"error writing to file");
|
||||
return -1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -11,6 +11,8 @@
|
||||
#ifndef WEBRTC_SYSTEM_WRAPPERS_INTERFACE_FILE_WRAPPER_H_
|
||||
#define WEBRTC_SYSTEM_WRAPPERS_INTERFACE_FILE_WRAPPER_H_
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
#include "common_types.h"
|
||||
#include "typedefs.h"
|
||||
|
||||
@ -18,10 +20,11 @@
|
||||
// write from/to a file.
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
class FileWrapper : public InStream, public OutStream
|
||||
{
|
||||
public:
|
||||
enum { kMaxFileNameSize = 1024};
|
||||
static const size_t kMaxFileNameSize = 1024;
|
||||
|
||||
// Factory method. Constructor disabled.
|
||||
static FileWrapper* Create();
|
||||
@ -30,41 +33,44 @@ public:
|
||||
virtual bool Open() const = 0;
|
||||
|
||||
// Opens a file in read or write mode, decided by the readOnly parameter.
|
||||
virtual WebRtc_Word32 OpenFile(const WebRtc_Word8* fileNameUTF8,
|
||||
const bool readOnly,
|
||||
const bool loop = false,
|
||||
const bool text = false) = 0;
|
||||
virtual int OpenFile(const char* fileNameUTF8,
|
||||
bool readOnly,
|
||||
bool loop = false,
|
||||
bool text = false) = 0;
|
||||
|
||||
virtual WebRtc_Word32 CloseFile() = 0;
|
||||
virtual int CloseFile() = 0;
|
||||
|
||||
// Limits the file size.
|
||||
virtual WebRtc_Word32 SetMaxFileSize(WebRtc_Word32 bytes) = 0;
|
||||
virtual int SetMaxFileSize(size_t bytes) = 0;
|
||||
|
||||
// Flush any pending writes.
|
||||
virtual WebRtc_Word32 Flush() = 0;
|
||||
virtual int Flush() = 0;
|
||||
|
||||
// Returns the opened file's name in fileNameUTF8. size is the allocated
|
||||
// size of fileNameUTF8. The name will be truncated if the size of
|
||||
// fileNameUTF8 is to small.
|
||||
virtual WebRtc_Word32 FileName(WebRtc_Word8* fileNameUTF8,
|
||||
WebRtc_UWord32 size) const = 0;
|
||||
// Returns the opened file's name in |fileNameUTF8|. Provide the size of
|
||||
// the buffer in bytes in |size|. The name will be truncated if |size| is
|
||||
// too small.
|
||||
virtual int FileName(char* fileNameUTF8,
|
||||
size_t size) const = 0;
|
||||
|
||||
// Write text to the opened file. The written text can contain plain text
|
||||
// and text with type specifiers in the same way as sprintf works.
|
||||
virtual WebRtc_Word32 WriteText(const char* format, ...) = 0;
|
||||
virtual int WriteText(const char* format, ...) = 0;
|
||||
|
||||
// Reads len number of bytes from buf to file.
|
||||
// Inherited from Instream.
|
||||
// Reads |len| bytes from file to |buf|.
|
||||
virtual int Read(void* buf, int len) = 0;
|
||||
|
||||
// Writes len number of bytes to buf from file. The actual writing to file
|
||||
// may happen some time later. Call flush to force a write to take effect.
|
||||
// Inherited from OutStream.
|
||||
// Writes |len| bytes from |buf| to file. The actual writing may happen
|
||||
// some time later. Call Flush() to force a write.
|
||||
virtual bool Write(const void *buf, int len) = 0;
|
||||
|
||||
// Inherited from both Instream and OutStream.
|
||||
// Rewinds the file to the start. Only available when OpenFile() has been
|
||||
// called with loop argument set to true. Or readOnly argument has been set
|
||||
// to false.
|
||||
// called with |loop| == true or |readOnly| == true.
|
||||
virtual int Rewind() = 0;
|
||||
};
|
||||
|
||||
} // namespace webrtc
|
||||
|
||||
#endif // WEBRTC_SYSTEM_WRAPPERS_INTERFACE_FILE_WRAPPER_H_
|
||||
|
@ -20,6 +20,7 @@
|
||||
#endif
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
FileWrapper* FileWrapper::Create()
|
||||
{
|
||||
return new FileWrapperImpl();
|
||||
@ -30,8 +31,7 @@ FileWrapperImpl::FileWrapperImpl()
|
||||
_open(false),
|
||||
_looping(false),
|
||||
_readOnly(false),
|
||||
_text(false),
|
||||
_maxSizeInBytes(-1),
|
||||
_maxSizeInBytes(0),
|
||||
_sizeInBytes(0)
|
||||
{
|
||||
memset(_fileNameUTF8, 0, kMaxFileNameSize);
|
||||
@ -45,7 +45,7 @@ FileWrapperImpl::~FileWrapperImpl()
|
||||
}
|
||||
}
|
||||
|
||||
WebRtc_Word32 FileWrapperImpl::CloseFile()
|
||||
int FileWrapperImpl::CloseFile()
|
||||
{
|
||||
if (_id != NULL)
|
||||
{
|
||||
@ -70,13 +70,13 @@ int FileWrapperImpl::Rewind()
|
||||
return -1;
|
||||
}
|
||||
|
||||
WebRtc_Word32 FileWrapperImpl::SetMaxFileSize(WebRtc_Word32 bytes)
|
||||
int FileWrapperImpl::SetMaxFileSize(size_t bytes)
|
||||
{
|
||||
_maxSizeInBytes = bytes;
|
||||
return 0;
|
||||
}
|
||||
|
||||
WebRtc_Word32 FileWrapperImpl::Flush()
|
||||
int FileWrapperImpl::Flush()
|
||||
{
|
||||
if (_id != NULL)
|
||||
{
|
||||
@ -85,10 +85,10 @@ WebRtc_Word32 FileWrapperImpl::Flush()
|
||||
return -1;
|
||||
}
|
||||
|
||||
WebRtc_Word32 FileWrapperImpl::FileName(WebRtc_Word8* fileNameUTF8,
|
||||
WebRtc_UWord32 size) const
|
||||
int FileWrapperImpl::FileName(char* fileNameUTF8,
|
||||
size_t size) const
|
||||
{
|
||||
WebRtc_Word32 len = static_cast<WebRtc_Word32>(strlen(_fileNameUTF8));
|
||||
size_t len = strlen(_fileNameUTF8);
|
||||
if(len > kMaxFileNameSize)
|
||||
{
|
||||
assert(false);
|
||||
@ -99,7 +99,7 @@ WebRtc_Word32 FileWrapperImpl::FileName(WebRtc_Word8* fileNameUTF8,
|
||||
return -1;
|
||||
}
|
||||
// Make sure to NULL terminate
|
||||
if(size < (WebRtc_UWord32)len)
|
||||
if(size < len)
|
||||
{
|
||||
len = size - 1;
|
||||
}
|
||||
@ -108,24 +108,21 @@ WebRtc_Word32 FileWrapperImpl::FileName(WebRtc_Word8* fileNameUTF8,
|
||||
return 0;
|
||||
}
|
||||
|
||||
bool
|
||||
FileWrapperImpl::Open() const
|
||||
bool FileWrapperImpl::Open() const
|
||||
{
|
||||
return _open;
|
||||
}
|
||||
|
||||
WebRtc_Word32 FileWrapperImpl::OpenFile(const WebRtc_Word8 *fileNameUTF8,
|
||||
const bool readOnly, const bool loop,
|
||||
const bool text)
|
||||
int FileWrapperImpl::OpenFile(const char *fileNameUTF8, bool readOnly,
|
||||
bool loop, bool text)
|
||||
{
|
||||
WebRtc_Word32 length = (WebRtc_Word32)strlen(fileNameUTF8);
|
||||
size_t length = strlen(fileNameUTF8);
|
||||
if (length > kMaxFileNameSize)
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
|
||||
_readOnly = readOnly;
|
||||
_text = text;
|
||||
|
||||
FILE *tmpId = NULL;
|
||||
#if defined _WIN32
|
||||
@ -191,10 +188,6 @@ WebRtc_Word32 FileWrapperImpl::OpenFile(const WebRtc_Word8 *fileNameUTF8,
|
||||
|
||||
int FileWrapperImpl::Read(void *buf, int len)
|
||||
{
|
||||
if(len < 0)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
if (_id != NULL)
|
||||
{
|
||||
int res = static_cast<int>(fread(buf, 1, len, _id));
|
||||
@ -205,19 +198,16 @@ int FileWrapperImpl::Read(void *buf, int len)
|
||||
CloseFile();
|
||||
}
|
||||
}
|
||||
return res;
|
||||
return 0;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
WebRtc_Word32 FileWrapperImpl::WriteText(const char* format, ...)
|
||||
int FileWrapperImpl::WriteText(const char* format, ...)
|
||||
{
|
||||
if (_readOnly)
|
||||
return -1;
|
||||
|
||||
if (!_text)
|
||||
return -1;
|
||||
|
||||
if (_id == NULL)
|
||||
return -1;
|
||||
|
||||
@ -226,10 +216,10 @@ WebRtc_Word32 FileWrapperImpl::WriteText(const char* format, ...)
|
||||
|
||||
va_list args;
|
||||
va_start(args, format);
|
||||
int num_bytes = vfprintf(_id, format, args);
|
||||
int num_chars = vfprintf(_id, format, args);
|
||||
va_end(args);
|
||||
|
||||
if (num_bytes > 0)
|
||||
if (num_chars > 0)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
@ -250,21 +240,21 @@ bool FileWrapperImpl::Write(const void* buf, int len)
|
||||
if (_id != NULL)
|
||||
{
|
||||
// Check if it's time to stop writing.
|
||||
if ((_maxSizeInBytes != -1) &&
|
||||
_sizeInBytes + len > (WebRtc_UWord32)_maxSizeInBytes)
|
||||
if (_sizeInBytes + len > _maxSizeInBytes)
|
||||
{
|
||||
Flush();
|
||||
return false;
|
||||
}
|
||||
|
||||
size_t nBytes = fwrite((WebRtc_UWord8*)buf, 1, len, _id);
|
||||
if (nBytes > 0)
|
||||
size_t num_bytes = fwrite(buf, 1, len, _id);
|
||||
if (num_bytes > 0)
|
||||
{
|
||||
_sizeInBytes += static_cast<WebRtc_Word32>(nBytes);
|
||||
_sizeInBytes += num_bytes;
|
||||
return true;
|
||||
}
|
||||
CloseFile();
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
} // namespace webrtc
|
||||
|
@ -16,42 +16,42 @@
|
||||
#include <stdio.h>
|
||||
|
||||
namespace webrtc {
|
||||
|
||||
class FileWrapperImpl : public FileWrapper
|
||||
{
|
||||
public:
|
||||
FileWrapperImpl();
|
||||
virtual ~FileWrapperImpl();
|
||||
|
||||
virtual WebRtc_Word32 FileName(WebRtc_Word8* fileNameUTF8,
|
||||
WebRtc_UWord32 size) const;
|
||||
virtual int FileName(char* fileNameUTF8,
|
||||
size_t size) const;
|
||||
|
||||
virtual bool Open() const;
|
||||
|
||||
virtual WebRtc_Word32 OpenFile(const WebRtc_Word8* fileNameUTF8,
|
||||
const bool readOnly,
|
||||
const bool loop = false,
|
||||
const bool text = false);
|
||||
virtual int OpenFile(const char* fileNameUTF8,
|
||||
bool readOnly,
|
||||
bool loop = false,
|
||||
bool text = false);
|
||||
|
||||
virtual WebRtc_Word32 CloseFile();
|
||||
virtual WebRtc_Word32 SetMaxFileSize(WebRtc_Word32 bytes);
|
||||
virtual WebRtc_Word32 Flush();
|
||||
virtual int CloseFile();
|
||||
virtual int SetMaxFileSize(size_t bytes);
|
||||
virtual int Flush();
|
||||
|
||||
virtual int Read(void* buf, int len);
|
||||
virtual bool Write(const void *buf, int len);
|
||||
virtual int WriteText(const char* format, ...);
|
||||
virtual int Rewind();
|
||||
|
||||
virtual WebRtc_Word32 WriteText(const char* format, ...);
|
||||
|
||||
private:
|
||||
FILE* _id;
|
||||
bool _open;
|
||||
bool _looping;
|
||||
bool _readOnly;
|
||||
bool _text;
|
||||
WebRtc_Word32 _maxSizeInBytes; // -1 indicates file size limitation is off
|
||||
WebRtc_UWord32 _sizeInBytes;
|
||||
WebRtc_Word8 _fileNameUTF8[kMaxFileNameSize];
|
||||
FILE* _id;
|
||||
bool _open;
|
||||
bool _looping;
|
||||
bool _readOnly;
|
||||
size_t _maxSizeInBytes; // -1 indicates file size limitation is off
|
||||
size_t _sizeInBytes;
|
||||
char _fileNameUTF8[kMaxFileNameSize];
|
||||
};
|
||||
|
||||
} // namespace webrtc
|
||||
|
||||
#endif // WEBRTC_SYSTEM_WRAPPERS_SOURCE_FILE_IMPL_H_
|
||||
|
Loading…
x
Reference in New Issue
Block a user