Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
barbibulle committed Jun 17, 2024
2 parents 4c5b67f + b92b7c3 commit 3fcc8e8
Show file tree
Hide file tree
Showing 14 changed files with 108 additions and 89 deletions.
22 changes: 11 additions & 11 deletions Source/C++/Core/Ap4Array.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
|
****************************************************************/
/**
* @file
* @file
* @brief Arrays
*/

Expand All @@ -51,15 +51,15 @@ const int AP4_ARRAY_INITIAL_COUNT = 64;
/*----------------------------------------------------------------------
| AP4_Array
+---------------------------------------------------------------------*/
template <typename T>
class AP4_Array
template <typename T>
class AP4_Array
{
public:
// methods
AP4_Array(): m_AllocatedCount(0), m_ItemCount(0), m_Items(0) {}
AP4_Array(const T* items, AP4_Size count);
AP4_Array<T>(const AP4_Array<T>& copy);
AP4_Array<T>& operator=(const AP4_Array<T>& copy);
AP4_Array(const AP4_Array<T>& copy);
AP4_Array& operator=(const AP4_Array& copy);
virtual ~AP4_Array();
AP4_Cardinal ItemCount() const { return m_ItemCount; }
AP4_Result Append(const T& item);
Expand Down Expand Up @@ -190,12 +190,12 @@ AP4_Array<T>::EnsureCapacity(AP4_Cardinal count)
| AP4_Array<T>::SetItemCount
+---------------------------------------------------------------------*/
template <typename T>
AP4_Result
AP4_Result
AP4_Array<T>::SetItemCount(AP4_Cardinal item_count)
{
// shortcut
if (item_count == m_ItemCount) return AP4_SUCCESS;

// check for a reduction in the number of items
if (item_count < m_ItemCount) {
// destruct the items that are no longer needed
Expand All @@ -205,11 +205,11 @@ AP4_Array<T>::SetItemCount(AP4_Cardinal item_count)
m_ItemCount = item_count;
return AP4_SUCCESS;
}

// grow the list
AP4_Result result = EnsureCapacity(item_count);
if (AP4_FAILED(result)) return result;

// construct the new items
for (unsigned int i=m_ItemCount; i<item_count; i++) {
new ((void*)&m_Items[i]) T();
Expand Down Expand Up @@ -247,12 +247,12 @@ AP4_Array<T>::Append(const T& item)

// if that's still not enough, just ask for what we need
if (new_count < m_ItemCount+1) new_count = m_ItemCount+1;

// reserve the space
AP4_Result result = EnsureCapacity(new_count);
if (result != AP4_SUCCESS) return result;
}

// store the item
new ((void*)&m_Items[m_ItemCount++]) T(item);

Expand Down
2 changes: 2 additions & 0 deletions Source/C++/Core/Ap4ContainerAtom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,7 @@ AP4_ContainerAtom::AP4_ContainerAtom(Type type,
AP4_AtomFactory& atom_factory) :
AP4_Atom(type, size, force_64)
{
if (size < GetHeaderSize()) return;
ReadChildren(atom_factory, stream, size-GetHeaderSize());
}

Expand All @@ -151,6 +152,7 @@ AP4_ContainerAtom::AP4_ContainerAtom(Type type,
AP4_AtomFactory& atom_factory) :
AP4_Atom(type, size, force_64, version, flags)
{
if (size < GetHeaderSize()) return;
ReadChildren(atom_factory, stream, size-GetHeaderSize());
}

Expand Down
9 changes: 7 additions & 2 deletions Source/C++/Core/Ap4ElstAtom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,8 +147,13 @@ AP4_ElstAtom::InspectFields(AP4_AtomInspector& inspector)
{
inspector.AddField("entry_count", m_Entries.ItemCount());
for (AP4_Ordinal i=0; i<m_Entries.ItemCount(); i++) {
inspector.AddField("entry/segment duration", (AP4_UI32)m_Entries[i].m_SegmentDuration);
inspector.AddField("entry/media time", (AP4_SI32)m_Entries[i].m_MediaTime);
if (1 == m_Version) {
inspector.AddField("entry/segment duration", (AP4_UI64)m_Entries[i].m_SegmentDuration);
inspector.AddField("entry/media time", (AP4_SI64)m_Entries[i].m_MediaTime);
} else {
inspector.AddField("entry/segment duration", (AP4_UI32)m_Entries[i].m_SegmentDuration);
inspector.AddField("entry/media time", (AP4_SI32)m_Entries[i].m_MediaTime);
}
inspector.AddField("entry/media rate", (AP4_UI16)m_Entries[i].m_MediaRate);
}

Expand Down
4 changes: 4 additions & 0 deletions Source/C++/Core/Ap4IproAtom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,10 @@ AP4_IproAtom::AP4_IproAtom(AP4_UI32 size,
AP4_AtomFactory& atom_factory) :
AP4_ContainerAtom(AP4_ATOM_TYPE_IPRO, size, false, version, flags)
{
if (size < AP4_FULL_ATOM_HEADER_SIZE + 2) {
return;
}

// read the number of entries
AP4_UI16 entry_count;
stream.ReadUI16(entry_count);
Expand Down
62 changes: 31 additions & 31 deletions Source/C++/Core/Ap4List.h
Original file line number Diff line number Diff line change
Expand Up @@ -43,24 +43,24 @@ template <typename T> class AP4_List;
/*----------------------------------------------------------------------
| AP4_List
+---------------------------------------------------------------------*/
template <typename T>
class AP4_List
template <typename T>
class AP4_List
{
public:
// types
class Item
class Item
{
public:
// types
class Operator
class Operator
{
public:
// methods
virtual ~Operator() {}
virtual AP4_Result Action(T* data) const = 0;
};

class Finder
class Finder
{
public:
// methods
Expand All @@ -86,8 +86,8 @@ class AP4_List
};

// methods
AP4_List<T>(): m_ItemCount(0), m_Head(0), m_Tail(0) {}
virtual ~AP4_List<T>();
AP4_List(): m_ItemCount(0), m_Head(0), m_Tail(0) {}
virtual ~AP4_List();
AP4_Result Clear();
AP4_Result Add(T* data);
AP4_Result Add(Item* item);
Expand All @@ -106,17 +106,17 @@ class AP4_List
AP4_Cardinal ItemCount() const { return m_ItemCount; }
Item* FirstItem() const { return m_Head; }
Item* LastItem() const { return m_Tail; }

protected:
// members
AP4_Cardinal m_ItemCount;
Item* m_Head;
Item* m_Tail;

private:
// these cannot be used
AP4_List<T>(const AP4_List<T>&);
AP4_List<T>& operator=(const AP4_List<T>&);
AP4_List(const AP4_List&);
AP4_List& operator=(const AP4_List&);
};

/*----------------------------------------------------------------------
Expand All @@ -137,18 +137,18 @@ AP4_Result
AP4_List<T>::Clear()
{
Item* item = m_Head;

while (item) {
Item* next = item->m_Next;
delete item;
item = next;
}
m_ItemCount = 0;
m_Head = m_Tail = NULL;

return AP4_SUCCESS;
}

/*----------------------------------------------------------------------
| AP4_List<T>::Add
+---------------------------------------------------------------------*/
Expand Down Expand Up @@ -182,7 +182,7 @@ AP4_List<T>::Add(Item* item)

// one more item in the list now
m_ItemCount++;

return AP4_SUCCESS;
}

Expand Down Expand Up @@ -241,7 +241,7 @@ AP4_List<T>::Remove(T* data)
}
item = item->m_Next;
}

return AP4_ERROR_NO_SUCH_ITEM;
}

Expand Down Expand Up @@ -335,20 +335,20 @@ AP4_List<T>::PopHead(T*& data)

// one less item in the list now
m_ItemCount--;

return AP4_SUCCESS;
}

