Bug 275106 - Add JavaDoc comments to non-generated Java files. r=darin

This commit is contained in:
pedemont%us.ibm.com 2004-12-21 17:36:55 +00:00
Родитель 0102bb910a
Коммит 819d6c6d4e
4 изменённых файлов: 195 добавлений и 25 удалений

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

@ -39,8 +39,33 @@ package org.mozilla.xpcom;
import java.io.*; import java.io.*;
/**
* Used by XPCOM's Directory Service to get file locations.
*
* @see GeckoEmbed#initEmbedding
* @see XPCOM#initXPCOM
*/
public interface AppFileLocProvider { public interface AppFileLocProvider {
/**
* Directory Service calls this when it gets the first request for
* a prop or on every request if the prop is not persistent.
*
* @param prop the symbolic name of the file
* @param persistent an array of length one used to supply the output value: <ul>
* <li><code>true</code> - The returned file will be cached
* by Directory Service. Subsequent requests for this prop
* will bypass the provider and use the cache. </li>
* <li><code>false</code> - The provider will be asked for
* this prop each time it is requested. </li>
* </ul>
*
* @return the file represented by the property
*
* @see <a href="http://lxr.mozilla.org/mozilla/source/xpcom/io/nsDirectoryServiceDefs.h">
* Directory Service property names </a>
*/
public File getFile(String prop, boolean[] persistent); public File getFile(String prop, boolean[] persistent);
} }

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

@ -39,9 +39,44 @@ package org.mozilla.xpcom;
import java.io.*; import java.io.*;
/**
* Provides access to functions that are used to embed Mozilla's Gecko layer.
*/
public final class GeckoEmbed { public final class GeckoEmbed {
public static native void initEmbedding(File aMozBinDirectory, AppFileLocProvider aAppFileLocProvider); /**
public static native void termEmbedding(); * Initializes the Gecko embedding layer. You <i>must</i>
* call this method before proceeding to use Gecko. This function ensures
* XPCOM is started, creates the component registry if necessary and
* starts global services.
*
* @param aMozBinDirectory The Gecko directory containing the component
* registry and runtime libraries;
* or use <code>null</code> to use the working
* directory.
* @param aAppFileLocProvider The object to be used by Gecko that specifies
* to Gecko where to find profiles, the component
* registry preferences and so on; or use
* <code>null</code> for the default behaviour.
*
* @exception XPCOMException if a failure occurred during initialization
*/
public static native
void initEmbedding(File aMozBinDirectory,
AppFileLocProvider aAppFileLocProvider);
/**
* Terminates the Gecko embedding layer. Call this function during shutdown to
* ensure that global services are unloaded, files are closed and
* XPCOM is shutdown.
* <p>
* NOTE: Release any XPCOM objects within Gecko that you may be holding a
* reference to before calling this function.
* </p>
*
* @exception XPCOMException if a failure occurred during termination
*/
public static native
void termEmbedding();
} }

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

