org.quartz.impl.StdJobRunShellFactory Maven / Gradle / Ivy
/* * Copyright 2004-2005 OpenSymphony * * 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. * */ /* * Previously Copyright (c) 2001-2004 James House */ package org.quartz.impl; import org.quartz.Scheduler; import org.quartz.SchedulerException; import org.quartz.core.JobRunShell; import org.quartz.core.JobRunShellFactory; import org.quartz.core.SchedulingContext; /** *
instance. * * ** Responsible for creating the instances of
{@link org.quartz.core.JobRunShell}
* to be used within the{@link org.quartz.core.QuartzScheduler} * * This implementation does not re-use any objects, it simply makes a new * JobRunShell each time
* * @author James House */ public class StdJobRunShellFactory implements JobRunShellFactory { /* * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Data members. * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ private Scheduler scheduler; private SchedulingContext schedCtxt; /* * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Interface. * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ /** *borrowJobRunShell()
is called. ** Initialize the factory, providing a handle to the
*/ public void initialize(Scheduler scheduler, SchedulingContext schedCtxt) { this.scheduler = scheduler; this.schedCtxt = schedCtxt; } /** *Scheduler
* that should be made available within theJobRunShell
and * theJobExecutionCOntext
s within it, and a handle to the *SchedulingContext
that the shell will use in its own * operations with theJobStore
. ** Called by the
*/ public JobRunShell borrowJobRunShell() throws SchedulerException { return new JobRunShell(this, scheduler, schedCtxt); } /** *{@link org.quartz.core.QuartzSchedulerThread} * to obtain instances of * {@link org.quartz.core.JobRunShell}
. ** Called by the
*/ public void returnJobRunShell(JobRunShell jobRunShell) { jobRunShell.passivate(); } }{@link org.quartz.core.QuartzSchedulerThread} * to return instances of * {@link org.quartz.core.JobRunShell}
. *