/*----------------------------------------------------------------------
| AP4_List<T>::Apply
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::Apply(const typename Item::Operator& op) const
{
Item* item = m_Head;

while (item) {
op.Action(item->m_Data);
item = item->m_Next;
Expand All @@ -361,12 +361,12 @@ AP4_List<T>::Apply(const typename Item::Operator& op) const
| AP4_List<T>::ApplyUntilFailure
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::ApplyUntilFailure(const typename Item::Operator& op) const
{
Item* item = m_Head;

while (item) {
AP4_Result result;
result = op.Action(item->m_Data);
Expand All @@ -381,12 +381,12 @@ AP4_List<T>::ApplyUntilFailure(const typename Item::Operator& op) const
| AP4_List<T>::ApplyUntilSuccess
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::ApplyUntilSuccess(const typename Item::Operator& op) const
{
Item* item = m_Head;

while (item) {
AP4_Result result;
result = op.Action(item->m_Data);
Expand All @@ -401,12 +401,12 @@ AP4_List<T>::ApplyUntilSuccess(const typename Item::Operator& op) const
| AP4_List<T>::ReverseApply
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::ReverseApply(const typename Item::Operator& op) const
{
Item* item = m_Tail;

while (item) {
if (op.Action(item->m_Data) != AP4_SUCCESS) {
return AP4_ERROR_LIST_OPERATION_ABORTED;
Expand All @@ -421,12 +421,12 @@ AP4_List<T>::ReverseApply(const typename Item::Operator& op) const
| AP4_List<T>::Find
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::Find(const typename Item::Finder& finder, T*& data) const
{
Item* item = m_Head;

while (item) {
if (finder.Test(item->m_Data) == AP4_SUCCESS) {
data = item->m_Data;
Expand All @@ -443,12 +443,12 @@ AP4_List<T>::Find(const typename Item::Finder& finder, T*& data) const
| AP4_List<T>::ReverseFind
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::ReverseFind(const typename Item::Finder& finder, T*& data) const
{
Item* item = m_Tail;

while (item) {
if (finder.Test(item->m_Data) == AP4_SUCCESS) {
data = item->m_Data;
Expand All @@ -465,12 +465,12 @@ AP4_List<T>::ReverseFind(const typename Item::Finder& finder, T*& data) const
| AP4_List<T>::DeleteReferences
+---------------------------------------------------------------------*/
template <typename T>
inline
inline
AP4_Result
AP4_List<T>::DeleteReferences()
{
Item* item = m_Head;

while (item) {
Item* next = item->m_Next;
delete item->m_Data;
Expand Down
3 changes: 2 additions & 1 deletion Source/C++/Core/Ap4Marlin.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1116,10 +1116,11 @@ AP4_MkidAtom::AP4_MkidAtom(AP4_Size size,
AP4_ByteStream& stream) :
AP4_Atom(AP4_ATOM_TYPE_MKID, size, version, flags)
{
if (size < AP4_FULL_ATOM_HEADER_SIZE+4) return;
AP4_Size available = size-(AP4_FULL_ATOM_HEADER_SIZE+4);
AP4_UI32 entry_count = 0;
stream.ReadUI32(entry_count);
if (available < entry_count*(16+4)) return;
if (available < (AP4_UI64)entry_count*(16+4)) return;
m_Entries.SetItemCount(entry_count);
for (unsigned int i=0; i<entry_count && available >= 16+4; i++) {
AP4_UI32 entry_size;
Expand Down
2 changes: 2 additions & 0 deletions Source/C++/Core/Ap4OdheAtom.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,11 @@ AP4_OdheAtom::AP4_OdheAtom(AP4_UI32 size,
AP4_AtomFactory& atom_factory) :
AP4_ContainerAtom(AP4_ATOM_TYPE_ODHE, size, false, version, flags)
{
if (size < AP4_FULL_ATOM_HEADER_SIZE+1) return;
// read the content type
AP4_UI08 content_type_length;
stream.ReadUI08(content_type_length);
if (size < AP4_FULL_ATOM_HEADER_SIZE+1+content_type_length) return;
char content_type[256];
stream.Read(content_type, content_type_length);
m_ContentType.Assign(content_type, content_type_length);
Expand Down
Loading

0 comments on commit 3fcc8e8

Please sign in to comment.