001 /**
002 * ========================================
003 * JFreeReport : a free Java report library
004 * ========================================
005 *
006 * Project Info: http://reporting.pentaho.org/
007 *
008 * (C) Copyright 2000-2007, by Object Refinery Limited, Pentaho Corporation and Contributors.
009 *
010 * This library is free software; you can redistribute it and/or modify it under the terms
011 * of the GNU Lesser General Public License as published by the Free Software Foundation;
012 * either version 2.1 of the License, or (at your option) any later version.
013 *
014 * This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
015 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
016 * See the GNU Lesser General Public License for more details.
017 *
018 * You should have received a copy of the GNU Lesser General Public License along with this
019 * library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
020 * Boston, MA 02111-1307, USA.
021 *
022 * [Java is a trademark or registered trademark of Sun Microsystems, Inc.
023 * in the United States and other countries.]
024 *
025 * ------------
026 * $Id: PrintTask.java,v 1.6 2007/06/10 15:54:22 taqua Exp $
027 * ------------
028 * (C) Copyright 2000-2005, by Object Refinery Limited.
029 * (C) Copyright 2005-2007, by Pentaho Corporation.
030 */
031
032 package org.jfree.report.modules.gui.swing.printing;
033
034 import java.awt.print.PrinterException;
035
036 import org.jfree.report.flow.ReportJob;
037 import org.jfree.util.Log;
038
039 /**
040 * Creation-Date: Dec 3, 2006, 3:23:22 PM
041 *
042 * @author Thomas Morgner
043 */
044 public class PrintTask implements Runnable
045 {
046 private ReportJob job;
047
048 public PrintTask(ReportJob job)
049 {
050 this.job = job;
051 }
052
053 /**
054 * When an object implementing interface <code>Runnable</code> is used to
055 * create a thread, starting the thread causes the object's <code>run</code>
056 * method to be called in that separately executing thread.
057 * <p/>
058 * The general contract of the method <code>run</code> is that it may take any
059 * action whatsoever.
060 *
061 * @see Thread#run()
062 */
063 public void run()
064 {
065 try
066 {
067 PrinterUtility.print(job);
068 }
069 catch (PrinterException e)
070 {
071 Log.error ("Failed");
072 }
073 }
074 }