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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
// =================================================================================================
// Copyright Adobe
// Copyright 2011 Adobe
// All Rights Reserved
//
// NOTICE: Adobe permits you to use, modify, and distribute this file in accordance with the terms
// of the Adobe license agreement accompanying it.
// =================================================================================================
#include "PluginRegistry.h"
#include "PluginBase.h"
namespace XMP_PLUGIN
{
// static class member initialization
PluginRegistry* PluginRegistry::msRegistry = NULL;
PluginRegistry::~PluginRegistry()
{
RegistryEntryMap::iterator iter = msRegistry->mRegistryEntries.begin();
RegistryEntryMap::iterator iterEnd = msRegistry->mRegistryEntries.end();
for( ; iter != iterEnd; )
{
RegistryEntryMap::iterator temp = iter++;
delete temp->second;
}
}
// ============================================================================
/*static*/
void PluginRegistry::registerHandler( const PluginCreatorBase* inCreator )
{
if( msRegistry == NULL )
msRegistry = new PluginRegistry();
msRegistry->mRegistryEntries[inCreator->GetUID()] = inCreator;
}
// ============================================================================
/*static*/
PluginBase* PluginRegistry::create( const std::string& uid, const std::string& filePath, XMP_Uns32 openFlags, XMP_Uns32 format, XMP_Uns32 handlerFlags, ErrorCallbackBox * errorCallbackbox /* = 0*/, XMP_ProgressTracker::CallbackInfo * progCBInfo /*= 0*/ )
{
if( msRegistry != NULL )
{
RegistryEntryMap::const_iterator iter = msRegistry->mRegistryEntries.find( uid );
if( iter != msRegistry->mRegistryEntries.end() )
return iter->second->create( filePath, openFlags, format, handlerFlags, errorCallbackbox, progCBInfo );
}
return NULL;
}
// ============================================================================
/*static*/
bool PluginRegistry::checkFileFormat( const std::string& uid, const std::string& filePath, const IOAdapter& file )
{
if( msRegistry != NULL )
{
RegistryEntryMap::const_iterator iter = msRegistry->mRegistryEntries.find(uid);
if( iter != msRegistry->mRegistryEntries.end() )
return iter->second->checkFileFormat( filePath, file );
}
return false;
}
// ============================================================================
/*static*/
bool PluginRegistry::checkFolderFormat( const std::string& uid, const std::string& rootPath, const std::string& gpName, const std::string& parentName, const std::string& leafName )
{
if( msRegistry != NULL )
{
RegistryEntryMap::const_iterator iter = msRegistry->mRegistryEntries.find(uid);
if( iter != msRegistry->mRegistryEntries.end() )
return iter->second->checkFolderFormat( rootPath, gpName, parentName, leafName );
}
return false;
}
// ============================================================================
/*static*/
bool PluginRegistry::initialize()
{
if( msRegistry != NULL )
{
RegistryEntryMap::const_iterator iter = msRegistry->mRegistryEntries.begin();
RegistryEntryMap::const_iterator iterEnd = msRegistry->mRegistryEntries.end();
for( ; iter != iterEnd; ++iter )
{
if( iter->second->initialize() == false )
return false;
}
}
return true;
}
// ============================================================================
/*static*/
bool PluginRegistry::terminate()
{
if( msRegistry != NULL )
{
RegistryEntryMap::const_iterator iter = msRegistry->mRegistryEntries.begin();
RegistryEntryMap::const_iterator iterEnd = msRegistry->mRegistryEntries.end();
for( ; iter != iterEnd; ++iter )
{
iter->second->terminate();
}
delete msRegistry;
msRegistry = NULL;
}
return true;
}
} //namespace XMP_PLUGIN
|