org.eclipse.core.resources.WorkspaceJob.java Source code

Java tutorial

Introduction

Here is the source code for org.eclipse.core.resources.WorkspaceJob.java

Source

/*******************************************************************************
 * Copyright (c) 2003, 2008 IBM Corporation and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM - Initial API and implementation
 *******************************************************************************/
package org.eclipse.core.resources;

import org.eclipse.core.internal.resources.InternalWorkspaceJob;
import org.eclipse.core.runtime.*;
import org.eclipse.core.runtime.jobs.ISchedulingRule;

/**
 * A job that makes an atomic modification to the workspace.  Clients must
 * implement the abstract method <code>runInWorkspace</code> instead
 * of the usual <code>Job.run</code> method.
 * <p>
 * After running a method that modifies resources in the workspace,
 * registered listeners receive after-the-fact notification of
 * what just transpired, in the form of a resource change event.
 * This method allows clients to call a number of
 * methods that modify resources and only have resource
 * change event notifications reported at the end of the entire
 * batch. This mechanism is used to avoid unnecessary builds 
 * and notifications.
 * </p>
 * <p>
 * Platform may decide to perform notifications during the operation.
 * The reason for this is that it is possible for multiple threads 
 * to be modifying the workspace concurrently. When one thread finishes modifying 
 * the workspace, a notification is required to prevent responsiveness problems, 
 * even if the other operation has not yet completed.
 * </p>
 * <p>
 * A WorkspaceJob is the asynchronous equivalent of IWorkspaceRunnable
 * </p>
 * <p>
 * Note that the workspace is not locked against other threads during the execution 
 * of a workspace job. Other threads can be modifying the workspace concurrently 
 * with a workspace job.  To obtain exclusive access to a portion of the workspace, 
 * set the scheduling rule on the job to be a resource scheduling rule.  The
 * interface <tt>IResourceRuleFactory</tt> is used to create a  scheduling rule 
 * for a particular workspace modification operation.
 * </p>
 * @see IWorkspaceRunnable
 * @see org.eclipse.core.resources.IResourceRuleFactory
 * @see IWorkspace#run(IWorkspaceRunnable, ISchedulingRule, int, IProgressMonitor)
 * @since 3.0
 */
public abstract class WorkspaceJob extends InternalWorkspaceJob {
    /**
     * Creates a new workspace job.
     * @param name the name of the job
     */
    public WorkspaceJob(String name) {
        super(name);
    }

    /**
     * Runs the operation, reporting progress to and accepting
     * cancelation requests from the given progress monitor.
     * <p>
     * Implementors of this method should check the progress monitor
     * for cancelation when it is safe and appropriate to do so.  The cancelation
     * request should be propagated to the caller by throwing 
     * <code>OperationCanceledException</code>.
     * </p>
     * 
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting and cancelation are not desired
     * @return the result of running the operation
     * @exception CoreException if this operation fails.
     */
    public abstract IStatus runInWorkspace(IProgressMonitor monitor) throws CoreException;
}