@ -41,19 +41,121 @@ import java.lang.reflect.*;
import java.io.*; import java.io.*;
/**
* Provides access to methods for initializing XPCOM, as well as helper methods
* for working with XPCOM classes.
*/
public final class XPCOM { public final class XPCOM {
public static native nsIServiceManager initXPCOM(File aMozBinDirectory, AppFileLocProvider aAppFileLocProvider); /**
public static native void shutdownXPCOM(nsIServiceManager aServMgr); * Initializes XPCOM. You must call this method before proceeding
public static native nsIServiceManager getServiceManager(); * to use XPCOM.
public static native nsIComponentManager getComponentManager(); *
public static native nsIComponentRegistrar getComponentRegistrar(); * @param aMozBinDirectory The directory containing the component
public static native nsILocalFile newLocalFile(String aPath, boolean followLinks); * registry and runtime libraries;
* or use <code>null</code> to use the working
* directory.
*
* @param aAppFileLocProvider The object to be used by Gecko that specifies
* to Gecko where to find profiles, the component
* registry preferences and so on; or use
* <code>null</code> for the default behaviour.
*
* @return the service manager
*
* @exception XPCOMException <ul>
* <li> NS_ERROR_NOT_INITIALIZED - if static globals were not initialied,
* which can happen if XPCOM is reloaded, but did not completly
* shutdown. </li>
* <li> Other error codes indicate a failure during initialisation. </li>
* </ul>
*/
public static native
nsIServiceManager initXPCOM(File aMozBinDirectory, AppFileLocProvider aAppFileLocProvider);
/**
* Shutdown XPCOM. You must call this method after you are finished
* using xpcom.
*
* @param aServMgr The service manager which was returned by initXPCOM.
* This will release servMgr.
*
* @exception XPCOMException if a failure occurred during termination
*/
public static native
void shutdownXPCOM(nsIServiceManager aServMgr);
/**
* Public Method to access to the service manager.
*
* @return the service manager
*
* @exception XPCOMException
*/
public static native
nsIServiceManager getServiceManager();
/**
* Public Method to access to the component manager.
*
* @return the component manager
*
* @exception XPCOMException
*/
public static native
nsIComponentManager getComponentManager();
/**
* Public Method to access to the component registration manager.
*
* @return the component registration manager
*
* @exception XPCOMException
*/
public static native
nsIComponentRegistrar getComponentRegistrar();
/**
* Public Method to create an instance of a nsILocalFile.
*
* @param aPath A string which specifies a full file path to a
* location. Relative paths will be treated as an
* error (NS_ERROR_FILE_UNRECOGNIZED_PATH).
* @param aFollowLinks This attribute will determine if the nsLocalFile will
* auto resolve symbolic links. By default, this value
* will be false on all non unix systems. On unix, this
* attribute is effectively a noop.
*
* @return an instance of an nsILocalFile that points to given path
*
* @exception XPCOMException <ul>
* <li> NS_ERROR_FILE_UNRECOGNIZED_PATH - raised for unrecognized paths
* or relative paths (must supply full file path) </li>
* </ul>
*/
public static native
nsILocalFile newLocalFile(String aPath, boolean aFollowLinks);
/* Utility functions */ /**
* If you create a class that implements nsISupports, you will need to provide
// Generic QueryInterface implementation * an implementation of the <code>queryInterface</code> method. This helper
* function provides a simple implementation. Therefore, if your class does
* not need to do anything special with <code>queryInterface</code>, your
* implementation would look like:
* <pre>
* public nsISupports queryInterface(String aIID) {
* return XPCOM.queryInterface(this, aIID);
* }
* </pre>
*
* @param aObject object to query
* @param aIID requested interface IID
*
* @return <code>aObject</code> if the given object supports that
* interface;
* <code>null</code> otherwise.
*/
public static nsISupports queryInterface(nsISupports aObject, String aIID) public static nsISupports queryInterface(nsISupports aObject, String aIID)
{ {
Class[] interfaces = aObject.getClass().getInterfaces(); Class[] interfaces = aObject.getClass().getInterfaces();
@ -64,8 +166,14 @@ public final class XPCOM {
return null; return null;
} }
// Given an interface, this will construct the name of the IID field (such as /**
// NS_ISUPPORTS_IID) and return its value. * Gets the interface IID for a particular Java interface. This is similar
* to NS_GET_IID in the C++ Mozilla files.
*
* @param aInterface interface which has defined an IID
*
* @return IID for given interface
*/
public static String getInterfaceIID(Class aInterface) public static String getInterfaceIID(Class aInterface)
{ {
// Get short class name (i.e. "bar", not "org.blah.foo.bar") // Get short class name (i.e. "bar", not "org.blah.foo.bar")
@ -90,7 +198,7 @@ public final class XPCOM {
iid = (String) iidField.get(null); iid = (String) iidField.get(null);
} catch (NoSuchFieldException e) { } catch (NoSuchFieldException e) {
// Class may implement non-Mozilla interfaces, which would not have an // Class may implement non-Mozilla interfaces, which would not have an
// IID method. In that case, just return an emptry string. // IID method. In that case, just return an empty string.
iid = ""; iid = "";
} catch (IllegalAccessException e) { } catch (IllegalAccessException e) {
// XXX Should be using a logging service, such as java.util.logging // XXX Should be using a logging service, such as java.util.logging

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

@ -37,26 +37,28 @@
package org.mozilla.xpcom; package org.mozilla.xpcom;
/**
* This exception is thrown whenever an internal XPCOM/Gecko error occurs.
* The internal Mozilla error ID is contained in the message.
*/
public final class XPCOMException extends RuntimeException { public final class XPCOMException extends RuntimeException {
/**
* Constructs a new XPCOMException instance.
*/
public XPCOMException() { public XPCOMException() {
super(); super();
} }
/**
* Constructs a new XPCOMException instance.
*
* @param message detailed message of exception
*/
public XPCOMException(String message) { public XPCOMException(String message) {
super(message); super(message);
} }
/* The RuntimeException constructors that take a Throwable parameter are only
available starting in Java 1.4. Commenting out for now to allow use by
Java 1.3
*/
/* public XPCOMException(String message, Throwable cause) {
super(message, cause);
}
public XPCOMException(Throwable cause) {
super(cause);
}*/
} }