Darwin-Streaming-Server/QTFileLib/QTFile.h
Darren VanBuren 849723c9cf Add even more of the source
This should be about everything needed to build so far?
2017-03-07 17:14:16 -08:00

215 lines
6.1 KiB
C++

/*
*
* @APPLE_LICENSE_HEADER_START@
*
* Copyright (c) 1999-2008 Apple Inc. All Rights Reserved.
*
* This file contains Original Code and/or Modifications of Original Code
* as defined in and that are subject to the Apple Public Source License
* Version 2.0 (the 'License'). You may not use this file except in
* compliance with the License. Please obtain a copy of the License at
* http://www.opensource.apple.com/apsl/ and read it before using this
* file.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
* Please see the License for the specific language governing rights and
* limitations under the License.
*
* @APPLE_LICENSE_HEADER_END@
*
*/
// $Id: QTFile.h,v 1.1 2006/01/05 13:20:36 murata Exp $
//
// QTFile:
// The central point of control for a file in the QuickTime File Format.
#ifndef QTFile_H
#define QTFile_H
//
// Includes
#include "OSHeaders.h"
#include "OSFileSource.h"
#include "QTFile_FileControlBlock.h"
#include "DateTranslator.h"
//
// External classes
class OSMutex;
class QTAtom_mvhd;
class QTTrack;
//
// QTFile class
class QTFile {
public:
//
// Class constants
//
// Class error codes
enum ErrorCode {
errNoError = 0,
errFileNotFound = 1,
errInvalidQuickTimeFile = 2,
errInternalError = 100
};
//
// Class typedefs.
struct AtomTOCEntry {
// TOC id (used to compare TOCs)
UInt32 TOCID;
// Atom information
OSType AtomType, beAtomType; // be = Big Endian
UInt64 AtomDataPos;
UInt64 AtomDataLength;
UInt32 AtomHeaderSize;
// TOC pointers
AtomTOCEntry *NextOrdAtom;
AtomTOCEntry *PrevAtom, *NextAtom;
AtomTOCEntry *Parent, *FirstChild;
};
struct TrackListEntry {
// Track information
UInt32 TrackID;
QTTrack *Track;
Bool16 IsHintTrack;
// List pointers
TrackListEntry *NextTrack;
};
public:
//
// Constructors and destructor.
QTFile(Bool16 Debug = false, Bool16 DeepDebug = false);
virtual ~QTFile(void);
//
// Open a movie file and generate the atom table of contents.
ErrorCode Open(const char * MoviePath);
OSMutex* GetMutex() { return fReadMutex; }
//
// Table of Contents functions.
Bool16 FindTOCEntry(const char * AtomPath,
AtomTOCEntry **TOCEntry,
AtomTOCEntry *LastFoundTOCEntry = NULL);
//
// Track List functions
inline UInt32 GetNumTracks(void) { return fNumTracks; }
Bool16 NextTrack(QTTrack **Track, QTTrack *LastFoundTrack = NULL);
Bool16 FindTrack(UInt32 TrackID, QTTrack **Track);
Bool16 IsHintTrack(QTTrack *Track);
//
// Accessors
inline char * GetMoviePath(void) { return fMoviePath; }
Float64 GetTimeScale(void);
Float64 GetDurationInSeconds(void);
SInt64 GetModDate();
// Returns the mod date as a RFC 1123 formatted string
char* GetModDateStr();
//
// Read functions.
Bool16 Read(UInt64 Offset, char * const Buffer, UInt32 Length, QTFile_FileControlBlock * FCB = NULL);
void AllocateBuffers(UInt32 inUnitSizeInK, UInt32 inBufferInc, UInt32 inBufferSize, UInt32 inMaxBitRateBuffSizeInBlocks, UInt32 inBitrate);
#if DSS_USE_API_CALLBACKS
void IncBufferUserCount() {if (fOSFileSourceFD != NULL) fOSFileSourceFD->IncMaxBuffers();}
void DecBufferUserCount() {if (fOSFileSourceFD != NULL) fOSFileSourceFD->DecMaxBuffers();}
#else
void IncBufferUserCount() {fMovieFD.IncMaxBuffers();}
void DecBufferUserCount() {fMovieFD.DecMaxBuffers();}
#endif
inline Bool16 ValidTOC();
char* MapFileToMem(UInt64 offset, UInt32 length);
int UnmapMem(char *memPtr, UInt32 length);
//
// Debugging functions.
void DumpAtomTOC(void);
protected:
//
// Protected member functions.
Bool16 GenerateAtomTOC(void);
//
// Protected member variables.
Bool16 fDebug, fDeepDebug;
UInt32 fNextTOCID;
#if DSS_USE_API_CALLBACKS
QTSS_Object fMovieFD;
OSFileSource *fOSFileSourceFD;
#else
OSFileSource fMovieFD;
#endif
Bool16 fCacheBuffersSet;
DateBuffer fModDateBuffer;
char *fMoviePath;
AtomTOCEntry *fTOC, *fTOCOrdHead, *fTOCOrdTail;
UInt32 fNumTracks;
TrackListEntry *fFirstTrack, *fLastTrack;
QTAtom_mvhd *fMovieHeaderAtom;
OSMutex *fReadMutex;
int fFile;
};
Bool16 QTFile::ValidTOC()
{
UInt64 theLength = 0;
UInt64 thePos = 0;
#if DSS_USE_API_CALLBACKS
UInt32 theDataLen = sizeof(UInt64);
(void)QTSS_GetValue(fMovieFD, qtssFlObjLength, 0, (void*)&theLength, &theDataLen);
(void)QTSS_GetValue(fMovieFD, qtssFlObjPosition, 0, (void*)&thePos, &theDataLen);
// qtss_printf("GenerateAtomTOC failed CurPos=%"_64BITARG_"u < Length=%"_64BITARG_"u\n", CurPos, theLength);
#else
theLength = fMovieFD.GetLength();
thePos = fMovieFD.GetCurOffset();
#endif
if (thePos < theLength) // failure pos not at end of file
{
// qtss_printf("GenerateAtomTOC failed CurPos=%"_64BITARG_"u < Length=%"_64BITARG_"u\n", CurPos, theLength);
return false;
}
return true;
}
#endif // QTFile_H