Bug 71869, make XML Extras component load in startup in embedded case as well as browser. r=chak, sr=vidur.

This commit is contained in:
heikki%netscape.com 2001-03-29 01:11:13 +00:00
Родитель d7b4428123
Коммит 31845da8a5
2 изменённых файлов: 26 добавлений и 66 удалений

Просмотреть файл

@ -30,7 +30,7 @@ MODULE = xmlextras
LIBRARY_NAME = xmlextras
SHORT_LIBNAME = xmlextra
IS_COMPONENT = 1
REQUIRES = xpcom string dom js layout widget caps necko webbrwsr
REQUIRES = xpcom string dom js layout widget caps necko webbrwsr appstartupnotifier
CPPSRCS = nsXMLExtrasModule.cpp

Просмотреть файл

@ -24,13 +24,16 @@
#include "nsDOMSerializer.h"
#include "nsXMLHttpRequest.h"
#include "nsDOMParser.h"
#include "nsIAppShellComponent.h"
#include "nsIAppStartupNotifier.h"
#include "nsICategoryManager.h"
#include "nsIObserver.h"
#include "nsIScriptExternalNameSet.h"
#include "nsIScriptNameSetRegistry.h"
#include "nsIScriptNameSpaceManager.h"
#include "nsIScriptContext.h"
#include "nsIRegistry.h"
#include "nsString.h"
#include "nsXPIDLString.h"
#include "nsDOMCID.h"
#include "prprf.h"
@ -98,7 +101,7 @@ nsXMLExtrasNameset::AddNameSet(nsIScriptContext* aScriptContext)
static NS_DEFINE_CID(kSOAPCall_CID, NS_SOAPCALL_CID);
static NS_DEFINE_CID(kSOAPParameter_CID, NS_SOAPPARAMETER_CID);
#endif
nsresult result = NS_OK;
nsresult result;
nsCOMPtr<nsIScriptNameSpaceManager> manager;
result = aScriptContext->GetNameSpaceManager(getter_AddRefs(manager));
@ -144,9 +147,9 @@ nsXMLExtrasNameset::AddNameSet(nsIScriptContext* aScriptContext)
0x33e569b0, 0x40f8, 0x11d4, \
{0x9a, 0x41, 0x00, 0x00, 0x64, 0x65, 0x73, 0x74} }
#define NS_XML_EXTRAS_CONTRACTID NS_IAPPSHELLCOMPONENT_CONTRACTID "/xmlextras;1"
#define NS_XML_EXTRAS_CONTRACTID "@mozilla.org/xmlextras;1"
class nsXMLExtras : public nsIAppShellComponent {
class nsXMLExtras : public nsIObserver {
public:
nsXMLExtras();
virtual ~nsXMLExtras();
@ -156,28 +159,10 @@ public:
// nsISupports
NS_DECL_ISUPPORTS
// nsIAppShellComponent
NS_DECL_NSIAPPSHELLCOMPONENT
static nsXMLExtras *GetInstance();
static nsXMLExtras* mInstance;
// nsIObserver
NS_DECL_NSIOBSERVER
};
nsXMLExtras* nsXMLExtras::mInstance = nsnull;
nsXMLExtras *
nsXMLExtras::GetInstance()
{
if (mInstance == nsnull) {
mInstance = new nsXMLExtras();
// Will be released in the module destructor
NS_IF_ADDREF(mInstance);
}
NS_IF_ADDREF(mInstance);
return mInstance;
}
nsXMLExtras::nsXMLExtras()
{
NS_INIT_ISUPPORTS();
@ -187,33 +172,27 @@ nsXMLExtras::~nsXMLExtras()
{
}
NS_IMPL_ISUPPORTS1(nsXMLExtras, nsIAppShellComponent)
NS_IMPL_ISUPPORTS1(nsXMLExtras, nsIObserver)
NS_IMETHODIMP
nsXMLExtras::Initialize(nsIAppShellService *anAppShell,
nsICmdLineService *aCmdLineService)
nsXMLExtras::Observe(nsISupports *aSubject, const PRUnichar *aTopic, const PRUnichar *aData)
{
nsresult rv;
nsCOMPtr<nsIScriptNameSetRegistry> namesetService =
do_GetService(kCScriptNameSetRegistryCID, &rv);
nsCOMPtr<nsIScriptNameSetRegistry>
namesetService(do_GetService(kCScriptNameSetRegistryCID, &rv));
if (NS_SUCCEEDED(rv)) {
nsXMLExtrasNameset* nameset = new nsXMLExtrasNameset();
if (!nameset)
return NS_ERROR_OUT_OF_MEMORY;
// the NameSet service will AddRef this one
namesetService->AddExternalNameSet(nameset);
rv = namesetService->AddExternalNameSet(nameset);
}
return rv;
}
NS_IMETHODIMP
nsXMLExtras::Shutdown()
{
return NS_OK;
}
NS_GENERIC_FACTORY_SINGLETON_CONSTRUCTOR(nsXMLExtras,nsXMLExtras::GetInstance);
NS_GENERIC_FACTORY_CONSTRUCTOR(nsXMLExtras)
static NS_METHOD
RegisterXMLExtras(nsIComponentManager *aCompMgr,
@ -222,27 +201,14 @@ RegisterXMLExtras(nsIComponentManager *aCompMgr,
const char *componentType,
const nsModuleComponentInfo *info)
{
// get the registry
nsIRegistry* registry;
nsresult rv = nsServiceManager::GetService(NS_REGISTRY_CONTRACTID,
NS_GET_IID(nsIRegistry),
(nsISupports**)&registry);
nsresult rv;
nsCOMPtr<nsICategoryManager>
categoryManager(do_GetService("@mozilla.org/categorymanager;1", &rv));
if (NS_SUCCEEDED(rv)) {
registry->OpenWellKnownRegistry(nsIRegistry::ApplicationComponentRegistry);
char buffer[256];
char *cid = nsXMLExtras::GetCID().ToString();
PR_snprintf(buffer,
sizeof buffer,
"%s/%s",
NS_IAPPSHELLCOMPONENT_KEY,
cid ? cid : "unknown" );
nsCRT::free(cid);
nsRegistryKey key;
rv = registry->AddSubtree(nsIRegistry::Common,
buffer,
&key );
nsServiceManager::ReleaseService(NS_REGISTRY_CONTRACTID, registry);
rv = categoryManager->AddCategoryEntry(APPSTARTUP_CATEGORY, "XML Extras Module",
"service," NS_XML_EXTRAS_CONTRACTID,
PR_TRUE, PR_TRUE,
nsnull);
}
return rv;
}
@ -265,10 +231,4 @@ static nsModuleComponentInfo components[] = {
#endif
};
static void PR_CALLBACK
XMLExtrasModuleDtor(nsIModule* self)
{
NS_IF_RELEASE(nsXMLExtras::mInstance);
}
NS_IMPL_NSGETMODULE_WITH_DTOR("nsXMLExtrasModule", components, XMLExtrasModuleDtor)
NS_IMPL_NSGETMODULE("nsXMLExtrasModule", components)