1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164
/* * @(#)ReferenceUriSchemesSupported.java 1.10 05/11/17 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */ package javax.print.attribute.standard; import javax.print.attribute.EnumSyntax; import javax.print.attribute.Attribute; /** * Class ReferenceUriSchemesSupported is a printing attribute class * an enumeration, that indicates a "URI scheme," such as "http:" or "ftp:", * that a printer can use to retrieve print data stored at a URI location. * If a printer supports doc flavors with a print data representation class of * <CODE>"java.net.URL"</CODE>, the printer uses instances of class * ReferenceUriSchemesSupported to advertise the URI schemes it can accept. * The acceptable URI schemes are included as service attributes in the * lookup service; this lets clients search the * for printers that can get print data using a certain URI scheme. The * acceptable URI schemes can also be queried using the capability methods in * interface <code>PrintService</code>. However, * ReferenceUriSchemesSupported attributes are used solely for determining * acceptable URI schemes, they are never included in a doc's, * print request's, print job's, or print service's attribute set. * <P> * The Internet Assigned Numbers Authority maintains the * <A HREF="http://www.isi.edu/in-notes/iana/assignments/url-schemes">official * list of URI schemes</A>. * <p> * Class ReferenceUriSchemesSupported defines enumeration values for widely * used URI schemes. A printer that supports additional URI schemes * can define them in a subclass of class ReferenceUriSchemesSupported. * <P> * <B>IPP Compatibility:</B> The category name returned by * <CODE>getName()</CODE> is the IPP attribute name. The enumeration's * integer value is the IPP enum value. The <code>toString()</code> method * returns the IPP string representation of the attribute value. * <P> * * @author Alan Kaminsky */ public class ReferenceUriSchemesSupported extends EnumSyntax implements Attribute { private static final long serialVersionUID = -8989076942813442805L; /** * File Transfer Protocol (FTP). */ public static final ReferenceUriSchemesSupported FTP = new ReferenceUriSchemesSupported(0); /** * HyperText Transfer Protocol (HTTP). */ public static final ReferenceUriSchemesSupported HTTP = new ReferenceUriSchemesSupported(1); /** * Secure HyperText Transfer Protocol (HTTPS). */ public static final ReferenceUriSchemesSupported HTTPS = new ReferenceUriSchemesSupported(2); /** * Gopher Protocol. */ public static final ReferenceUriSchemesSupported GOPHER = new ReferenceUriSchemesSupported(3); /** * USENET news. */ public static final ReferenceUriSchemesSupported NEWS = new ReferenceUriSchemesSupported(4); /** * USENET news using Network News Transfer Protocol (NNTP). */ public static final ReferenceUriSchemesSupported NNTP = new ReferenceUriSchemesSupported(5); /** * Wide Area Information Server (WAIS) protocol. */ public static final ReferenceUriSchemesSupported WAIS = new ReferenceUriSchemesSupported(6); /** * Host-specific file names. */ public static final ReferenceUriSchemesSupported FILE = new ReferenceUriSchemesSupported(7); /** * Construct a new reference URI scheme enumeration value with the given * integer value. * * @param value Integer value. */ protected ReferenceUriSchemesSupported(int value) { super (value); } private static final String[] myStringTable = { "ftp", "http", "https", "gopher", "news", "nntp", "wais", "file", }; private static final ReferenceUriSchemesSupported[] myEnumValueTable = { FTP, HTTP, HTTPS, GOPHER, NEWS, NNTP, WAIS, FILE, }; /** * Returns the string table for class ReferenceUriSchemesSupported. */ protected String[] getStringTable() { return (String[])myStringTable.clone(); } /** * Returns the enumeration value table for class * ReferenceUriSchemesSupported. */ protected EnumSyntax[] getEnumValueTable() { return (EnumSyntax[])myEnumValueTable.clone(); } /** * Get the printing attribute class which is to be used as the "category" * for this printing attribute value. * <P> * For class ReferenceUriSchemesSupported and any vendor-defined * subclasses, the category is class ReferenceUriSchemesSupported itself. * * @return Printing attribute class (category), an instance of class * {@link java.lang.Class java.lang.Class}. */ public final Class<? extends Attribute> getCategory() { return ReferenceUriSchemesSupported.class; } /** * Get the name of the category of which this attribute value is an * instance. * <P> * For class ReferenceUriSchemesSupported and any vendor-defined * subclasses, the category name is * <CODE>"reference-uri-schemes-supported"</CODE>. * * @return Attribute category name. */ public final String getName() { return "reference-uri-schemes-supported"; } }