org.apache.openejb.quartz.JobExecutionException Maven / Gradle / Ivy
/*
* Copyright 2001-2009 Terracotta, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy
* of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
*/
package org.quartz;
/**
* An exception that can be thrown by a {@link org.quartz.Job}
* to indicate to the Quartz {@link Scheduler}
that an error
* occurred while executing, and whether or not the Job
requests
* to be re-fired immediately (using the same {@link JobExecutionContext}
,
* or whether it wants to be unscheduled.
*
*
* Note that if the flag for 'refire immediately' is set, the flags for
* unscheduling the Job are ignored.
*
*
* @see Job
* @see JobExecutionContext
* @see SchedulerException
*
* @author James House
*/
public class JobExecutionException extends SchedulerException {
private static final long serialVersionUID = 1326342535829043325L;
/*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*
* Data members.
*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*/
private boolean refire = false;
private boolean unscheduleTrigg = false;
private boolean unscheduleAllTriggs = false;
/*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*
* Constructors.
*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*/
/**
*
* Create a JobExcecutionException, with the 're-fire immediately' flag set
* to false
.
*
*/
public JobExecutionException() {
}
/**
*
* Create a JobExcecutionException, with the given cause.
*
*/
public JobExecutionException(Throwable cause) {
super(cause);
}
/**
*
* Create a JobExcecutionException, with the given message.
*
*/
public JobExecutionException(String msg) {
super(msg);
}
/**
*
* Create a JobExcecutionException with the 're-fire immediately' flag set
* to the given value.
*
*/
public JobExecutionException(boolean refireImmediately) {
refire = refireImmediately;
}
/**
*
* Create a JobExcecutionException with the given underlying exception, and
* the 're-fire immediately' flag set to the given value.
*
*/
public JobExecutionException(Throwable cause, boolean refireImmediately) {
super(cause);
refire = refireImmediately;
}
/**
*
* Create a JobExcecutionException with the given message, and underlying
* exception.
*
*/
public JobExecutionException(String msg, Throwable cause) {
super(msg, cause);
}
/**
*
* Create a JobExcecutionException with the given message, and underlying
* exception, and the 're-fire immediately' flag set to the given value.
*
*/
public JobExecutionException(String msg, Throwable cause,
boolean refireImmediately) {
super(msg, cause);
refire = refireImmediately;
}
/**
* Create a JobExcecutionException with the given message and the 're-fire
* immediately' flag set to the given value.
*/
public JobExecutionException(String msg, boolean refireImmediately) {
super(msg);
refire = refireImmediately;
}
/*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*
* Interface.
*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*/
public void setRefireImmediately(boolean refire) {
this.refire = refire;
}
public boolean refireImmediately() {
return refire;
}
public void setUnscheduleFiringTrigger(boolean unscheduleTrigg) {
this.unscheduleTrigg = unscheduleTrigg;
}
public boolean unscheduleFiringTrigger() {
return unscheduleTrigg;
}
public void setUnscheduleAllTriggers(boolean unscheduleAllTriggs) {
this.unscheduleAllTriggs = unscheduleAllTriggs;
}
public boolean unscheduleAllTriggers() {
return unscheduleAllTriggs;
}
}