summaryrefslogtreecommitdiff
path: root/libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp')
-rw-r--r--libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp604
1 files changed, 302 insertions, 302 deletions
diff --git a/libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp b/libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp
index 1a00f96251..b823147604 100644
--- a/libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp
+++ b/libs/appleutility/CoreAudio/AudioFile/AFPublic/AudioFileObject.cpp
@@ -2,14 +2,14 @@
File: AudioFileObject.cpp
Abstract: AudioFileObject.h
Version: 1.1
-
+
Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple
Inc. ("Apple") in consideration of your agreement to the following
terms, and your use, installation, modification or redistribution of
this Apple software constitutes acceptance of these terms. If you do
not agree with these terms, please do not use, install, modify or
redistribute this Apple software.
-
+
In consideration of your agreement to abide by the following terms, and
subject to these terms, Apple grants you a personal, non-exclusive
license, under Apple's copyrights in this original Apple software (the
@@ -25,13 +25,13 @@
implied, are granted by Apple herein, including but not limited to any
patent rights that may be infringed by your derivative works or by other
works in which the Apple Software may be incorporated.
-
+
The Apple Software is provided by Apple on an "AS IS" basis. APPLE
MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION
THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS
FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND
OPERATION ALONE OR IN COMBINATION WITH YOUR PRODUCTS.
-
+
IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL
OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
@@ -40,9 +40,9 @@
AND WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE),
STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
-
+
Copyright (C) 2014 Apple Inc. All Rights Reserved.
-
+
*/
#include "AudioFileObject.h"
#include "CADebugMacros.h"
@@ -64,7 +64,7 @@ AudioFileObject::~AudioFileObject()
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::DoCreate(
+OSStatus AudioFileObject::DoCreate(
CFURLRef inFileRef,
const AudioStreamBasicDescription *inFormat,
UInt32 inFlags)
@@ -73,27 +73,27 @@ OSStatus AudioFileObject::DoCreate(
if (!IsDataFormatValid(inFormat))
return kAudioFileUnsupportedDataFormatError;
- if (!IsDataFormatSupported(inFormat))
+ if (!IsDataFormatSupported(inFormat))
return kAudioFileUnsupportedDataFormatError;
SetPermissions(kAudioFileReadWritePermission);
-
+
SetAlignDataWithFillerChunks(!(inFlags & 2 /* kAudioFileFlags_DontPageAlignAudioData */ ));
-
+
// call virtual method for particular format.
return Create(inFileRef, inFormat);
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-OSStatus AudioFileObject::Create(
+
+OSStatus AudioFileObject::Create(
CFURLRef inFileRef,
const AudioStreamBasicDescription *inFormat)
{
int fileD;
OSStatus err = CreateDataFile (inFileRef, fileD);
FailIf (err != noErr, Bail, "CreateDataFile failed");
-
+
SetURL (inFileRef);
err = OpenFile(kAudioFileReadWritePermission, fileD);
@@ -101,23 +101,23 @@ OSStatus AudioFileObject::Create(
err = SetDataFormat(inFormat);
FailIf (err != noErr, Bail, "SetDataFormat failed");
-
+
mIsInitialized = false;
-
+
Bail:
return err;
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::DoOpen(
- CFURLRef inFileRef,
+OSStatus AudioFileObject::DoOpen(
+ CFURLRef inFileRef,
SInt8 inPermissions,
int inFD)
-{
+{
OSStatus err = noErr;
SetPermissions(inPermissions);
-
+
err = Open(inFileRef, inPermissions, inFD);
FailIf (err != noErr, Bail, "Open failed");
@@ -130,22 +130,22 @@ Bail:
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::Open(
- CFURLRef inFileRef,
+OSStatus AudioFileObject::Open(
+ CFURLRef inFileRef,
SInt8 inPermissions,
int inFD)
-{
+{
if (!(inPermissions & kAudioFileReadPermission))
return kAudioFilePermissionsError; // file must have read permissions
-
+
SetURL(inFileRef);
-
+
OSStatus err = OpenFile(inPermissions, inFD);
FailIf (err != noErr, Bail, "OpenFile failed");
-
+
err = OpenFromDataSource();
FailIf (err != noErr, Bail, "OpenFromDataSource failed");
-
+
Bail:
return err;
}
@@ -154,17 +154,17 @@ Bail:
OSStatus AudioFileObject::ValidateFormatAndData()
{
-
+
AudioStreamBasicDescription asbd = GetDataFormat();
if (!IsDataFormatValid(&asbd))
return kAudioFileInvalidFileError;
- if (asbd.mFormatID == kAudioFormatLinearPCM)
+ if (asbd.mFormatID == kAudioFormatLinearPCM)
{
SInt64 maxPackets = GetNumBytes() / asbd.mBytesPerPacket;
- if (GetNumPackets() > maxPackets)
+ if (GetNumPackets() > maxPackets)
return kAudioFileInvalidFileError;
}
return noErr;
@@ -173,24 +173,24 @@ OSStatus AudioFileObject::ValidateFormatAndData()
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
OSStatus AudioFileObject::DoOpenWithCallbacks(
- void * inRefCon,
- AudioFile_ReadProc inReadFunc,
- AudioFile_WriteProc inWriteFunc,
+ void * inRefCon,
+ AudioFile_ReadProc inReadFunc,
+ AudioFile_WriteProc inWriteFunc,
AudioFile_GetSizeProc inGetSizeFunc,
AudioFile_SetSizeProc inSetSizeFunc)
{
SInt8 perms = (inSetSizeFunc || inWriteFunc) ? kAudioFileReadWritePermission : kAudioFileReadPermission;
SetPermissions(perms);
-
+
DataSource* dataSource = new Seekable_DataSource(inRefCon, inReadFunc, inWriteFunc, inGetSizeFunc, inSetSizeFunc);
SetDataSource(dataSource);
return OpenFromDataSource();
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
+
OSStatus AudioFileObject::OpenFromDataSource(void)
-{
+{
return noErr;
}
@@ -198,15 +198,15 @@ OSStatus AudioFileObject::OpenFromDataSource(void)
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
OSStatus AudioFileObject::DoInitializeWithCallbacks(
- void * inRefCon,
- AudioFile_ReadProc inReadFunc,
- AudioFile_WriteProc inWriteFunc,
+ void * inRefCon,
+ AudioFile_ReadProc inReadFunc,
+ AudioFile_WriteProc inWriteFunc,
AudioFile_GetSizeProc inGetSizeFunc,
AudioFile_SetSizeProc inSetSizeFunc,
UInt32 inFileType,
const AudioStreamBasicDescription *inFormat,
UInt32 inFlags)
-{
+{
DataSource* dataSource = new Seekable_DataSource(inRefCon, inReadFunc, inWriteFunc, inGetSizeFunc, inSetSizeFunc);
if (!dataSource->CanWrite()) return -54/*permErr*/;
dataSource->SetSize(0);
@@ -217,13 +217,13 @@ OSStatus AudioFileObject::DoInitializeWithCallbacks(
OSStatus err = SetDataFormat(inFormat);
if (err) return err;
-
+
return InitializeDataSource(inFormat, inFlags);
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-OSStatus AudioFileObject::DoInitialize(
+
+OSStatus AudioFileObject::DoInitialize(
CFURLRef inFileRef,
const AudioStreamBasicDescription *inFormat,
UInt32 inFlags)
@@ -236,15 +236,15 @@ OSStatus AudioFileObject::DoInitialize(
return Initialize(inFileRef, inFormat, inFlags);
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
-OSStatus AudioFileObject::Initialize(
+
+OSStatus AudioFileObject::Initialize(
CFURLRef inFileRef,
const AudioStreamBasicDescription *inFormat,
UInt32 inFlags)
{
OSStatus err = noErr;
-
- UInt8 fPath[FILENAME_MAX];
+
+ UInt8 fPath[FILENAME_MAX];
if (!CFURLGetFileSystemRepresentation (inFileRef, true, fPath, FILENAME_MAX))
return kAudio_FileNotFoundError;
@@ -259,10 +259,10 @@ OSStatus AudioFileObject::Initialize(
int fileD = open((const char*)fPath, flags, filePerms);
if (fileD < 0)
return AudioFileTranslateErrno(errno);
-
+
err = OpenFile(kAudioFileReadWritePermission, fileD);
FailIf (err != noErr, Bail, "OpenFile failed");
-
+
// don't need to do this as open has an option to truncate the file
// GetDataSource()->SetSize(0);
@@ -270,15 +270,15 @@ OSStatus AudioFileObject::Initialize(
FailIf (err != noErr, Bail, "SetDataFormat failed");
InitializeDataSource(inFormat, inFlags);
-
-Bail:
+
+Bail:
return err;
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
+
OSStatus AudioFileObject::InitializeDataSource(const AudioStreamBasicDescription *inFormat, UInt32 /*inFlags*/)
-{
+{
return noErr;
}
@@ -288,7 +288,7 @@ OSStatus AudioFileObject::DoClose()
{
OSStatus err = UpdateSizeIfNeeded();
if (err) return err;
-
+
return Close();
}
@@ -313,7 +313,7 @@ OSStatus AudioFileObject::Close()
OSStatus AudioFileObject::Optimize()
{
// default is that nothing needs to be done. This happens to be true for Raw, SD2 and NeXT/Sun types.
- SetIsOptimized(true);
+ SetIsOptimized(true);
return noErr;
}
@@ -326,7 +326,7 @@ OSStatus AudioFileObject::DoOptimize()
OSStatus err = UpdateSizeIfNeeded();
if (err) return err;
-
+
if (IsOptimized()) return noErr;
err = Optimize();
@@ -335,12 +335,12 @@ OSStatus AudioFileObject::DoOptimize()
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::UpdateNumBytes(SInt64 inNumBytes)
+OSStatus AudioFileObject::UpdateNumBytes(SInt64 inNumBytes)
{
OSStatus err = noErr;
if (inNumBytes != GetNumBytes()) {
SetNumBytes(inNumBytes);
-
+
// #warning " this will not work for vbr formats"
SetNumPackets(GetNumBytes() / mDataFormat.mBytesPerPacket);
SizeChanged();
@@ -350,7 +350,7 @@ OSStatus AudioFileObject::UpdateNumBytes(SInt64 inNumBytes)
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::UpdateNumPackets(SInt64 inNumPackets)
+OSStatus AudioFileObject::UpdateNumPackets(SInt64 inNumPackets)
{
OSStatus err = noErr;
if (inNumPackets != GetNumPackets()) {
@@ -358,7 +358,7 @@ OSStatus AudioFileObject::UpdateNumPackets(SInt64 inNumPackets)
SetNeedsSizeUpdate(true);
UpdateSizeIfNeeded();
SetNumPackets(inNumPackets);
-
+
// #warning " this will not work for vbr formats"
SetNumBytes(GetNumPackets() * mDataFormat.mBytesPerFrame);
SizeChanged();
@@ -375,19 +375,19 @@ OSStatus AudioFileObject::PacketToFrame(SInt64 inPacket, SInt64& outFirstFrameIn
{
OSStatus err = ScanForPackets(inPacket+1); // the packet count must be one greater than the packet index
if (err) return err;
-
+
SInt64 packetTableSize = GetPacketTableSize();
-
+
if (mPacketTable && inPacket >= packetTableSize)
return kAudioFileEndOfFileError;
-
+
CompressedPacketTable* packetTable = GetPacketTable();
if (!packetTable)
return kAudioFileInvalidPacketOffsetError;
-
+
if (inPacket < 0 || inPacket >= packetTableSize)
return kAudioFileInvalidPacketOffsetError;
-
+
outFirstFrameInPacket = (*packetTable)[(size_t)inPacket].mFrameOffset;
}
else
@@ -406,18 +406,18 @@ OSStatus AudioFileObject::FrameToPacket(SInt64 inFrame, SInt64& outPacket, UInt3
CompressedPacketTable* packetTable = GetPacketTable();
if (!packetTable)
return kAudioFileInvalidPacketOffsetError;
-
+
// search packet table
AudioStreamPacketDescriptionExtended pext;
memset(&pext, 0, sizeof(pext));
pext.mFrameOffset = inFrame;
CompressedPacketTable::iterator iter = std::lower_bound(packetTable->begin(), packetTable->end(), pext);
-
+
if (iter == packetTable->end())
return kAudioFileInvalidPacketOffsetError;
-
+
if (iter > packetTable->begin()) --iter;
-
+
outPacket = iter - packetTable->begin();
outFrameOffsetInPacket = (UInt32)(inFrame - iter->mFrameOffset);
}
@@ -435,21 +435,21 @@ OSStatus AudioFileObject::PacketToByte(AudioBytePacketTranslation* abpt)
{
if (abpt->mPacket < 0)
return kAudioFileInvalidPacketOffsetError;
-
+
if (mDataFormat.mBytesPerPacket == 0)
{
CompressedPacketTable* packetTable = GetPacketTable();
if (!packetTable)
return kAudioFileInvalidPacketOffsetError;
-
+
if (abpt->mPacket < GetPacketTableSize()) {
abpt->mByte = (*packetTable)[(int)abpt->mPacket].mStartOffset;
abpt->mFlags = 0;
} else {
SInt64 numPackets = packetTable->size();
- if (numPackets < 8)
+ if (numPackets < 8)
return 'more' /*kAudioFileStreamError_DataUnavailable*/ ;
-
+
const AudioStreamPacketDescriptionExtended lastPacket = (*packetTable)[numPackets - 1];
SInt64 bytesReadSoFar = lastPacket.mStartOffset + lastPacket.mDataByteSize;
double averageBytesPerPacket = (double)(bytesReadSoFar - GetDataOffset()) / (double)numPackets;
@@ -487,21 +487,21 @@ OSStatus AudioFileObject::ByteToPacket(AudioBytePacketTranslation* abpt)
memset(&pext, 0, sizeof(pext));
pext.mStartOffset = abpt->mByte;
CompressedPacketTable::iterator iter = std::lower_bound(packetTable->begin(), packetTable->end(), pext, byte_less_than);
-
+
if (iter == packetTable->end()) {
SInt64 numPackets = packetTable->size();
- if (numPackets < 8)
+ if (numPackets < 8)
return 'more' /*kAudioFileStreamError_DataUnavailable*/ ;
-
+
const AudioStreamPacketDescriptionExtended lastPacket = (*packetTable)[numPackets - 1];
SInt64 bytesReadSoFar = lastPacket.mStartOffset + lastPacket.mDataByteSize;
double averageBytesPerPacket = (double)(bytesReadSoFar - GetDataOffset()) / (double)numPackets;
-
+
double fpacket = (double)abpt->mByte / averageBytesPerPacket;
abpt->mPacket = (SInt64)floor(fpacket);
abpt->mByteOffsetInPacket = (UInt32)floor((fpacket - (double)abpt->mPacket) * averageBytesPerPacket);
abpt->mFlags = kBytePacketTranslationFlag_IsEstimate;
-
+
} else {
if (iter > packetTable->begin()) --iter;
abpt->mPacket = iter - packetTable->begin();
@@ -523,29 +523,29 @@ OSStatus AudioFileObject::ByteToPacket(AudioBytePacketTranslation* abpt)
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::ReadBytes(
+OSStatus AudioFileObject::ReadBytes(
Boolean inUseCache,
- SInt64 inStartingByte,
- UInt32 *ioNumBytes,
+ SInt64 inStartingByte,
+ UInt32 *ioNumBytes,
void *outBuffer)
{
OSStatus err = noErr;
UInt16 mode = SEEK_SET;
SInt64 fileOffset = mDataOffset + inStartingByte;
bool readingPastEnd = false;
-
- FailWithAction((ioNumBytes == NULL) || (outBuffer == NULL), err = kAudio_ParamError,
+
+ FailWithAction((ioNumBytes == NULL) || (outBuffer == NULL), err = kAudio_ParamError,
Bail, "invalid num bytes parameter");
//printf("inStartingByte %lld GetNumBytes %lld\n", inStartingByte, GetNumBytes());
- if (inStartingByte >= GetNumBytes())
+ if (inStartingByte >= GetNumBytes())
{
*ioNumBytes = 0;
return kAudioFileEndOfFileError;
}
- if ((fileOffset + *ioNumBytes) > (GetNumBytes() + mDataOffset))
+ if ((fileOffset + *ioNumBytes) > (GetNumBytes() + mDataOffset))
{
*ioNumBytes = (UInt32)(GetNumBytes() + mDataOffset - fileOffset);
readingPastEnd = true;
@@ -554,9 +554,9 @@ OSStatus AudioFileObject::ReadBytes(
if (!inUseCache)
mode |= kAudioFileNoCacheMask;
-
+
err = GetDataSource()->ReadBytes(mode, fileOffset, *ioNumBytes, outBuffer, ioNumBytes);
-
+
if (readingPastEnd && err == noErr)
err = kAudioFileEndOfFileError;
@@ -567,10 +567,10 @@ Bail:
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::WriteBytes(
+OSStatus AudioFileObject::WriteBytes(
Boolean inUseCache,
- SInt64 inStartingByte,
- UInt32 *ioNumBytes,
+ SInt64 inStartingByte,
+ UInt32 *ioNumBytes,
const void *inBuffer)
{
OSStatus err = noErr;
@@ -586,57 +586,57 @@ OSStatus AudioFileObject::WriteBytes(
// if so, see if file type supports this and bail if not
err = IsValidFilePosition(inStartingByte + *ioNumBytes);
FailIf(err != noErr, Bail, "invalid file position");
-
+
extendingTheAudioData = inStartingByte + *ioNumBytes > GetNumBytes();
-
+
// if file is not optimized, then do not write data that would overwrite chunks following the sound data chunk
- FailWithAction( extendingTheAudioData && !IsOptimized(),
+ FailWithAction( extendingTheAudioData && !IsOptimized(),
err = kAudioFileNotOptimizedError, Bail, "Can't write more data until the file is optimized");
if (!inUseCache)
mode |= kAudioFileNoCacheMask;
-
- err = GetDataSource()->WriteBytes(mode, mDataOffset + inStartingByte, *ioNumBytes,
+
+ err = GetDataSource()->WriteBytes(mode, mDataOffset + inStartingByte, *ioNumBytes,
inBuffer, ioNumBytes);
-
+
FailIf(err != noErr, Bail, "couldn't write new data");
-
+
if (extendingTheAudioData) {
SInt64 nuEOF; // Get the total bytes of audio data
SInt64 nuByteTotal;
err = GetDataSource()->GetSize(nuEOF);
FailIf(err != noErr, Bail, "GetSize failed");
-
+
nuByteTotal = nuEOF - mDataOffset;
err = UpdateNumBytes(nuByteTotal);
}
-
+
Bail:
return err;
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::ReadPackets(
+OSStatus AudioFileObject::ReadPackets(
Boolean inUseCache,
UInt32 *outNumBytes,
AudioStreamPacketDescription *outPacketDescriptions,
- SInt64 inStartingPacket,
- UInt32 *ioNumPackets,
+ SInt64 inStartingPacket,
+ UInt32 *ioNumPackets,
void *outBuffer)
{
// This only works with CBR. To suppport VBR you must override.
OSStatus err = noErr;
-
+
FailWithAction(outBuffer == NULL, err = kAudio_ParamError, Bail, "NULL buffer");
-
+
FailWithAction((ioNumPackets == NULL) || (*ioNumPackets < 1), err = kAudio_ParamError, Bail, "invalid num packets parameter");
-
+
{
UInt32 byteCount = *ioNumPackets * mDataFormat.mBytesPerPacket;
SInt64 startingByte = inStartingPacket * mDataFormat.mBytesPerPacket;
-
+
err = ReadBytes (inUseCache, startingByte, &byteCount, outBuffer);
if ((err == noErr) || (err == kAudioFileEndOfFileError))
{
@@ -648,7 +648,7 @@ OSStatus AudioFileObject::ReadPackets(
if (outNumBytes)
*outNumBytes = byteCount;
-
+
if (err == kAudioFileEndOfFileError)
err = noErr;
}
@@ -664,12 +664,12 @@ Bail:
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::ReadPacketData(
+OSStatus AudioFileObject::ReadPacketData(
Boolean inUseCache,
UInt32 *ioNumBytes,
AudioStreamPacketDescription *outPacketDescriptions,
- SInt64 inStartingPacket,
- UInt32 *ioNumPackets,
+ SInt64 inStartingPacket,
+ UInt32 *ioNumPackets,
void *outBuffer)
{
OSStatus err = noErr;
@@ -703,12 +703,12 @@ Bail:
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::ReadPacketDataVBR(
+OSStatus AudioFileObject::ReadPacketDataVBR(
Boolean inUseCache,
UInt32 *ioNumBytes,
AudioStreamPacketDescription *outPacketDescriptions,
- SInt64 inStartingPacket,
- UInt32 *ioNumPackets,
+ SInt64 inStartingPacket,
+ UInt32 *ioNumPackets,
void *outBuffer)
{
OSStatus err = ScanForPackets(inStartingPacket+1); // need to scan packets up to start
@@ -718,7 +718,7 @@ OSStatus AudioFileObject::ReadPacketDataVBR(
SInt64 dataOffset = GetDataOffset();
CompressedPacketTable* packetTable = GetPacketTable();
- if (!packetTable)
+ if (!packetTable)
return kAudioFileInvalidFileError;
SInt64 packetTableSize = GetPacketTableSize();
@@ -728,7 +728,7 @@ OSStatus AudioFileObject::ReadPacketDataVBR(
*ioNumPackets = 0;
return kAudioFileEndOfFileError;
}
-
+
if (inStartingPacket + *ioNumPackets <= packetTableSize) {
err = ReadPacketDataVBR_InTable(inUseCache, ioNumBytes, outPacketDescriptions, inStartingPacket, ioNumPackets, outBuffer);
} else {
@@ -741,21 +741,21 @@ OSStatus AudioFileObject::ReadPacketDataVBR(
SInt64 remainingBytesInFile = fileSize - firstPacketOffset - dataOffset;
if (bytesRead > remainingBytesInFile)
bytesRead = (UInt32)remainingBytesInFile;
-
+
err = ReadBytes (inUseCache, firstPacketOffset, &bytesRead, outBuffer);
if (err && err != kAudioFileEndOfFileError) {
*ioNumBytes = 0;
*ioNumPackets = 0;
return err;
}
-
+
Buffer_DataSource bufSrc(bytesRead, outBuffer, dataOffset + firstPacketOffset);
-
+
OSStatus scanErr = ScanForPackets(kScanToEnd, &bufSrc, false);
if (scanErr && scanErr != kAudioFileEndOfFileError)
return scanErr;
packetTableSize = packetTable->size();
-
+
UInt32 numPacketsRead = 0;
UInt32 endOfData = 0;
SInt64 packetNumber = inStartingPacket;
@@ -765,10 +765,10 @@ OSStatus AudioFileObject::ReadPacketDataVBR(
SInt64 endOfPacket = curPacketOffset + curPacket.mDataByteSize;
if (endOfPacket > bytesRead) break;
endOfData = (UInt32)endOfPacket;
- outPacketDescriptions[numPacketsRead] = curPacket;
+ outPacketDescriptions[numPacketsRead] = curPacket;
outPacketDescriptions[numPacketsRead].mStartOffset = curPacketOffset;
}
-
+
*ioNumBytes = endOfData;
*ioNumPackets = numPacketsRead;
}
@@ -778,14 +778,14 @@ OSStatus AudioFileObject::ReadPacketDataVBR(
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
OSStatus AudioFileObject::HowManyPacketsCanBeReadIntoBuffer(UInt32* ioNumBytes, SInt64 inStartingPacket, UInt32 *ioNumPackets)
-{
+{
CompressedPacketTable* packetTable = GetPacketTable();
SInt64 packetTableSize = GetPacketTableSize();
if (inStartingPacket + *ioNumPackets > (SInt64)packetTableSize) {
*ioNumPackets = (UInt32)(packetTableSize - inStartingPacket);
}
-
+
AudioStreamPacketDescription firstPacket = (*packetTable)[inStartingPacket];
if (*ioNumBytes < firstPacket.mDataByteSize) {
@@ -795,28 +795,28 @@ OSStatus AudioFileObject::HowManyPacketsCanBeReadIntoBuffer(UInt32* ioNumBytes,
}
SInt64 lastPacketIndex = inStartingPacket + *ioNumPackets - 1;
- if (lastPacketIndex >= packetTableSize)
+ if (lastPacketIndex >= packetTableSize)
lastPacketIndex = packetTableSize - 1;
-
+
AudioStreamPacketDescription lastPacket = (*packetTable)[lastPacketIndex];
-
+
SInt64 readBytes = lastPacket.mStartOffset + lastPacket.mDataByteSize - firstPacket.mStartOffset;
if (readBytes <= *ioNumBytes) {
*ioNumBytes = (UInt32)readBytes;
return noErr;
}
-
+
SInt64 lowBound = inStartingPacket;
SInt64 highBound = lastPacketIndex + 1;
SInt64 okIndex = lowBound;
- while (highBound >= lowBound) {
+ while (highBound >= lowBound) {
SInt64 tryBound = (lowBound + highBound) >> 1;
- if (tryBound > lastPacketIndex)
+ if (tryBound > lastPacketIndex)
break;
AudioStreamPacketDescription tryPacket = (*packetTable)[tryBound];
-
+
SInt64 readBytes = tryPacket.mStartOffset + tryPacket.mDataByteSize - firstPacket.mStartOffset;
-
+
if (readBytes > (SInt64)*ioNumBytes) {
highBound = tryBound - 1;
} else if (readBytes < (SInt64)*ioNumBytes) {
@@ -826,14 +826,14 @@ OSStatus AudioFileObject::HowManyPacketsCanBeReadIntoBuffer(UInt32* ioNumBytes,
okIndex = tryBound;
break;
}
- }
-
+ }
+
SInt64 numPackets = okIndex - inStartingPacket + 1;
if (numPackets > *ioNumPackets) {
numPackets = *ioNumPackets;
okIndex = inStartingPacket + numPackets - 1;
}
-
+
AudioStreamPacketDescription packet = (*packetTable)[okIndex];
*ioNumBytes = (UInt32)(packet.mStartOffset + packet.mDataByteSize - firstPacket.mStartOffset);
*ioNumPackets = (UInt32)numPackets;
@@ -846,25 +846,25 @@ OSStatus AudioFileObject::HowManyPacketsCanBeReadIntoBuffer(UInt32* ioNumBytes,
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::ReadPacketDataVBR_InTable(
+OSStatus AudioFileObject::ReadPacketDataVBR_InTable(
Boolean inUseCache,
UInt32 *ioNumBytes,
AudioStreamPacketDescription *outPacketDescriptions,
- SInt64 inStartingPacket,
- UInt32 *ioNumPackets,
+ SInt64 inStartingPacket,
+ UInt32 *ioNumPackets,
void *outBuffer)
{
CompressedPacketTable* packetTable = GetPacketTable();
- if (!packetTable)
+ if (!packetTable)
return kAudioFileInvalidFileError;
-
+
OSStatus err = HowManyPacketsCanBeReadIntoBuffer(ioNumBytes, inStartingPacket, ioNumPackets);
if (err) return err;
-
+
AudioStreamPacketDescription firstPacket = (*packetTable)[inStartingPacket];
SInt64 firstPacketOffset = firstPacket.mStartOffset;
UInt32 bytesRead = *ioNumBytes;
-
+
if (outBuffer) {
err = ReadBytes (inUseCache, firstPacketOffset, &bytesRead, outBuffer);
if (err && err != kAudioFileEndOfFileError) {
@@ -874,12 +874,12 @@ OSStatus AudioFileObject::ReadPacketDataVBR_InTable(
}
*ioNumBytes = bytesRead;
}
-
+
// fill out packet descriptions
- if (outPacketDescriptions) {
+ if (outPacketDescriptions) {
for (UInt32 i = 0; i < *ioNumPackets; i++) {
AudioStreamPacketDescription curPacket = (*packetTable)[i + inStartingPacket];
- outPacketDescriptions[i] = curPacket;
+ outPacketDescriptions[i] = curPacket;
outPacketDescriptions[i].mStartOffset = curPacket.mStartOffset - firstPacketOffset;
}
}
@@ -890,20 +890,20 @@ OSStatus AudioFileObject::ReadPacketDataVBR_InTable(
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::WritePackets(
+OSStatus AudioFileObject::WritePackets(
Boolean inUseCache,
UInt32 inNumBytes,
const AudioStreamPacketDescription *inPacketDescriptions,
- SInt64 inStartingPacket,
- UInt32 *ioNumPackets,
+ SInt64 inStartingPacket,
+ UInt32 *ioNumPackets,
const void *inBuffer)
{
// This only works with CBR. To suppport VBR you must override.
OSStatus err = noErr;
-
+
FailWithAction(inStartingPacket > GetNumPackets(), err = kAudioFileInvalidPacketOffsetError, Bail, "write past end");
FailWithAction((ioNumPackets == NULL) || (inBuffer == NULL), err = kAudioFileUnspecifiedError, Bail, "invalid parameter");
-
+
{
UInt32 byteCount = *ioNumPackets * mDataFormat.mBytesPerPacket;
SInt64 startingByte = inStartingPacket * mDataFormat.mBytesPerPacket;
@@ -922,21 +922,21 @@ Bail:
OSStatus AudioFileObject::GetBitRate( UInt32 *outBitRate)
{
-
+
if (!outBitRate) return kAudioFileUnspecifiedError;
-
+
UInt32 bytesPerPacket = GetDataFormat().mBytesPerPacket;
UInt32 framesPerPacket = GetDataFormat().mFramesPerPacket;
Float64 sampleRate = GetDataFormat().mSampleRate;
const Float64 bitsPerByte = 8.;
-
+
if (bytesPerPacket && framesPerPacket) {
*outBitRate = (UInt32)(bitsPerByte * (Float64)bytesPerPacket * sampleRate / (Float64)framesPerPacket);
- } else {
+ } else {
SInt64 numPackets = GetNumPackets();
SInt64 numBytes = GetNumBytes();
SInt64 numFrames = 0;
-
+
if (framesPerPacket) {
numFrames = numPackets * framesPerPacket;
} else {
@@ -953,12 +953,12 @@ OSStatus AudioFileObject::GetBitRate( UInt32 *outBitRate)
#endif
{
numFrames += (*packetTable)[i].mVariableFramesInPacket;
- }
+ }
} else {
return kAudioFileUnsupportedPropertyError;
}
}
-
+
if (numFrames == 0 || (sampleRate == 0.)) {
*outBitRate = 0;
return noErr;
@@ -1098,18 +1098,18 @@ OSStatus AudioFileObject::GetInfoDictionarySize( UInt32 *outDataSize,
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
+
OSStatus AudioFileObject::GetInfoDictionary(CACFDictionary *infoDict)
-{
+{
Float64 fl;
if (GetEstimatedDuration(&fl) == noErr)
return AddDurationToInfoDictionary(infoDict, fl);
-
+
return kAudioFileUnsupportedPropertyError;
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
+
OSStatus AudioFileObject::SetInfoDictionary(CACFDictionary *infoDict)
{
return kAudioFileUnsupportedPropertyError;
@@ -1120,31 +1120,31 @@ OSStatus AudioFileObject::GetEstimatedDuration(Float64* duration)
{
// calculate duration
AudioStreamBasicDescription ASBD = GetDataFormat();
-
+
*duration = (ASBD.mFramesPerPacket != 0) ? (GetNumPackets() * ASBD.mFramesPerPacket) / ASBD.mSampleRate : 0.0;
-
+
/*
For now, assume that any ASBD that has zero in the frames per packet field has been subclassed for this
method. i.e. A CAF file has a frame count in one of it's chunks.
-
- MP3 has been subclassed because it guesstimates a duration so the entire file does not
+
+ MP3 has been subclassed because it guesstimates a duration so the entire file does not
need to be parsed in order to calculate the total frames.
*/
-
+
return noErr;
}
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-OSStatus AudioFileObject::GetPropertyInfo (
+OSStatus AudioFileObject::GetPropertyInfo (
AudioFilePropertyID inPropertyID,
UInt32 *outDataSize,
UInt32 *isWritable)
{
OSStatus err = noErr;
UInt32 writable = 0;
-
+
switch (inPropertyID)
{
case kAudioFilePropertyDeferSizeUpdates :
@@ -1161,11 +1161,11 @@ OSStatus AudioFileObject::GetPropertyInfo (
if (outDataSize) *outDataSize = sizeof(AudioStreamBasicDescription);
writable = 1;
break;
-
+
case kAudioFilePropertyFormatList:
err = GetFormatListInfo(*outDataSize, writable);
break;
-
+
case kAudioFilePropertyPacketSizeUpperBound:
case kAudioFilePropertyIsOptimized:
case kAudioFilePropertyMaximumPacketSize:
@@ -1184,25 +1184,25 @@ OSStatus AudioFileObject::GetPropertyInfo (
if (outDataSize) *outDataSize = sizeof(SInt64);
break;
- case kAudioFilePropertyBitRate:
+ case kAudioFilePropertyBitRate:
writable = 0;
if (outDataSize) *outDataSize = sizeof(UInt32);
break;
- case kAudioFilePropertyMagicCookieData:
+ case kAudioFilePropertyMagicCookieData:
err = GetMagicCookieDataSize(outDataSize, &writable);
break;
case kAudioFilePropertyMarkerList :
- err = GetMarkerListSize(outDataSize, &writable);
+ err = GetMarkerListSize(outDataSize, &writable);
break;
-
+
case kAudioFilePropertyRegionList :
- err = GetRegionListSize(outDataSize, &writable);
+ err = GetRegionListSize(outDataSize, &writable);
break;
-
+
case kAudioFilePropertyChannelLayout :
- err = GetChannelLayoutSize(outDataSize, &writable);
+ err = GetChannelLayoutSize(outDataSize, &writable);
break;
case kAudioFilePropertyPacketToFrame :
@@ -1218,11 +1218,11 @@ OSStatus AudioFileObject::GetPropertyInfo (
break;
case kAudioFilePropertyInfoDictionary :
- err = GetInfoDictionarySize(outDataSize, &writable);
+ err = GetInfoDictionarySize(outDataSize, &writable);
break;
case kTEMPAudioFilePropertySoundCheckDictionary :
- err = GetSoundCheckDictionarySize(outDataSize, &writable);
+ err = GetSoundCheckDictionarySize(outDataSize, &writable);
break;
case kTEMPAudioFilePropertyGenerateLoudnessInfo :
@@ -1253,7 +1253,7 @@ OSStatus AudioFileObject::GetPropertyInfo (
if (outDataSize) *outDataSize = sizeof(SInt32);
if (isWritable) *isWritable = CanWrite();
break;
-
+
default:
writable = 0;
err = kAudioFileUnsupportedPropertyError;
@@ -1275,109 +1275,109 @@ OSStatus AudioFileObject::GetProperty(
OSStatus err = noErr;
UInt32 neededSize;
UInt32 writable;
-
+
switch (inPropertyID)
{
case kAudioFilePropertyFileFormat:
- FailWithAction(*ioDataSize != sizeof(UInt32),
+ FailWithAction(*ioDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
+
*(UInt32 *) ioPropertyData = GetFileType();
break;
case kAudioFilePropertyFormatList:
err = GetFormatList(*ioDataSize, (AudioFormatListItem*)ioPropertyData);
break;
-
+
case kAudioFilePropertyDataFormat:
- FailWithAction(*ioDataSize != sizeof(AudioStreamBasicDescription),
+ FailWithAction(*ioDataSize != sizeof(AudioStreamBasicDescription),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
+
memcpy(ioPropertyData, &mDataFormat, sizeof(AudioStreamBasicDescription));
break;
case kAudioFilePropertyDataOffset:
- FailWithAction(*ioDataSize != sizeof(SInt64),
+ FailWithAction(*ioDataSize != sizeof(SInt64),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
*(SInt64 *) ioPropertyData = mDataOffset;
break;
case kAudioFilePropertyIsOptimized:
- FailWithAction(*ioDataSize != sizeof(UInt32),
+ FailWithAction(*ioDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
*(UInt32 *) ioPropertyData = mIsOptimized;
break;
case kAudioFilePropertyAudioDataByteCount:
- FailWithAction(*ioDataSize != sizeof(SInt64),
+ FailWithAction(*ioDataSize != sizeof(SInt64),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
*(SInt64 *)ioPropertyData = GetNumBytes();
break;
case kAudioFilePropertyAudioDataPacketCount:
- FailWithAction(*ioDataSize != sizeof(SInt64),
+ FailWithAction(*ioDataSize != sizeof(SInt64),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
*(SInt64 *)ioPropertyData = GetNumPackets();
break;
case kAudioFilePropertyPacketSizeUpperBound:
- FailWithAction(*ioDataSize != sizeof(UInt32),
+ FailWithAction(*ioDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
*(UInt32 *)ioPropertyData = GetPacketSizeUpperBound();
break;
-
+
case kAudioFilePropertyMaximumPacketSize:
- FailWithAction(*ioDataSize != sizeof(UInt32),
+ FailWithAction(*ioDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
*(UInt32 *)ioPropertyData = FindMaximumPacketSize();
break;
- case kAudioFilePropertyBitRate:
- FailWithAction(*ioDataSize != sizeof(UInt32),
+ case kAudioFilePropertyBitRate:
+ FailWithAction(*ioDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
err = GetBitRate((UInt32*)ioPropertyData);
break;
- case kAudioFilePropertyMagicCookieData:
-
+ case kAudioFilePropertyMagicCookieData:
+
err = GetMagicCookieData(ioDataSize, ioPropertyData);
break;
case kAudioFilePropertyMarkerList :
- err = GetMarkerList(ioDataSize, static_cast<AudioFileMarkerList*>(ioPropertyData));
+ err = GetMarkerList(ioDataSize, static_cast<AudioFileMarkerList*>(ioPropertyData));
break;
-
+
case kAudioFilePropertyRegionList :
memset(ioPropertyData, 0, *ioDataSize);
- err = GetRegionList(ioDataSize, static_cast<AudioFileRegionList*>(ioPropertyData));
+ err = GetRegionList(ioDataSize, static_cast<AudioFileRegionList*>(ioPropertyData));
break;
-
+
case kAudioFilePropertyChannelLayout :
err = GetChannelLayoutSize(&neededSize, &writable);
FailIf(err, Bail, "GetChannelLayoutSize failed");
FailWithAction(*ioDataSize != neededSize, err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
- err = GetChannelLayout(ioDataSize, static_cast<AudioChannelLayout*>(ioPropertyData));
+
+ err = GetChannelLayout(ioDataSize, static_cast<AudioChannelLayout*>(ioPropertyData));
break;
-
+
case kAudioFilePropertyDeferSizeUpdates :
- FailWithAction(*ioDataSize != sizeof(UInt32),
+ FailWithAction(*ioDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
+
*(UInt32 *) ioPropertyData = DeferSizeUpdates();
break;
- case kAudioFilePropertyPacketToFrame :
+ case kAudioFilePropertyPacketToFrame :
{
- FailWithAction(*ioDataSize != sizeof(AudioFramePacketTranslation),
+ FailWithAction(*ioDataSize != sizeof(AudioFramePacketTranslation),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
+
AudioFramePacketTranslation* afpt = (AudioFramePacketTranslation*)ioPropertyData;
err = PacketToFrame(afpt->mPacket, afpt->mFrame);
break;
- }
+ }
case kAudioFilePropertyFrameToPacket :
{
- FailWithAction(*ioDataSize != sizeof(AudioFramePacketTranslation),
+ FailWithAction(*ioDataSize != sizeof(AudioFramePacketTranslation),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
AudioFramePacketTranslation* afpt = (AudioFramePacketTranslation*)ioPropertyData;
@@ -1385,18 +1385,18 @@ OSStatus AudioFileObject::GetProperty(
break;
}
- case kAudioFilePropertyPacketToByte :
+ case kAudioFilePropertyPacketToByte :
{
- FailWithAction(*ioDataSize != sizeof(AudioBytePacketTranslation),
+ FailWithAction(*ioDataSize != sizeof(AudioBytePacketTranslation),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
+
AudioBytePacketTranslation* abpt = (AudioBytePacketTranslation*)ioPropertyData;
err = PacketToByte(abpt);
break;
- }
+ }
case kAudioFilePropertyByteToPacket :
{
- FailWithAction(*ioDataSize != sizeof(AudioBytePacketTranslation),
+ FailWithAction(*ioDataSize != sizeof(AudioBytePacketTranslation),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
AudioBytePacketTranslation* abpt = (AudioBytePacketTranslation*)ioPropertyData;
@@ -1406,13 +1406,13 @@ OSStatus AudioFileObject::GetProperty(
case kAudioFilePropertyInfoDictionary :
{
- FailWithAction(*ioDataSize != sizeof(CFDictionaryRef),
+ FailWithAction(*ioDataSize != sizeof(CFDictionaryRef),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
CACFDictionary afInfoDictionary(true);
- err = GetInfoDictionary(&afInfoDictionary);
-
+ err = GetInfoDictionary(&afInfoDictionary);
+
if (!err)
{
*(CFMutableDictionaryRef *)ioPropertyData = afInfoDictionary.CopyCFMutableDictionary();
@@ -1422,7 +1422,7 @@ OSStatus AudioFileObject::GetProperty(
case kTEMPAudioFilePropertySoundCheckDictionary :
{
- FailWithAction(*ioDataSize != sizeof(CFDictionaryRef),
+ FailWithAction(*ioDataSize != sizeof(CFDictionaryRef),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
CACFDictionary afInfoDictionary(true);
@@ -1432,7 +1432,7 @@ OSStatus AudioFileObject::GetProperty(
OSStatus err2 = GetSoundCheckDictionaryFromLoudnessInfo(&afInfoDictionary);
if (err2 == noErr) err = noErr; // else report original error from GetSoundCheckDictionary.
}
-
+
if (!err)
{
*(CFMutableDictionaryRef *)ioPropertyData = afInfoDictionary.CopyCFMutableDictionary();
@@ -1442,7 +1442,7 @@ OSStatus AudioFileObject::GetProperty(
case kTEMPAudioFilePropertyLoudnessInfo :
{
- FailWithAction(*ioDataSize != sizeof(CFDictionaryRef),
+ FailWithAction(*ioDataSize != sizeof(CFDictionaryRef),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
CACFDictionary afInfoDictionary(true);
@@ -1452,8 +1452,8 @@ OSStatus AudioFileObject::GetProperty(
OSStatus err2 = GetLoudnessInfoFromSoundCheckDictionary(&afInfoDictionary);
if (err2 == noErr) err = noErr; // else report original error from GetLoudnessInfo.
}
-
- if (!err)
+
+ if (!err)
{
*(CFMutableDictionaryRef *)ioPropertyData = afInfoDictionary.CopyCFMutableDictionary();
}
@@ -1467,8 +1467,8 @@ OSStatus AudioFileObject::GetProperty(
CACFDictionary afInfoDictionary(true);
- err = GenerateLoudnessInfo(&afInfoDictionary);
-
+ err = GenerateLoudnessInfo(&afInfoDictionary);
+
if (!err)
{
*(CFMutableDictionaryRef *)ioPropertyData = afInfoDictionary.CopyCFMutableDictionary();
@@ -1478,10 +1478,10 @@ OSStatus AudioFileObject::GetProperty(
case kAudioFilePropertyEstimatedDuration :
{
- FailWithAction(*ioDataSize != sizeof(Float64),
+ FailWithAction(*ioDataSize != sizeof(Float64),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
-
- err = GetEstimatedDuration((Float64*)ioPropertyData);
+
+ err = GetEstimatedDuration((Float64*)ioPropertyData);
break;
}
@@ -1492,21 +1492,21 @@ OSStatus AudioFileObject::GetProperty(
*ioDataSize = sizeof(CFStringRef);
err = GetLyrics((CFStringRef*) ioPropertyData);
break;
-
- case 'eof?' :
+
+ case 'eof?' :
{
if (*ioDataSize != sizeof(UInt32))
return kAudioFileBadPropertySizeError;
-
+
SInt64 pos;
err = GetDataSource()->GetPos(pos);
if (err) break;
-
+
SInt64 endOfData = GetDataOffset() + GetNumBytes();
*(UInt32*)ioPropertyData = pos >= endOfData;
-
+
break;
- }
+ }
case 'sbtd' /*kAudioFilePropertySourceBitDepth*/ :
{
if (*ioDataSize != sizeof(SInt32))
@@ -1518,17 +1518,17 @@ OSStatus AudioFileObject::GetProperty(
// if there was no stored source bit depth, and this file is LPCM, then report this file's bit depth.
err = noErr;
outValue = GetDataFormat().mBitsPerChannel;
- if (GetDataFormat().mFormatFlags & kAudioFormatFlagIsFloat)
+ if (GetDataFormat().mFormatFlags & kAudioFormatFlagIsFloat)
outValue = -outValue;
- } else if (err)
+ } else if (err)
break;
-
+
*(SInt32 *) ioPropertyData = outValue;
-
+
break;
- }
+ }
default:
- err = kAudioFileUnsupportedPropertyError;
+ err = kAudioFileUnsupportedPropertyError;
break;
}
@@ -1548,14 +1548,14 @@ OSStatus AudioFileObject::SetProperty(
switch (inPropertyID)
{
case kAudioFilePropertyDataFormat:
- FailWithAction(inDataSize != sizeof(AudioStreamBasicDescription),
+ FailWithAction(inDataSize != sizeof(AudioStreamBasicDescription),
err = kAudioFileBadPropertySizeError, Bail, "Incorrect data size");
err = UpdateDataFormat((AudioStreamBasicDescription *) inPropertyData);
break;
case kAudioFilePropertyFormatList:
err = SetFormatList(inDataSize, (AudioFormatListItem*)inPropertyData);
break;
-
+
case kAudioFilePropertyAudioDataByteCount: {
FailWithAction(inDataSize != sizeof(SInt64), err = kAudioFileBadPropertySizeError, Bail, "Incorrect data size");
SInt64 numBytes = *(SInt64 *) inPropertyData;
@@ -1577,82 +1577,82 @@ OSStatus AudioFileObject::SetProperty(
}
err = UpdateNumPackets(numPackets);
} break;
-
- case kAudioFilePropertyMagicCookieData:
+
+ case kAudioFilePropertyMagicCookieData:
err = SetMagicCookieData(inDataSize, inPropertyData);
break;
case kAudioFilePropertyMarkerList :
- err = SetMarkerList(inDataSize, static_cast<const AudioFileMarkerList*>(inPropertyData));
+ err = SetMarkerList(inDataSize, static_cast<const AudioFileMarkerList*>(inPropertyData));
break;
-
+
case kAudioFilePropertyRegionList :
- err = SetRegionList(inDataSize, static_cast<const AudioFileRegionList*>(inPropertyData));
+ err = SetRegionList(inDataSize, static_cast<const AudioFileRegionList*>(inPropertyData));
break;
-
+
case kAudioFilePropertyChannelLayout :
- err = SetChannelLayout(inDataSize, static_cast<const AudioChannelLayout*>(inPropertyData));
+ err = SetChannelLayout(inDataSize, static_cast<const AudioChannelLayout*>(inPropertyData));
break;
case kAudioFilePropertyDeferSizeUpdates :
- FailWithAction(inDataSize != sizeof(UInt32),
+ FailWithAction(inDataSize != sizeof(UInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
SetDeferSizeUpdates(*(UInt32 *) inPropertyData);
break;
case kAudioFilePropertyInfoDictionary :
{
- FailWithAction(inDataSize != sizeof(CFDictionaryRef),
+ FailWithAction(inDataSize != sizeof(CFDictionaryRef),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
// pass the SetInfoDictionary a CACFDictionary object made with the provided CFDictionaryRef
// Let the caller release their own CFObject so pass false for th erelease parameter
CACFDictionary afInfoDictionary(*(CFDictionaryRef *)inPropertyData, false);
- err = SetInfoDictionary(&afInfoDictionary);
-
+ err = SetInfoDictionary(&afInfoDictionary);
+
break;
}
-
+
case kTEMPAudioFilePropertySoundCheckDictionary :
{
- FailWithAction(inDataSize != sizeof(CFDictionaryRef),
+ FailWithAction(inDataSize != sizeof(CFDictionaryRef),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
// pass the SetInfoDictionary a CACFDictionary object made with the provided CFDictionaryRef
// Let the caller release their own CFObject so pass false for the release parameter
CACFDictionary afInfoDictionary(*(CFDictionaryRef *)inPropertyData, false);
- err = SetSoundCheckDictionary(&afInfoDictionary);
-
+ err = SetSoundCheckDictionary(&afInfoDictionary);
+
break;
}
case kTEMPAudioFilePropertyLoudnessInfo :
{
- FailWithAction(inDataSize != sizeof(CFDictionaryRef),
+ FailWithAction(inDataSize != sizeof(CFDictionaryRef),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
// pass the SetInfoDictionary a CACFDictionary object made with the provided CFDictionaryRef
// Let the caller release their own CFObject so pass false for the release parameter
CACFDictionary afInfoDictionary(*(CFDictionaryRef *)inPropertyData, false);
- err = SetLoudnessInfo(&afInfoDictionary);
-
+ err = SetLoudnessInfo(&afInfoDictionary);
+
break;
}
-
+
case 'sbtd' /*kAudioFilePropertySourceBitDepth*/ :
{
- FailWithAction(inDataSize != sizeof(SInt32),
+ FailWithAction(inDataSize != sizeof(SInt32),
err = kAudioFileBadPropertySizeError, Bail, "inDataSize is wrong");
SInt32 inValue = *(SInt32 *)inPropertyData;
err = SetSourceBitDepth(inValue);
-
+
break;
- }
+ }
default:
- err = kAudioFileUnsupportedPropertyError;
+ err = kAudioFileUnsupportedPropertyError;
break;
}
@@ -1666,17 +1666,17 @@ Bail:
OSStatus AudioFileObject::SetDataFormat(const AudioStreamBasicDescription* inStreamFormat)
{
OSStatus err = noErr;
-
+
if (!IsDataFormatValid(inStreamFormat))
return kAudioFileUnsupportedDataFormatError;
- if (!IsDataFormatSupported(inStreamFormat))
+ if (!IsDataFormatSupported(inStreamFormat))
return kAudioFileUnsupportedDataFormatError;
-
+
UInt32 prevBytesPerPacket = mDataFormat.mBytesPerPacket;
-
+
mDataFormat = *inStreamFormat;
-
+
// if CBR and bytes per packet changes, we need to change the number of packets we think we have.
if (mDataFormat.mBytesPerPacket && mDataFormat.mBytesPerPacket != prevBytesPerPacket)
{
@@ -1687,9 +1687,9 @@ OSStatus AudioFileObject::SetDataFormat(const AudioStreamBasicDescription* inStr
if (!mFirstSetFormat)
SizeChanged();
}
-
+
mFirstSetFormat = false;
-
+
return err;
}
@@ -1712,7 +1712,7 @@ OSStatus AudioFileObject::GetFormatList( UInt32 &ioDataSize,
// default implementation is to just return the data format
if (ioDataSize < sizeof(AudioFormatListItem))
return kAudioFileBadPropertySizeError;
-
+
AudioFormatListItem afli;
afli.mASBD = mDataFormat;
AudioChannelLayoutTag layoutTag = /*kAudioChannelLayoutTag_Unknown*/ 0xFFFF0000 | mDataFormat.mChannelsPerFrame;
@@ -1727,14 +1727,14 @@ OSStatus AudioFileObject::GetFormatList( UInt32 &ioDataSize,
layoutTag = layout->mChannelLayoutTag;
}
}
- afli.mChannelLayoutTag = layoutTag;
-
+ afli.mChannelLayoutTag = layoutTag;
+
memcpy(ioPropertyData, &afli, sizeof(AudioFormatListItem));
-
+
ioDataSize = sizeof(AudioFormatListItem);
return noErr;
}
-
+
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
OSStatus AudioFileObject::SetFormatList( UInt32 inDataSize,
@@ -1765,22 +1765,22 @@ Boolean AudioFileObject::IsDataFormatValid(AudioStreamBasicDescription const* in
return false;
if (inDesc->mFormatID == kAudioFormatLinearPCM)
- {
+ {
if (inDesc->mBitsPerChannel < 1 || inDesc->mBitsPerChannel > 64)
return false;
-
+
if (inDesc->mFramesPerPacket != 1)
return false;
-
- if (inDesc->mBytesPerPacket == 0)
+
+ if (inDesc->mBytesPerPacket == 0)
return false;
if (inDesc->mBytesPerFrame != inDesc->mBytesPerPacket)
return false;
-
+
// [3605260] we assume here that a packet is an integer number of frames.
UInt32 minimumBytesPerPacket = (inDesc->mBitsPerChannel * inDesc->mChannelsPerFrame + 7) / 8;
- if (inDesc->mBytesPerPacket < minimumBytesPerPacket)
+ if (inDesc->mBytesPerPacket < minimumBytesPerPacket)
return false;
}
return true;
@@ -1788,7 +1788,7 @@ Boolean AudioFileObject::IsDataFormatValid(AudioStreamBasicDescription const* in
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-void AudioFileObject::SetDataSource(DataSource* inDataSource)
+void AudioFileObject::SetDataSource(DataSource* inDataSource)
{
if (mDataSource != inDataSource) {
delete mDataSource;
@@ -1811,21 +1811,21 @@ OSStatus AudioFileObject::OpenFile(SInt8 inPermissions, int inFD)
OSStatus err = noErr;
SetDataSource(new Cached_DataSource(new UnixFile_DataSource(inFD, inPermissions, true)));
-
+
mFileD = inFD;
SetPermissions (inPermissions);
return err;
}
-
+
OSStatus AudioFileObject::CreateDataFile (CFURLRef inFileRef, int &outFileD)
-{
- UInt8 fPath[FILENAME_MAX];
+{
+ UInt8 fPath[FILENAME_MAX];
if (!CFURLGetFileSystemRepresentation (inFileRef, true, fPath, FILENAME_MAX))
return kAudio_FileNotFoundError;
-
+
struct stat stbuf;
- if (stat ((const char*)fPath, &stbuf) == 0)
+ if (stat ((const char*)fPath, &stbuf) == 0)
return kAudioFilePermissionsError;
#if TARGET_OS_WIN32
@@ -1863,7 +1863,7 @@ OSStatus AudioFileObject::AddDurationToInfoDictionary(CACFDictionary *infoDict,
OSStatus AudioFileObject::SizeChanged()
{
OSStatus err = noErr;
- if (mPermissions & kAudioFileWritePermission)
+ if (mPermissions & kAudioFileWritePermission)
{
if (DeferSizeUpdates())
SetNeedsSizeUpdate(true);
@@ -1874,8 +1874,8 @@ OSStatus AudioFileObject::SizeChanged()
}
OSStatus AudioFileObject::UpdateSizeIfNeeded()
-{
- if (GetNeedsSizeUpdate())
+{
+ if (GetNeedsSizeUpdate())
{
OSStatus err = UpdateSize();
if (err) return err;
@@ -1896,7 +1896,7 @@ OSStatus AudioFileObject::GetUserDataSize( UInt32 /*inUserDataID*/,
{
return kAudioFileOperationNotSupportedError;
}
-
+
OSStatus AudioFileObject::GetUserData( UInt32 /*inUserDataID*/,
UInt32 /*inIndex*/,
UInt32* /*ioDataSize*/,
@@ -1904,7 +1904,7 @@ OSStatus AudioFileObject::GetUserData( UInt32 /*inUserDataID*/,
{
return kAudioFileOperationNotSupportedError;
}
-
+
OSStatus AudioFileObject::SetUserData( UInt32 /*inUserDataID*/,
UInt32 /*inIndex*/,
UInt32 /*inDataSize*/,
@@ -1912,7 +1912,7 @@ OSStatus AudioFileObject::SetUserData( UInt32 /*inUserDataID*/,
{
return kAudioFileOperationNotSupportedError;
}
-
+
OSStatus AudioFileObject::RemoveUserData( UInt32 /*inUserDataID*/,
UInt32 /*inIndex*/)
{
@@ -1921,7 +1921,7 @@ OSStatus AudioFileObject::RemoveUserData( UInt32 /*inUserDataID*/,
OSStatus AudioFileObject::MoveData(SInt64 fromPos, SInt64 toPos, SInt64 size)
{
- if (fromPos == toPos)
+ if (fromPos == toPos)
return noErr;
OSStatus err = noErr;
@@ -1933,13 +1933,13 @@ OSStatus AudioFileObject::MoveData(SInt64 fromPos, SInt64 toPos, SInt64 size)
{
// read from old file
UInt32 byteCount;
- SInt64 count = (bytesRemaining < kCopySoundDataBufferSize) ? bytesRemaining : kCopySoundDataBufferSize;
+ SInt64 count = (bytesRemaining < kCopySoundDataBufferSize) ? bytesRemaining : kCopySoundDataBufferSize;
err = GetDataSource()->ReadBytes(SEEK_SET, fromPos+(bytesRemaining-count), (UInt32)count, audioData(), &byteCount);
FailIf (err != noErr, Bail, "MoveData ReadBytes failed");
err = GetDataSource()->WriteBytes(SEEK_SET, toPos+(bytesRemaining-count), (UInt32)count, audioData(), &byteCount);
FailIf (err != noErr, Bail, "WriteBytes failed");
-
+
bytesRemaining -= count;
}
} else {
@@ -1947,17 +1947,17 @@ OSStatus AudioFileObject::MoveData(SInt64 fromPos, SInt64 toPos, SInt64 size)
{
// read from old file
UInt32 byteCount;
- SInt64 count = (bytesRemaining < kCopySoundDataBufferSize) ? bytesRemaining : kCopySoundDataBufferSize;
+ SInt64 count = (bytesRemaining < kCopySoundDataBufferSize) ? bytesRemaining : kCopySoundDataBufferSize;
err = GetDataSource()->ReadBytes(SEEK_SET, fromPos+(size - bytesRemaining), (UInt32)count, audioData(), &byteCount);
FailIf (err != noErr, Bail, "MoveData ReadBytes failed");
-
+
err = GetDataSource()->WriteBytes(SEEK_SET, toPos+(size - bytesRemaining), (UInt32)count, audioData(), &byteCount);
FailIf (err != noErr, Bail, "WriteBytes failed");
-
+
bytesRemaining -= count;
}
}
-
+
Bail:
return err;
}