123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916 |
- /* DocFlavor.java --
- Copyright (C) 2004, 2006 Free Software Foundation, Inc.
- This file is part of GNU Classpath.
- GNU Classpath is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2, or (at your option)
- any later version.
- GNU Classpath is distributed in the hope that it will be useful, but
- WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with GNU Classpath; see the file COPYING. If not, write to the
- Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
- 02110-1301 USA.
- Linking this library statically or dynamically with other modules is
- making a combined work based on this library. Thus, the terms and
- conditions of the GNU General Public License cover the whole
- combination.
- As a special exception, the copyright holders of this library give you
- permission to link this library with independent modules to produce an
- executable, regardless of the license terms of these independent
- modules, and to copy and distribute the resulting executable under
- terms of your choice, provided that you also meet, for each linked
- independent module, the terms and conditions of the license of that
- module. An independent module is a module which is not derived from
- or based on this library. If you modify this library, you may extend
- this exception to your version of the library, but you are not
- obligated to do so. If you do not wish to do so, delete this
- exception statement from your version. */
- package javax.print;
- import java.io.IOException;
- import java.io.ObjectInputStream;
- import java.io.Serializable;
- import java.io.StreamTokenizer;
- import java.io.StringReader;
- import java.nio.charset.Charset;
- import java.util.Iterator;
- import java.util.Map;
- import java.util.TreeMap;
- /**
- * <code>DocFlavor</code> provides a description of the format in which the
- * print data will be supplied in a print job to the print service.
- * <p>
- * A doc flavor consists of two parts:
- * <ul>
- * <li>
- * The MIME type (Multipurpose Internet Mail Extensions types as described
- * in RFC 2045/2046) specifying the media format of the print data.
- * </li><li>
- * The representation class name which is the fully qualified name of the
- * class providing the print data to the print job. For example if the print
- * data is supplied as a byte array the representation class name will be
- * <code>"[B"</code> or for an input stream <code>"java.io.InputStream"</code>.
- * </li>
- * </ul>
- * The <code>DocFlavor</code> class is therefore used in several places in the
- * Java Print Service API. A print service provides its supported document
- * flavors as an array of DocFlavor objects and a print job gets the flavor of
- * its data to print from the <code>Doc</code> object provided as a DocFlavor
- * instance.
- * </p>
- * <p>
- * It has to be differentiated between <b>client formatted</b> and <b>service
- * formatted</b> print data. Client formatted print data is already provided
- * formatted by the client e.g. in an image format or as postscript. For
- * service formatted print data, the Java Print Service instance produces
- * the formatted print data. Here the doc flavor's representation class name
- * does specify an interface instead of the actual print data source. The
- * print service will call the methods of the given implementation of this
- * interface with a special Graphics object capable of producing formatted
- * print data from the graphics routines inside the interface methods.
- * </p>
- * <p>
- * <h3>Client formatted print data document flavors</h3>
- * The print service uses the representation class of the doc flavor to know
- * how to retrieve the print data. If the representation class is a
- * <code>URL</code> it will open the URL to read the print data from it. If it is
- * a <code>byte[]</code> it will directly use the array and send it to the
- * printer. There are predefined doc flavor as inner class for the most common
- * representation class types:
- * <ul>
- * <li>Character arrays (<code>char[]</code>): The characters of the array
- * represent the print data.</li>
- * <li>Character streams (<code>java.io.Reader</code>): The whole characters
- * read from the stream represent the print data.</li>
- * <li>String (<code>java.lang.String</code>): The characters of the String
- * represent the print data.</li>
- * <li>Byte arrays (<code>byte[]</code>): The bytes of the array represent the
- * print data. Encoding if text content is given in the mime type.</li>
- * <li>Byte streams (<code>java.io.InputStream</code>): The whole bytes read
- * from the stream represent the print data. If text content the encoding is
- * specified in the mime type.</li>
- * <li>Uniform Resource Locator (<code>java.net.URL</code>): The bytes read
- * from the stream through opening of the URL represent the print data.
- * If text content the encoding is specified in the mime type.</li></li>
- * </ul>
- * </p>
- * <p>
- * <h3>Service formatted print data document flavors</h3>
- * The print service uses the provided object implementing the interface
- * specified by the representation class to produce the formatted print data.
- * The mime type of service formatted data is always
- * <code>"application/x-java-jvm-local-objectref"</code> to signal the local
- * reference to the print data object implementing the interface. Predefined
- * doc flavor classes exist as an inner class for the three available interface
- * to produce print data:
- * <ul>
- * <li>Pageable object (<code>java.awt.print.Pageable</code>): A pageable object
- * is supplied to the print service. The print service will call the methods of
- * the interface with a Grahics object to produce the formatted print data.</li>
- * <li>Printable object (<code>java.awt.print.Printable</code>): A printable object
- * is supplied to the print service. The print service will call the methods of
- * the interface with a Grahics object to produce the formatted print data.</li>
- * <li>Renderable Image object
- * (<code>java.awt.image.renderable.RenderableImage</code>): A renderable image
- * object is supplied to the print service. The print service calls methods of
- * this interface to obtain the image to be printed.</li>
- * </ul>
- * </p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- * @author Wolfgang Baer (WBaer@gmx.de)
- */
- public class DocFlavor implements Cloneable, Serializable
- {
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which use a byte array for the print data representation.
- * <p>All the defined doc flavors have a print data representation
- * classname of "[B" (byte array).</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class BYTE_ARRAY
- extends DocFlavor
- {
- private static final long serialVersionUID = -9065578006593857475L;
- /**
- * Byte array doc flavor with a MIME Type of "application/octet-stream".
- */
- public static final BYTE_ARRAY AUTOSENSE = new BYTE_ARRAY("application/octet-stream");
- /**
- * Byte array doc flavor with a MIME Type of "image/gif".
- */
- public static final BYTE_ARRAY GIF = new BYTE_ARRAY("image/gif");
- /**
- * Byte array doc flavor with a MIME Type of "image/jpeg".
- */
- public static final BYTE_ARRAY JPEG = new BYTE_ARRAY("image/jpeg");
- /**
- * Byte array doc flavor with a MIME Type of "application/vnd.hp-PCL".
- */
- public static final BYTE_ARRAY PCL = new BYTE_ARRAY("application/vnd.hp-PCL");
- /**
- * Byte array doc flavor with a MIME Type of "application/pdf".
- */
- public static final BYTE_ARRAY PDF = new BYTE_ARRAY("application/pdf");
- /**
- * Byte array doc flavor with a MIME Type of "image/png".
- */
- public static final BYTE_ARRAY PNG = new BYTE_ARRAY("image/png");
- /**
- * Byte array doc flavor with a MIME Type of "application/postscript".
- */
- public static final BYTE_ARRAY POSTSCRIPT = new BYTE_ARRAY("application/postscript");
- /**
- * Byte array doc flavor with a MIME Type of "text/html" in the host encoding.
- */
- public static final BYTE_ARRAY TEXT_HTML_HOST = new BYTE_ARRAY("text/html; charset=" + hostEncoding);
- /**
- * Byte array doc flavor with a MIME Type of "text/html; charset=us-ascii".
- */
- public static final BYTE_ARRAY TEXT_HTML_US_ASCII = new BYTE_ARRAY("text/html; charset=us-ascii");
- /**
- * Byte array doc flavor with a MIME Type of "text/html; charset=utf-16".
- */
- public static final BYTE_ARRAY TEXT_HTML_UTF_16 = new BYTE_ARRAY("text/html; charset=utf-16");
- /**
- * Byte array doc flavor with a MIME Type of "text/html; charset=utf-16be".
- */
- public static final BYTE_ARRAY TEXT_HTML_UTF_16BE = new BYTE_ARRAY("text/html; charset=utf-16be");
- /**
- * Byte array doc flavor with a MIME Type of "text/html; charset=utf-16le".
- */
- public static final BYTE_ARRAY TEXT_HTML_UTF_16LE = new BYTE_ARRAY("text/html; charset=utf-16le");
- /**
- * Byte array doc flavor with a MIME Type of "text/html; charset=utf-8".
- */
- public static final BYTE_ARRAY TEXT_HTML_UTF_8 = new BYTE_ARRAY("text/html; charset=utf-8");
- /**
- * Byte array doc flavor with a MIME Type of "text/plain" in the host encoding.
- */
- public static final BYTE_ARRAY TEXT_PLAIN_HOST = new BYTE_ARRAY("text/plain; charset=" + hostEncoding);
- /**
- * Byte array doc flavor with a MIME Type of "text/plain; charset=us-ascii".
- */
- public static final BYTE_ARRAY TEXT_PLAIN_US_ASCII = new BYTE_ARRAY("text/plain; charset=us-ascii");
- /**
- * Byte array doc flavor with a MIME Type of "text/plain; charset=utf-16".
- */
- public static final BYTE_ARRAY TEXT_PLAIN_UTF_16 = new BYTE_ARRAY("text/plain; charset=utf-16");
- /**
- * Byte array doc flavor with a MIME Type of "text/plain; charset=utf-16be".
- */
- public static final BYTE_ARRAY TEXT_PLAIN_UTF_16BE = new BYTE_ARRAY("text/plain; charset=utf-16be");
- /**
- * Byte array doc flavor with a MIME Type of "text/plain; charset=utf-16le".
- */
- public static final BYTE_ARRAY TEXT_PLAIN_UTF_16LE = new BYTE_ARRAY("text/plain; charset=utf-16le");
- /**
- * Byte array doc flavor with a MIME Type of "text/plain; charset=utf-8".
- */
- public static final BYTE_ARRAY TEXT_PLAIN_UTF_8 = new BYTE_ARRAY("text/plain; charset=utf-8");
- /**
- * Constructor for doc flavor objects with the given MIME type
- * and a print data representation class name of "[B".
- *
- * @param mimeType the mime type string
- *
- * @throws NullPointerException if mimeType is <code>null</code>.
- * @throws IllegalArgumentException if mimeType has the wrong syntax.
- */
- public BYTE_ARRAY(String mimeType)
- {
- super(mimeType, "[B");
- }
- }
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which use a char array for the print data representation.
- * <p>All the defined doc flavors have a print data representation
- * classname of "[C" (char array).</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class CHAR_ARRAY
- extends DocFlavor
- {
- private static final long serialVersionUID = -8720590903724405128L;
- /**
- * Char array doc flavor with a MIME Type of "text/html; charset=utf-16".
- */
- public static final DocFlavor.CHAR_ARRAY TEXT_HTML = new CHAR_ARRAY("text/html; charset=utf-16");
- /**
- * Char array doc flavor with a MIME Type of "text/plain; charset=utf-16".
- */
- public static final DocFlavor.CHAR_ARRAY TEXT_PLAIN = new CHAR_ARRAY("text/plain; charset=utf-16");
- /**
- * Constructor for doc flavor objects with the given MIME type
- * and a print data representation class name of "[C".
- *
- * @param mimeType the mime type string
- *
- * @throws NullPointerException if mimeType is <code>null</code>.
- * @throws IllegalArgumentException if mimeType has the wrong syntax.
- */
- public CHAR_ARRAY(String mimeType)
- {
- super(mimeType, "[C");
- }
- }
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which use an InputStream to retrieve the print data.
- * <p>All the defined doc flavors have a print data representation
- * classname of "java.io.InputStream".</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class INPUT_STREAM
- extends DocFlavor
- {
- private static final long serialVersionUID = -7045842700749194127L;
- /**
- * InputStream doc flavor with a MIME Type of "application/octet-stream".
- */
- public static final INPUT_STREAM AUTOSENSE = new INPUT_STREAM("application/octet-stream");
- /**
- * InputStream doc flavor with a MIME Type of "image/gif".
- */
- public static final INPUT_STREAM GIF = new INPUT_STREAM("image/gif");
- /**
- * InputStream doc flavor with a MIME Type of "image/jpeg".
- */
- public static final INPUT_STREAM JPEG = new INPUT_STREAM("image/jpeg");
- /**
- * InputStream doc flavor with a MIME Type of "application/vnd.hp-PCL".
- */
- public static final INPUT_STREAM PCL = new INPUT_STREAM("application/vnd.hp-PCL");
- /**
- * InputStream doc flavor with a MIME Type of "application/pdf".
- */
- public static final INPUT_STREAM PDF = new INPUT_STREAM("application/pdf");
- /**
- * InputStream doc flavor with a MIME Type of "image/png".
- */
- public static final INPUT_STREAM PNG = new INPUT_STREAM("image/png");
- /**
- * InputStream doc flavor with a MIME Type of "application/postscript".
- */
- public static final INPUT_STREAM POSTSCRIPT = new INPUT_STREAM("application/postscript");
- /**
- * InputStream doc flavor with a MIME Type of "text/html" in the host encoding.
- */
- public static final INPUT_STREAM TEXT_HTML_HOST = new INPUT_STREAM("text/html; charset=" + hostEncoding);
- /**
- * InputStream doc flavor with a MIME Type of "text/html; charset=us-ascii".
- */
- public static final INPUT_STREAM TEXT_HTML_US_ASCII = new INPUT_STREAM("text/html; charset=us-ascii");
- /**
- * InputStream doc flavor with a MIME Type of "text/html; charset=utf-16".
- */
- public static final INPUT_STREAM TEXT_HTML_UTF_16 = new INPUT_STREAM("text/html; charset=utf-16");
- /**
- * InputStream doc flavor with a MIME Type of "text/html; charset=utf-16be".
- */
- public static final INPUT_STREAM TEXT_HTML_UTF_16BE = new INPUT_STREAM("text/html; charset=utf-16be");
- /**
- * InputStream doc flavor with a MIME Type of "text/html; charset=utf-16le".
- */
- public static final INPUT_STREAM TEXT_HTML_UTF_16LE = new INPUT_STREAM("text/html; charset=utf-16le");
- /**
- * InputStream doc flavor with a MIME Type of "text/html; charset=utf-8".
- */
- public static final INPUT_STREAM TEXT_HTML_UTF_8 = new INPUT_STREAM("text/html; charset=utf-8");
- /**
- * InputStream doc flavor with a MIME Type of "text/plain" in the host encoding.
- */
- public static final INPUT_STREAM TEXT_PLAIN_HOST = new INPUT_STREAM("text/plain; charset=" + hostEncoding);
- /**
- * InputStream doc flavor with a MIME Type of "text/plain; charset=us-ascii".
- */
- public static final INPUT_STREAM TEXT_PLAIN_US_ASCII = new INPUT_STREAM("text/plain; charset=us-ascii");
- /**
- * InputStream doc flavor with a MIME Type of "text/plain; charset=utf-16".
- */
- public static final INPUT_STREAM TEXT_PLAIN_UTF_16 = new INPUT_STREAM("text/plain; charset=utf-16");
- /**
- * InputStream doc flavor with a MIME Type of "text/plain; charset=utf-16be".
- */
- public static final INPUT_STREAM TEXT_PLAIN_UTF_16BE = new INPUT_STREAM("text/plain; charset=utf-16be");
- /**
- * InputStream doc flavor with a MIME Type of "text/plain; charset=utf-16le".
- */
- public static final INPUT_STREAM TEXT_PLAIN_UTF_16LE = new INPUT_STREAM("text/plain; charset=utf-16le");
- /**
- * InputStream doc flavor with a MIME Type of "text/plain; charset=utf-8".
- */
- public static final INPUT_STREAM TEXT_PLAIN_UTF_8 = new INPUT_STREAM("text/plain; charset=utf-8");
- /**
- * Constructor for doc flavor objects with the given MIME type
- * and a print data representation class name of "java.io.InputStream".
- *
- * @param mimeType the mime type string
- *
- * @throws NullPointerException if mimeType is <code>null</code>.
- * @throws IllegalArgumentException if mimeType has the wrong syntax.
- */
- public INPUT_STREAM(String mimeType)
- {
- super(mimeType, "java.io.InputStream");
- }
- }
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which use an Reader to retrieve the print data.
- * <p>All the defined doc flavors have a print data representation
- * classname of "java.io.Reader".</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class READER
- extends DocFlavor
- {
- private static final long serialVersionUID = 7100295812579351567L;
- /**
- * Reader doc flavor with a MIME Type of "text/html; charset=utf-16".
- */
- public static final DocFlavor.READER TEXT_HTML = new READER("text/html; charset=utf-16");
- /**
- * Reader doc flavor with a MIME Type of "text/plain; charset=utf-16".
- */
- public static final DocFlavor.READER TEXT_PLAIN = new READER("text/plain; charset=utf-16");
- /**
- * Constructor for doc flavor objects with the given MIME type
- * and a print data representation class name of "java.io.Reader".
- *
- * @param mimeType the mime type string
- *
- * @throws NullPointerException if mimeType is <code>null</code>.
- * @throws IllegalArgumentException if mimeType has the wrong syntax.
- */
- public READER(String mimeType)
- {
- super(mimeType, "java.io.Reader");
- }
- }
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which use service formatted print data.
- * <p>All the defined doc flavors have a MIME type of
- * "application/x-java-jvm-local-objectref".</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class SERVICE_FORMATTED
- extends DocFlavor
- {
- private static final long serialVersionUID = 6181337766266637256L;
- /**
- * Service formatted doc flavor with a representation class of
- * "java.awt.print.Pageable".
- */
- public static final DocFlavor.SERVICE_FORMATTED PAGEABLE = new SERVICE_FORMATTED("java.awt.print.Pageable");
- /**
- * Service formatted doc flavor with a representation class of
- * "java.awt.print.Printable".
- */
- public static final DocFlavor.SERVICE_FORMATTED PRINTABLE = new SERVICE_FORMATTED("java.awt.print.Printable");
- /**
- * Service formatted doc flavor with a representation class of
- * "java.awt.image.renderable.RenderableImage".
- */
- public static final DocFlavor.SERVICE_FORMATTED RENDERABLE_IMAGE = new SERVICE_FORMATTED("java.awt.image.renderable.RenderableImage");
- /**
- * Constructor for doc flavor objects with a MIME type of
- * "application/x-java-jvm-local-objectref" and the given
- * print data representation classname.
- *
- * @param className the representation classname
- *
- * @throws NullPointerException if className is <code>null</code>.
- */
- public SERVICE_FORMATTED(String className)
- {
- super("application/x-java-jvm-local-objectref", className);
- }
- }
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which use a String for the print data representation.
- * <p>All the defined doc flavors have a print data representation
- * classname of "java.lang.String".</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class STRING
- extends DocFlavor
- {
- private static final long serialVersionUID = 4414407504887034035L;
- /**
- * String doc flavor with a MIME Type of "text/html; charset=utf-16".
- */
- public static final DocFlavor.STRING TEXT_HTML = new STRING("text/html; charset=utf-16");
- /**
- * String doc flavor with a MIME Type of "text/plain; charset=utf-16".
- */
- public static final DocFlavor.STRING TEXT_PLAIN = new STRING("text/plain; charset=utf-16");
- /**
- * Constructor for doc flavor objects with the given MIME type
- * and a print data representation class name of "java.lang.String".
- *
- * @param mimeType the mime type string
- *
- * @throws NullPointerException if mimeType is <code>null</code>.
- * @throws IllegalArgumentException if mimeType has the wrong syntax.
- */
- public STRING(String mimeType)
- {
- super(mimeType, "java.lang.String");
- }
- }
- /**
- * Predefined static <code>DocFlavor</code> objects for document
- * types which have an URL where to retrieve the print data.
- * <p>All the defined doc flavors have a print data representation
- * classname of "java.net.URL".</p>
- *
- * @author Michael Koch (konqueror@gmx.de)
- */
- public static class URL
- extends DocFlavor
- {
- private static final long serialVersionUID = 2936725788144902062L;
- /**
- * URL doc flavor with a MIME Type of "application/octet-stream".
- */
- public static final DocFlavor.URL AUTOSENSE = new URL("application/octet-stream");
- /**
- * URL doc flavor with a MIME Type of "image/gif".
- */
- public static final DocFlavor.URL GIF = new URL("image/gif");
- /**
- * URL doc flavor with a MIME Type of "image/jpeg".
- */
- public static final DocFlavor.URL JPEG = new URL("image/jpeg");
- /**
- * URL doc flavor with a MIME Type of "application/vnd.hp-PCL".
- */
- public static final DocFlavor.URL PCL = new URL("application/vnd.hp-PCL");
- /**
- * URL doc flavor with a MIME Type of "application/pdf".
- */
- public static final DocFlavor.URL PDF = new URL("application/pdf");
- /**
- * URL doc flavor with a MIME Type of "image/png".
- */
- public static final DocFlavor.URL PNG = new URL("image/png");
- /**
- * URL doc flavor with a MIME Type of "application/postscript".
- */
- public static final DocFlavor.URL POSTSCRIPT = new URL("application/postscript");
- /**
- * URL doc flavor with a MIME Type of "text/html" in the host encoding.
- */
- public static final DocFlavor.URL TEXT_HTML_HOST = new URL("text/html; charset=" + hostEncoding);
- /**
- * URL doc flavor with a MIME Type of "text/html; charset=us-ascii".
- */
- public static final DocFlavor.URL TEXT_HTML_US_ASCII = new URL("text/html; charset=us-ascii");
- /**
- * URL doc flavor with a MIME Type of "text/html; charset=utf-16".
- */
- public static final DocFlavor.URL TEXT_HTML_UTF_16 = new URL("text/html; charset=utf-16");
- /**
- * URL doc flavor with a MIME Type of "text/html; charset=utf-16be".
- */
- public static final DocFlavor.URL TEXT_HTML_UTF_16BE = new URL("text/html; charset=utf-16be");
- /**
- * URL doc flavor with a MIME Type of "text/html; charset=utf-16le".
- */
- public static final DocFlavor.URL TEXT_HTML_UTF_16LE = new URL("text/html; charset=utf-16le");
- /**
- * URL doc flavor with a MIME Type of "text/html; charset=utf-8".
- */
- public static final DocFlavor.URL TEXT_HTML_UTF_8 = new URL("text/html; charset=utf-8");
- /**
- * URL doc flavor with a MIME Type of "text/plain" in the host encoding.
- */
- public static final DocFlavor.URL TEXT_PLAIN_HOST = new URL("text/plain; charset=" + hostEncoding);
- /**
- * URL doc flavor with a MIME Type of "text/plain; charset=us-ascii".
- */
- public static final DocFlavor.URL TEXT_PLAIN_US_ASCII = new URL("text/plain; charset=us-ascii");
- /**
- * URL doc flavor with a MIME Type of "text/plain; charset=utf-16".
- */
- public static final DocFlavor.URL TEXT_PLAIN_UTF_16 = new URL("text/plain; charset=utf-16");
- /**
- * URL doc flavor with a MIME Type of "text/plain; charset=utf-16be".
- */
- public static final DocFlavor.URL TEXT_PLAIN_UTF_16BE = new URL("text/plain; charset=utf-16be");
- /**
- * URL doc flavor with a MIME Type of "text/plain; charset=utf-16le".
- */
- public static final DocFlavor.URL TEXT_PLAIN_UTF_16LE = new URL("text/plain; charset=utf-16le");
- /**
- * URL doc flavor with a MIME Type of "text/plain; charset=utf-8".
- */
- public static final DocFlavor.URL TEXT_PLAIN_UTF_8 = new URL("text/plain; charset=utf-8");
- /**
- * Constructor for doc flavor objects with the given MIME type
- * and a print data representation class name of "java.net.URL".
- *
- * @param mimeType the mime type string
- *
- * @throws NullPointerException if mimeType is <code>null</code>.
- * @throws IllegalArgumentException if mimeType has the wrong syntax.
- */
- public URL(String mimeType)
- {
- super(mimeType, "java.net.URL");
- }
- }
- private static final long serialVersionUID = -4512080796965449721L;
- /**
- * The string representing the host encoding. This is the encoding
- * used in the predefined HOST doc flavors
- * (e.g. {@link BYTE_ARRAY#TEXT_HTML_HOST}).
- */
- public static final String hostEncoding = Charset.defaultCharset().name();
- private transient String mediaSubtype;
- private transient String mediaType;
- private transient TreeMap params;
- // name as defined in Serialized Form JDK 1.4
- private String myClassName;
- /**
- * Constructs a <code>DocFlavor</code> object with the given MIME type and
- * representation class name.
- *
- * @param mimeType the MIME type string.
- * @param className the fully-qualified name of the representation class.
- *
- * @throws NullPointerException if mimeType or className are <code>null</code>.
- * @throws IllegalArgumentException if given mimeType has syntax errors.
- */
- public DocFlavor(String mimeType, String className)
- {
- if (mimeType == null || className == null)
- throw new NullPointerException();
- params = new TreeMap();
- parseMimeType(mimeType);
- myClassName = className;
- }
- /**
- * Parses the given string as MIME type.
- * The mediatype, mediasubtype and all parameter/value
- * combinations are extracted, comments are dropped.
- *
- * @param mimeType the string to parse
- * @throws IllegalArgumentException if not conformant.
- */
- private void parseMimeType(String mimeType)
- {
- int MEDIA = 1;
- int MEDIASUB = 2;
- int PARAM_NAME = 3;
- int PARAM_VALUE = 4;
- int COMMENT_START = 5;
- int state = 0;
- int lastState = 0; // keeps track of state before comment
- int tok;
- try
- {
- String paramName = null;
- StreamTokenizer in = new StreamTokenizer(new StringReader(mimeType));
- in.resetSyntax();
- // Allowed characters are anything except:
- // SPACE, CTLs (= Unicode characters U+0000 - U+001F and U+007F)
- // and tspecials ( ) < > @ , ; : \ " / [ ] ? =
- in.whitespaceChars(0x00, 0x20);
- in.whitespaceChars(0x7F, 0x7F);
- in.wordChars('A', 'Z');
- in.wordChars('a', 'z');
- in.wordChars('0', '9');
- in.wordChars(0xA0, 0xFF);
- in.wordChars(0x21, 0x21);
- in.wordChars(0x23, 0x27);
- in.wordChars(0x2A, 0x2B);
- in.wordChars(0x2D, 0x2E);
- in.wordChars(0x5E, 0x60);
- in.wordChars(0x7B, 0x7E);
- in.quoteChar('"');
- while ((tok = in.nextToken()) != StreamTokenizer.TT_EOF)
- {
- switch (tok)
- {
- case StreamTokenizer.TT_WORD:
- if (state == 0)
- {
- mediaType = in.sval.toLowerCase();
- state = MEDIA;
- break;
- }
- if (state == MEDIA)
- {
- mediaSubtype = in.sval.toLowerCase();
- state = MEDIASUB;
- break;
- }
- // begin of parameters is either after mediasub or a parameter value
- if (state == MEDIASUB || state == PARAM_VALUE)
- {
- paramName = in.sval.toLowerCase();
- state = PARAM_NAME;
- break;
- }
- // a parameter always needs to follow a value
- if (state == PARAM_NAME)
- {
- String paramValue = in.sval;
- // if a charset param the value needs to be stored lowercase
- if (paramName.equals("charset"))
- paramValue = paramValue.toLowerCase();
- state = PARAM_VALUE;
- params.put(paramName, paramValue);
- break;
- }
- if (state == COMMENT_START)
- {
- // ignore;
- break;
- }
- break;
- case '/':
- // may only occur after the mediatype
- if (state != MEDIA)
- throw new IllegalArgumentException();
- break;
- case '=':
- // may only occur after a parameter
- if (state != PARAM_NAME)
- throw new IllegalArgumentException();
- break;
- case ';':
- // differentiates mime type and parameters/value combinations
- if (state != MEDIASUB && state != PARAM_VALUE)
- throw new IllegalArgumentException();
- break;
- case '(': // begin comment
- lastState = state;
- state = COMMENT_START;
- break;
- case ')': // end comment
- state = lastState;
- break;
- // a parameter always needs to follow a value / or quoted value
- case '"':
- if (state == PARAM_NAME)
- {
- String paramValue = in.sval;
- // if a charset param the value needs to be stored lowercase
- if (paramName.equals("charset"))
- paramValue = paramValue.toLowerCase();
- state = PARAM_VALUE;
- params.put(paramName, paramValue);
- break;
- }
- // only values may be quoted
- throw new IllegalArgumentException();
- default:
- // if any other char is observed its not allowed
- throw new IllegalArgumentException();
- }
- }
- }
- catch (IOException e)
- {
- // should not happen as mimetype str cannot be null
- throw new InternalError("IOException during parsing String " + mimeType);
- }
- }
- /**
- * Checks if this doc flavor object is equal to the given object.
- * <p>
- * Two doc flavor objects are considered equal if the provided object is not
- * <code>null</code> and an instance of <code>DocFlavor</code>. The MIME
- * types has to be equal in their media type, media subtype, their
- * paramter/value combinations and the representation classname.
- * </p>
- *
- * @param obj the object to test.
- * @return <code>true</code> if equal, <code>false</code> otherwise.
- */
- public boolean equals(Object obj)
- {
- if (! (obj instanceof DocFlavor))
- return false;
- DocFlavor tmp = (DocFlavor) obj;
- return (getMimeType().equals(tmp.getMimeType())
- && getRepresentationClassName().equals(tmp.getRepresentationClassName()));
- }
- /**
- * Returns the media subtype of this flavor object.
- * A mimetype of "text/html; charset=us-ascii" will
- * return "html" as the media subtype.
- *
- * @return The media subtype.
- */
- public String getMediaSubtype()
- {
- return mediaSubtype;
- }
- /**
- * Returns the media type of this flavor object.
- * A mimetype of "text/html; charset=us-ascii" will
- * return "text" as the media type.
- *
- * @return The media type.
- */
- public String getMediaType()
- {
- return mediaType;
- }
- /**
- * Returns the mime type of this flavor object.
- * The mimetype will have every parameter value
- * enclosed in quotes.
- *
- * @return The mime type.
- */
- public String getMimeType()
- {
- String mimeType = getMediaType() + "/" + getMediaSubtype();
- Iterator it = params.entrySet().iterator();
- while (it.hasNext())
- {
- Map.Entry entry = (Map.Entry) it.next();
- mimeType += "; " + entry.getKey() + "=\"" + entry.getValue() + "\"";
- }
- return mimeType;
- }
- /**
- * Returns the value for an optional parameter of the mime type of this
- * flavor object.
- *
- * @param paramName the name of the parameter
- * @return The value for the parameter, or <code>null</code> if none bound.
- * @throws NullPointerException if paramName is <code>null</code>.
- */
- public String getParameter(String paramName)
- {
- if (paramName == null)
- throw new NullPointerException();
- return (String) params.get(paramName.toLowerCase());
- }
- /**
- * Returns the name of the representation class of this flavor object.
- *
- * @return The representation classname.
- */
- public String getRepresentationClassName()
- {
- return myClassName;
- }
- /**
- * Returns a hash code for this doc flavor object.
- *
- * @return The hashcode.
- */
- public int hashCode()
- {
- return ((mediaType.hashCode()
- * mediaSubtype.hashCode()
- * myClassName.hashCode()) ^ params.hashCode());
- }
- /**
- * Returns a string representation of this doc flavor object.
- * The returned string is of the form
- * getMimeType() + "; class=\"" + getRepresentationClassName() + "\"";
- *
- * @return The constructed string representation.
- */
- public String toString()
- {
- return getMimeType() + "; class=\"" + getRepresentationClassName() + "\"";
- }
- // needs special treatment for serialization
- private void readObject(ObjectInputStream stream)
- throws IOException, ClassNotFoundException
- {
- params = new TreeMap();
- myClassName = (String) stream.readObject();
- parseMimeType((String) stream.readObject());
- }
- private void writeObject(java.io.ObjectOutputStream stream)
- throws IOException
- {
- stream.writeObject(myClassName);
- stream.writeObject(getMimeType());
- }
- }
|