/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- * * The contents of this file are subject to the Netscape Public * License Version 1.1 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.mozilla.org/NPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is Mozilla Communicator client code. * * The Initial Developer of the Original Code is Netscape Communications * Corporation. Portions created by Netscape are * Copyright (C) 1998 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): * Pierre Phaneuf */ #include "nsString.h" #include "nspr.h" #include "nsCOMPtr.h" #include "nsIGenericFactory.h" #include "nsIModule.h" #include "nsParserCIID.h" #include "nsParser.h" #include "nsLoggingSink.h" #include "nsWellFormedDTD.h" #include "CNavDTD.h" #include "COtherDTD.h" #include "COtherDTD.h" #include "nsViewSourceHTML.h" #include "nsHTMLContentSinkStream.h" #include "nsHTMLEntities.h" #include "nsHTMLTokenizer.h" #include "nsXMLTokenizer.h" //#include "nsTextTokenizer.h" #include "nsExpatTokenizer.h" #include "nsIParserService.h" #include "nsElementTable.h" static NS_DEFINE_IID(kIParserServiceIID, NS_IPARSERSERVICE_IID); class nsParserService : public nsIParserService { public: nsParserService(); virtual ~nsParserService(); NS_DECL_ISUPPORTS NS_IMETHOD HTMLAtomTagToId(nsIAtom* aAtom, PRInt32* aId) const; NS_IMETHOD HTMLStringTagToId(const nsString &aTag, PRInt32* aId) const; NS_IMETHOD HTMLIdToStringTag(PRInt32 aId, nsString& aTag) const; NS_IMETHOD HTMLConvertEntityToUnicode(const nsString& aEntity, PRInt32* aUnicode) const; NS_IMETHOD HTMLConvertUnicodeToEntity(PRInt32 aUnicode, nsCString& aEntity) const; NS_IMETHOD IsContainer(PRInt32 aId, PRBool& aIsContainer) const; NS_IMETHOD IsBlock(PRInt32 aId, PRBool& aIsBlock) const; }; nsParserService::nsParserService() { NS_INIT_ISUPPORTS(); } nsParserService::~nsParserService() { } NS_IMPL_ISUPPORTS(nsParserService, kIParserServiceIID) NS_IMETHODIMP nsParserService::HTMLAtomTagToId(nsIAtom* aAtom, PRInt32* aId) const { NS_ENSURE_ARG_POINTER(aAtom); nsAutoString tagName; aAtom->ToString(tagName); *aId = nsHTMLTags::LookupTag(tagName); return NS_OK; } NS_IMETHODIMP nsParserService::HTMLStringTagToId(const nsString &aTag, PRInt32* aId) const { *aId = nsHTMLTags::LookupTag(aTag); return NS_OK; } NS_IMETHODIMP nsParserService::HTMLIdToStringTag(PRInt32 aId, nsString& aTag) const { aTag.AssignWithConversion( nsHTMLTags::GetStringValue((nsHTMLTag)aId) ); return NS_OK; } NS_IMETHODIMP nsParserService::HTMLConvertEntityToUnicode(const nsString& aEntity, PRInt32* aUnicode) const { *aUnicode = nsHTMLEntities::EntityToUnicode(aEntity); return NS_OK; } NS_IMETHODIMP nsParserService::HTMLConvertUnicodeToEntity(PRInt32 aUnicode, nsCString& aEntity) const { const nsCString& str = nsHTMLEntities::UnicodeToEntity(aUnicode); if (str.Length() > 0) { aEntity.Assign(str); } return NS_OK; } NS_IMETHODIMP nsParserService::IsContainer(PRInt32 aId, PRBool& aIsContainer) const { aIsContainer = nsHTMLElement::IsContainer((eHTMLTags)aId); return NS_OK; } NS_IMETHODIMP nsParserService::IsBlock(PRInt32 aId, PRBool& aIsBlock) const { if((aId>eHTMLTag_unknown) && (aId fact; for (unsigned int i = 0; i < NUM_COMPONENTS; i++) { if (aClass.Equals(gComponents[i].mCID)) { rv = NS_NewGenericFactory(getter_AddRefs(fact), &gComponents[i]); break; } } if (fact) { rv = fact->QueryInterface(aIID, r_classObj); } return rv; } NS_IMETHODIMP nsParserModule::RegisterSelf(nsIComponentManager *aCompMgr, nsIFile* aPath, const char* registryLocation, const char* componentType) { nsresult rv = NS_OK; nsModuleComponentInfo* cp = gComponents, *end = cp + NUM_COMPONENTS; while (cp < end) { rv = aCompMgr->RegisterComponentSpec(cp->mCID, cp->mDescription, nsnull, aPath, PR_TRUE, PR_TRUE); if (NS_FAILED(rv)) { #ifdef DEBUG printf("nsParserModule: unable to register %s component => %x\n", cp->mDescription, rv); #endif break; } cp++; } return rv; } NS_IMETHODIMP nsParserModule::UnregisterSelf(nsIComponentManager *aCompMgr, nsIFile* aPath, const char* registryLocation) { nsModuleComponentInfo* cp = gComponents, *end = cp + NUM_COMPONENTS; while (cp < end) { nsresult rv = aCompMgr->UnregisterComponentSpec(cp->mCID, aPath); if (NS_FAILED(rv)) { #ifdef DEBUG printf("nsParserModule: unable to unregister %s component => %x\n", cp->mDescription, rv); #endif } cp++; } return NS_OK; } NS_IMETHODIMP nsParserModule::CanUnload(nsIComponentManager *aCompMgr, PRBool *okToUnload) { if (!okToUnload) { return NS_ERROR_INVALID_POINTER; } *okToUnload = PR_FALSE; return NS_ERROR_FAILURE; } //---------------------------------------------------------------------- static nsParserModule *gModule = NULL; extern "C" NS_EXPORT nsresult NSGetModule(nsIComponentManager *servMgr, nsIFile* location, nsIModule** return_cobj) { nsresult rv = NS_OK; NS_ASSERTION(return_cobj, "Null argument"); NS_ASSERTION(gModule == NULL, "nsParserModule: Module already created."); // Create an initialize the layout module instance nsParserModule *m = new nsParserModule(); if (!m) { return NS_ERROR_OUT_OF_MEMORY; } // Increase refcnt and store away nsIModule interface to m in return_cobj rv = m->QueryInterface(NS_GET_IID(nsIModule), (void**)return_cobj); if (NS_FAILED(rv)) { delete m; m = nsnull; } gModule = m; // WARNING: Weak Reference return rv; } #ifdef XP_WIN32 //in addition to returning a version number for this module, //this also provides a convenient hook for the preloader //to keep (some if not all) of the module resident. extern "C" __declspec(dllexport) float GetVersionNumber(void) { return 1.0; } #endif