File: Ap4.cpp

package info (click to toggle)
kodi-inputstream-adaptive 2.6.14%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 4,036 kB
  • sloc: cpp: 53,019; ansic: 492; makefile: 10
file content (89 lines) | stat: -rw-r--r-- 3,164 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*****************************************************************
|
|    AP4 - Main Header
|
|    Copyright 2002-2008 Axiomatic Systems, LLC
|
|
|    This file is part of Bento4/AP4 (MP4 Atom Processing Library).
|
|    Unless you have obtained Bento4 under a difference license,
|    this version of Bento4 is Bento4|GPL.
|    Bento4|GPL is free software; you can redistribute it and/or modify
|    it under the terms of the GNU General Public License as published by
|    the Free Software Foundation; either version 2, or (at your option)
|    any later version.
|
|    Bento4|GPL is distributed in the hope that it will be useful,
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
|    GNU General Public License for more details.
|
|    You should have received a copy of the GNU General Public License
|    along with Bento4|GPL; see the file COPYING.  If not, write to the
|    Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
|    02111-1307, USA.
|
 ****************************************************************/

/*----------------------------------------------------------------------
|   includes
+---------------------------------------------------------------------*/
#include "Ap4.h"

/*----------------------------------------------------------------------
|   AP4::AP4
+---------------------------------------------------------------------*/
// this constructor can be used to detect if the platform's loader
// correctly constructs static C++ objects
static AP4 AP4_LoaderCheck;
AP4::AP4() : m_ConstructedByLoader(true)
{
}

/*----------------------------------------------------------------------
|   AP4::Initialize
+---------------------------------------------------------------------*/
AP4_Result
AP4::Initialize()
{
    AP4_Result result = AP4_SUCCESS;
#if defined(AP4_CONFIG_CONSTRUCT_STATICS_ON_INITIALIZE)
    if (!AP4_DefaultAtomFactory::Instance.m_Initialized) {
        result = AP4_DefaultAtomFactory::Instance.Initialize();
        if (AP4_FAILED(result)) return result;
    }
    if (!AP4_DefaultBlockCipherFactory::Instance.m_Initialized) {
        result = AP4_DefaultBlockCipherFactory::Instance.Initialize();
        if (AP4_FAILED(result)) return result;
    }
    if (!AP4_MetaData::Initialized()) {
        AP4_MetaData::Initialize();
    }
#endif
    
    return result;
}

/*----------------------------------------------------------------------
|   AP4_Terminate
+---------------------------------------------------------------------*/
AP4_Result
AP4::Terminate()
{
#if defined(AP4_CONFIG_DESTRUCT_STATICS_ON_TERMINATE)
    if (!AP4_LoaderCheck.m_ConstructedByLoader) {
        if (AP4_DefaultAtomFactory::Instance.m_Initialized) {
            AP4_DefaultAtomFactory::Instance.~AP4_DefaultAtomFactory();
        }
        if (AP4_DefaultBlockCipherFactory::Instance.m_Initialized) {
            AP4_DefaultBlockCipherFactory::Instance.~AP4_DefaultBlockCipherFactory();
        }
        if (AP4_MetaData::Initialized()) {
            AP4_MetaData::UnInitialize();
        }
    }
#endif

    return AP4_SUCCESS;
}