1 /* 2 * Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26 package javax.print; 27 28 import javax.print.attribute.Attribute; 29 30 /** 31 * Interface {@code AttributeException} is a mixin interface which a subclass of 32 * {@link PrintException PrintException} can implement to report an error 33 * condition involving one or more printing attributes that a particular Print 34 * Service instance does not support. Either the attribute is not supported at 35 * all, or the attribute is supported but the particular specified value is not 36 * supported. The Print Service API does not define any print exception classes 37 * that implement interface {@code AttributeException}, that being left to the 38 * Print Service implementor's discretion. 39 */ 40 public interface AttributeException { 41 42 /** 43 * Returns the array of printing attribute classes for which the Print 44 * Service instance does not support the attribute at all, or {@code null} 45 * if there are no such attributes. The objects in the returned array are 46 * classes that extend the base interface {@link Attribute Attribute}. 47 * 48 * @return unsupported attribute classes 49 */ 50 public Class<?>[] getUnsupportedAttributes(); 51 52 /** 53 * Returns the array of printing attributes for which the Print Service 54 * instance supports the attribute but does not support that particular 55 * value of the attribute, or {@code null} if there are no such attribute 56 * values. 57 * 58 * @return unsupported attribute values 59 */ 60 public Attribute[] getUnsupportedValues(); 61 }