/*
* Copyright (C) 2007 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __DCF_COMM_H__
#define __DCF_COMM_H__
#include <Drm2CommonTypes.h>
#include <arpa/inet.h>
#include <mistream.h>
#include <ustring.h>
using namespace ustl;
////DCF box type list
const uint32_t DCF_CONTAINER_BOX = uint32_t('m' << 24 | 'r' << 16 | 'd' << 8 | 'o');
const uint32_t DCF_USER_TYPE = uint32_t('d' << 24 | 'i' << 16 | 'u' << 8 | 'u');
const uint32_t DCF_FILE_TYPE = uint32_t('p' << 24 | 'y' << 16 | 't' << 8 | 'f');
const uint32_t DCF_FILE_BRAND = uint32_t('f' << 24 | 'c' << 16 | 'd' << 8 | 'o');
/**
* The basic box class.
*/
class Box
{
public:
/**
* constructor for Box, used to parse Box
* \param box Box data
*/
Box(const uint8_t* box);
/**
* copy constructor for Box
* \param dcfBox Box object used to init a new Box object
*/
Box(const Box& dcfBox);
/**
* assignment operator for Box
* \param other Box object used to assign to a exist Box object
*/
Box& operator=(const Box& other);
/** Destructor for Box */
virtual ~Box();
/**
* get the size of Box
* \param none
* \return
* the size
*/
uint64_t getSize(void) const;
/**
* get the type of Box
* \param none
* \return
* the type
*/
uint32_t getType(void) const;
/**
* get the user type of Box
* \param none
* \return
* the user type
*/
const uint8_t* getUsertype(void) const;
/**
* get the length of Box
* \param none
* \return
* the length
*/
virtual uint32_t getLen(void) const;
PRIVATE:
static const uint32_t USER_TYPE_LEN = 16;
uint32_t mSize;
uint32_t mType;
uint64_t mLargeSize;
uint8_t* mUserType;
uint32_t mBoxLength;
};
/**
* The fullBox class.
*/
class FullBox : public Box
{
public:
/**
* constructor for FullBox, used to parse FullBox
* \param fullBox FullBox data
*/
FullBox(const uint8_t* fullBox);
/** Destructor for FullBox */
virtual ~FullBox(){}
/**
* get the version of FullBox
* \param none
* \return
* the version
*/
uint8_t getVersion(void) const;
/**
* get the flag of FullBox
* \param none
* \return
* the flag
*/
const uint8_t* getFlag(void) const;
/**
* get the length of FullBox
* \param none
* \return
* the length
*/
virtual uint32_t getLen(void) const;
PRIVATE:
static const uint32_t FLAG_LEN = 3;
uint8_t mVersion;
uint8_t mFlag[FLAG_LEN];
uint32_t mFullBoxLength;
};
////// textal header class
class TextualHeader
{
public:
/** default constructor of DrmInStream */
TextualHeader(){};
/**
* constructor for TextualHeader, used to parse textal header
* \param inData textal header data
*/
TextualHeader(const string& inData);
/**
* get the name of textal header
* \param none
* \return
* the name
*/
string getName() const;
/**
* get the value of textal header
* \param none
* \return
* the value
*/
string getValue() const;
/**
* get the parameter of textal header
* \param none
* \return
* the parameter
*/
string getParam() const;
PRIVATE:
string name;
string value;
string param;
};
extern int64_t ntoh_int64(int64_t in);
#endif