gecko-dev/dom/media/gmp/widevine-adapter/WidevineFileIO.cpp
Chris Pearce 7e95ac21ed Bug 1341135 - Rename CDM log macro from Log to CDM_LOG. r=gerald
This prevents the Log macro from colliding with the Log function on
IPC ParamTraits definitions.

MozReview-Commit-ID: Hd2v6ilbmGc

--HG--
extra : rebase_source : d26d495878706fe5a2009dd33d226cc71193be13
2017-02-21 13:07:10 +13:00

98 lines
2.5 KiB
C++

#include "WidevineFileIO.h"
#include "WidevineUtils.h"
#include "WidevineAdapter.h"
using namespace cdm;
namespace mozilla {
void
WidevineFileIO::Open(const char* aFilename, uint32_t aFilenameLength)
{
mName = std::string(aFilename, aFilename + aFilenameLength);
GMPRecord* record = nullptr;
GMPErr err = GMPCreateRecord(aFilename, aFilenameLength, &record, static_cast<GMPRecordClient*>(this));
if (GMP_FAILED(err)) {
CDM_LOG("WidevineFileIO::Open() '%s' GMPCreateRecord failed", mName.c_str());
mClient->OnOpenComplete(FileIOClient::kError);
return;
}
if (GMP_FAILED(record->Open())) {
CDM_LOG("WidevineFileIO::Open() '%s' record open failed", mName.c_str());
mClient->OnOpenComplete(FileIOClient::kError);
return;
}
CDM_LOG("WidevineFileIO::Open() '%s'", mName.c_str());
mRecord = record;
}
void
WidevineFileIO::Read()
{
if (!mRecord) {
CDM_LOG("WidevineFileIO::Read() '%s' used uninitialized!", mName.c_str());
mClient->OnReadComplete(FileIOClient::kError, nullptr, 0);
return;
}
CDM_LOG("WidevineFileIO::Read() '%s'", mName.c_str());
mRecord->Read();
}
void
WidevineFileIO::Write(const uint8_t* aData, uint32_t aDataSize)
{
if (!mRecord) {
CDM_LOG("WidevineFileIO::Write() '%s' used uninitialized!", mName.c_str());
mClient->OnWriteComplete(FileIOClient::kError);
return;
}
mRecord->Write(aData, aDataSize);
}
void
WidevineFileIO::Close()
{
CDM_LOG("WidevineFileIO::Close() '%s'", mName.c_str());
if (mRecord) {
mRecord->Close();
mRecord = nullptr;
}
delete this;
}
static FileIOClient::Status
GMPToWidevineFileStatus(GMPErr aStatus)
{
switch (aStatus) {
case GMPRecordInUse: return FileIOClient::kInUse;
case GMPNoErr: return FileIOClient::kSuccess;
default: return FileIOClient::kError;
}
}
void
WidevineFileIO::OpenComplete(GMPErr aStatus)
{
CDM_LOG("WidevineFileIO::OpenComplete() '%s' status=%d", mName.c_str(), aStatus);
mClient->OnOpenComplete(GMPToWidevineFileStatus(aStatus));
}
void
WidevineFileIO::ReadComplete(GMPErr aStatus,
const uint8_t* aData,
uint32_t aDataSize)
{
CDM_LOG("WidevineFileIO::OnReadComplete() '%s' status=%d", mName.c_str(), aStatus);
mClient->OnReadComplete(GMPToWidevineFileStatus(aStatus), aData, aDataSize);
}
void
WidevineFileIO::WriteComplete(GMPErr aStatus)
{
CDM_LOG("WidevineFileIO::WriteComplete() '%s' status=%d", mName.c_str(), aStatus);
mClient->OnWriteComplete(GMPToWidevineFileStatus(aStatus));
}
} // namespace mozilla