2010-06-10 11:11:11 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2012-05-21 04:12:37 -07:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2010-06-10 11:11:11 -07:00
|
|
|
|
|
|
|
#ifndef mozilla_Module_h
|
|
|
|
#define mozilla_Module_h
|
|
|
|
|
|
|
|
#include "nscore.h"
|
|
|
|
#include "nsID.h"
|
|
|
|
#include "nsIFactory.h"
|
|
|
|
#include "nsCOMPtr.h" // for already_AddRefed
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A module implements one or more XPCOM components. This structure is used
|
|
|
|
* for both binary and script modules, but the registration members
|
|
|
|
* (cids/contractids/categoryentries) are unused for modules which are loaded
|
|
|
|
* via a module loader.
|
|
|
|
*/
|
|
|
|
struct Module
|
|
|
|
{
|
2014-04-28 11:18:37 -07:00
|
|
|
static const unsigned int kVersion = 32;
|
2010-06-10 11:11:11 -07:00
|
|
|
|
|
|
|
struct CIDEntry;
|
|
|
|
|
2010-06-21 09:46:26 -07:00
|
|
|
typedef already_AddRefed<nsIFactory> (*GetFactoryProcPtr)
|
2010-06-10 11:11:11 -07:00
|
|
|
(const Module& module, const CIDEntry& entry);
|
|
|
|
|
2010-06-21 09:46:26 -07:00
|
|
|
typedef nsresult (*ConstructorProcPtr)(nsISupports* aOuter,
|
|
|
|
const nsIID& aIID,
|
|
|
|
void** aResult);
|
2010-06-10 11:11:11 -07:00
|
|
|
|
2010-06-21 09:46:26 -07:00
|
|
|
typedef nsresult (*LoadFuncPtr)();
|
|
|
|
typedef void (*UnloadFuncPtr)();
|
2010-06-10 11:11:11 -07:00
|
|
|
|
2014-02-09 16:11:37 -08:00
|
|
|
/**
|
|
|
|
* This selector allows CIDEntrys to be marked so that they're only loaded
|
|
|
|
* into certain kinds of processes.
|
|
|
|
*/
|
|
|
|
enum ProcessSelector
|
|
|
|
{
|
|
|
|
ANY_PROCESS = 0,
|
|
|
|
MAIN_PROCESS_ONLY,
|
|
|
|
CONTENT_PROCESS_ONLY
|
|
|
|
};
|
|
|
|
|
2010-06-10 11:11:11 -07:00
|
|
|
/**
|
|
|
|
* The constructor callback is an implementation detail of the default binary
|
|
|
|
* loader and may be null.
|
|
|
|
*/
|
|
|
|
struct CIDEntry
|
|
|
|
{
|
|
|
|
const nsCID* cid;
|
|
|
|
bool service;
|
2010-06-21 09:46:26 -07:00
|
|
|
GetFactoryProcPtr getFactoryProc;
|
|
|
|
ConstructorProcPtr constructorProc;
|
2014-02-09 16:11:37 -08:00
|
|
|
ProcessSelector processSelector;
|
2010-06-10 11:11:11 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct ContractIDEntry
|
|
|
|
{
|
|
|
|
const char* contractid;
|
|
|
|
nsID const * cid;
|
2014-02-09 16:11:37 -08:00
|
|
|
ProcessSelector processSelector;
|
2010-06-10 11:11:11 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct CategoryEntry
|
|
|
|
{
|
|
|
|
const char* category;
|
|
|
|
const char* entry;
|
|
|
|
const char* value;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Binary compatibility check, should be kModuleVersion.
|
|
|
|
*/
|
|
|
|
unsigned int mVersion;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An array of CIDs (class IDs) implemented by this module. The final entry
|
2013-10-10 13:41:00 -07:00
|
|
|
* should be { nullptr }.
|
2010-06-10 11:11:11 -07:00
|
|
|
*/
|
|
|
|
const CIDEntry* mCIDs;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An array of mappings from contractid to CID. The final entry should
|
2013-10-10 13:41:00 -07:00
|
|
|
* be { nullptr }.
|
2010-06-10 11:11:11 -07:00
|
|
|
*/
|
|
|
|
const ContractIDEntry* mContractIDs;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An array of category manager entries. The final entry should be
|
2013-10-10 13:41:00 -07:00
|
|
|
* { nullptr }.
|
2010-06-10 11:11:11 -07:00
|
|
|
*/
|
|
|
|
const CategoryEntry* mCategoryEntries;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* When the component manager tries to get the factory for a CID, it first
|
|
|
|
* checks for this module-level getfactory callback. If this function is
|
|
|
|
* not implemented, it checks the CIDEntry getfactory callback. If that is
|
2013-10-10 13:41:00 -07:00
|
|
|
* also nullptr, a generic factory is generated using the CIDEntry
|
|
|
|
* constructor callback which must be non-nullptr.
|
2010-06-10 11:11:11 -07:00
|
|
|
*/
|
2010-06-21 09:46:26 -07:00
|
|
|
GetFactoryProcPtr getFactoryProc;
|
2010-06-10 11:11:11 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Optional Function which are called when this module is loaded and
|
|
|
|
* at shutdown. These are not C++ constructor/destructors to avoid
|
|
|
|
* calling them too early in startup or too late in shutdown.
|
|
|
|
*/
|
2010-06-21 09:46:26 -07:00
|
|
|
LoadFuncPtr loadProc;
|
|
|
|
UnloadFuncPtr unloadProc;
|
2010-06-10 11:11:11 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
2013-06-14 23:33:35 -07:00
|
|
|
#if defined(MOZILLA_INTERNAL_API)
|
2010-06-10 11:11:11 -07:00
|
|
|
# define NSMODULE_NAME(_name) _name##_NSModule
|
2013-11-22 08:00:32 -08:00
|
|
|
# define NSMODULE_DECL(_name) extern mozilla::Module const *const NSMODULE_NAME(_name)
|
|
|
|
# define NSMODULE_DEFN(_name) NSMODULE_DECL(_name)
|
2010-06-10 11:11:11 -07:00
|
|
|
#else
|
|
|
|
# define NSMODULE_NAME(_name) NSModule
|
|
|
|
# define NSMODULE_DEFN(_name) extern "C" NS_EXPORT mozilla::Module const *const NSModule
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // mozilla_Module_h
|