JavaDoc

git-svn-id: https://svn.apache.org/repos/asf/sling/trunk@1200288 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/src/main/java/org/apache/sling/commons/mime/MimeTypeService.java b/src/main/java/org/apache/sling/commons/mime/MimeTypeService.java
index 1d17c53..773934e 100644
--- a/src/main/java/org/apache/sling/commons/mime/MimeTypeService.java
+++ b/src/main/java/org/apache/sling/commons/mime/MimeTypeService.java
@@ -20,7 +20,9 @@
 import java.io.InputStream;
 
 /**
- * The <code>MimeTypeService</code> TODO
+ * The <code>MimeTypeService</code> defines the service applications can call to
+ * resolve file names to MIME types and derive default file name extensions from
+ * MIME types.
  * <p>
  * This interface is not intended to be implemented by bundles. It is
  * implemented by this bundle and may be used by client bundles.
@@ -43,17 +45,17 @@
 
     /**
      * Returns the primary name extension to which the given
-     * <code>mimeType</code> maps. The returned extension must map to the
-     * given <code>mimeType</code> when fed to the
-     * {@link #getMimeType(String)} method. In other words, the expression
+     * <code>mimeType</code> maps. The returned extension must map to the given
+     * <code>mimeType</code> when fed to the {@link #getMimeType(String)}
+     * method. In other words, the expression
      * <code>mimeType.equals(getMimeType(getExtension(mimeType)))</code> must
      * always be <code>true</code> for any non-<code>null</code> MIME type.
      * <p>
      * A MIME type may be mapped to multiple extensions (e.g.
-     * <code>text/plain</code> to <code>txt</code>, <code>log</code>,
-     * ...). This method is expected to returned one of those extensions. It is
-     * up to the implementation to select an appropriate extension if multiple
-     * mappings exist for a single MIME type.
+     * <code>text/plain</code> to <code>txt</code>, <code>log</code>, ...). This
+     * method is expected to returned one of those extensions. It is up to the
+     * implementation to select an appropriate extension if multiple mappings
+     * exist for a single MIME type.
      *
      * @param mimeType The MIME type whose primary extension is requested.
      * @return A extension which maps to the given MIME type or
@@ -62,7 +64,35 @@
      */
     String getExtension(String mimeType);
 
+    /**
+     * Dynamically register a new mime type with one or more file name
+     * extensions. The first of those extensions is assumed to be default file
+     * name extension.
+     * <p>
+     * This registration is dynamic and not persisted.
+     *
+     * @param mimeType The MIME type to register
+     * @param extensions One or more file name extensions (without leading dot)
+     *            to register for the MIME type.
+     */
     void registerMimeType(String mimeType, String... extensions);
 
+    /**
+     * Register MIME types stored in the given input stream formatted as a
+     * regular MIME type file format: One entry per line. Each entry consists of
+     * two or more whitespace delimited fields where the first field is the MIME
+     * type and the rest of the fields are the file extensions. The first of the
+     * extensions is considered the default extension. Empty lines and lines
+     * starting with a hash sign (<code>#</code>) are ignored.
+     * <p>
+     * The stream is assumed to contain string data encoded with "ISO-8859-1".
+     * <p>
+     * This method reads the stream until an <code>IOException</code> occurs or
+     * until it has been fully read. The stream is not closed, though, by this
+     * method.
+     *
+     * @param mimeTabStream The stream to read the MIME type mappings from
+     * @throws IOException If an error occurs reading from the stream
+     */
     void registerMimeType(InputStream mimeTabStream) throws IOException;
 }