/* -*- 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): */ #ifndef nsIScriptNameSetRegistry_h__ #define nsIScriptNameSetRegistry_h__ #include "nscore.h" #include "nsString.h" #include "nsISupports.h" #define NS_ISCRIPTNAMESETREGISTRY_IID \ {0xa6cf90d9, 0x15b3, 0x11d2, \ {0x93, 0x2e, 0x00, 0x80, 0x5f, 0x8a, 0xdd, 0x32}} class nsIScriptContext; class nsIScriptExternalNameSet; /** * Interface used to add and remove name sets. These name sets * are asked to register themselves with a namespace registry * for every new script context. */ class nsIScriptNameSetRegistry : public nsISupports { public: NS_DEFINE_STATIC_IID_ACCESSOR(NS_ISCRIPTNAMESETREGISTRY_IID); /** * Add a new name set to the list. Each name set will be asked * to register itself with a namespace registry for each new * script context. * * @param aNameSet the name set to register * @result NS_OK if successful */ NS_IMETHOD AddExternalNameSet(nsIScriptExternalNameSet* aNameSet) = 0; /** * Remove a name set from the manager's list. * * @param aNameSet the name set to unregister. * @result NS_OK if successful */ NS_IMETHOD RemoveExternalNameSet(nsIScriptExternalNameSet* aNameSet) = 0; /** * Intialize classes associated with the name sets. * * @param aScriptContext the script context within which to initialize * @result NS_OK if successful */ NS_IMETHOD InitializeClasses(nsIScriptContext* aContext) = 0; /** * Populate the specified script context with all of the * name sets in the registry. Will generally be called when the * script context first needs to create a name space manager. * * @param aScriptContext the script context to populate * @result NS_OK if successful */ NS_IMETHOD PopulateNameSpace(nsIScriptContext* aContext) = 0; }; #endif /* nsIScriptNameSetRegistry_h__ */