All Downloads are FREE. Search and download functionalities are using the official Maven repository.

META-INF.modules.java.desktop.classes.javax.print.attribute.standard.JobImpressionsCompleted Maven / Gradle / Ivy

/*
 * Copyright (c) 2000, 2021, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code 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
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

package javax.print.attribute.standard;

import java.io.Serial;

import javax.print.attribute.Attribute;
import javax.print.attribute.IntegerSyntax;
import javax.print.attribute.PrintJobAttribute;

/**
 * Class {@code JobImpressionsCompleted} is an integer valued printing attribute
 * class that specifies the number of impressions completed for the job so far.
 * For printing devices, the impressions completed includes interpreting,
 * marking, and stacking the output.
 * 

* The {@code JobImpressionsCompleted} attribute describes the progress of the * job. This attribute is intended to be a counter. That is, the * {@code JobImpressionsCompleted} value for a job that has not started * processing must be 0. When the job's {@link JobState JobState} is * {@code PROCESSING} or {@code PROCESSING_STOPPED}, the * {@code JobImpressionsCompleted} value is intended to increase as the job is * processed; it indicates the amount of the job that has been processed at the * time the Print Job's attribute set is queried or at the time a print job * event is reported. When the job enters the {@code COMPLETED}, * {@code CANCELED}, or {@code ABORTED} states, the * {@code JobImpressionsCompleted} value is the final value for the job. *

* IPP Compatibility: The integer value gives the IPP integer value. The * category name returned by {@code getName()} gives the IPP attribute name. * * @author Alan Kaminsky * @see JobImpressions * @see JobImpressionsSupported * @see JobKOctetsProcessed * @see JobMediaSheetsCompleted */ public final class JobImpressionsCompleted extends IntegerSyntax implements PrintJobAttribute { /** * Use serialVersionUID from JDK 1.4 for interoperability. */ @Serial private static final long serialVersionUID = 6722648442432393294L; /** * Construct a new job impressions completed attribute with the given * integer value. * * @param value Integer value * @throws IllegalArgumentException if {@code value} is negative */ public JobImpressionsCompleted(int value) { super (value, 0, Integer.MAX_VALUE); } /** * Returns whether this job impressions completed attribute is equivalent tp * the passed in object. To be equivalent, all of the following conditions * must be true: *

    *
  1. {@code object} is not {@code null}. *
  2. {@code object} is an instance of class * {@code JobImpressionsCompleted}. *
  3. This job impressions completed attribute's value and * {@code object}'s value are equal. *
* * @param object {@code Object} to compare to * @return {@code true} if {@code object} is equivalent to this job * impressions completed attribute, {@code false} otherwise */ public boolean equals(Object object) { return(super.equals (object) && object instanceof JobImpressionsCompleted); } /** * Get the printing attribute class which is to be used as the "category" * for this printing attribute value. *

* For class {@code JobImpressionsCompleted}, the category is class * {@code JobImpressionsCompleted} itself. * * @return printing attribute class (category), an instance of class * {@link Class java.lang.Class} */ public final Class getCategory() { return JobImpressionsCompleted.class; } /** * Get the name of the category of which this attribute value is an * instance. *

* For class {@code JobImpressionsCompleted}, the category name is * {@code "job-impressions-completed"}. * * @return attribute category name */ public final String getName() { return "job-impressions-completed"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy