CLOSED TREE: TraceMonkey merge head. (a=blockers)
[mozilla-central.git] / layout / printing / nsPagePrintTimer.cpp
blobcb5aa63ec499550d6a8f1d68dca3ee620f1ca5fc
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
13 * License.
15 * The Original Code is mozilla.org code.
17 * The Initial Developer of the Original Code is
18 * Netscape Communications Corporation.
19 * Portions created by the Initial Developer are Copyright (C) 1998
20 * the Initial Developer. All Rights Reserved.
22 * Contributor(s):
24 * Alternatively, the contents of this file may be used under the terms of
25 * either of the GNU General Public License Version 2 or later (the "GPL"),
26 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 * in which case the provisions of the GPL or the LGPL are applicable instead
28 * of those above. If you wish to allow use of your version of this file only
29 * under the terms of either the GPL or the LGPL, and not to allow others to
30 * use your version of this file under the terms of the MPL, indicate your
31 * decision by deleting the provisions above and replace them with the notice
32 * and other provisions required by the GPL or the LGPL. If you do not delete
33 * the provisions above, a recipient may use your version of this file under
34 * the terms of any one of the MPL, the GPL or the LGPL.
36 * ***** END LICENSE BLOCK ***** */
38 #include "nsPagePrintTimer.h"
39 #include "nsIContentViewer.h"
40 #include "nsIServiceManager.h"
41 #include "nsPrintEngine.h"
43 NS_IMPL_ISUPPORTS1(nsPagePrintTimer, nsITimerCallback)
45 nsPagePrintTimer::nsPagePrintTimer() :
46 mPrintEngine(nsnull),
47 mDelay(0),
48 mFiringCount(0),
49 mPrintObj(nsnull)
53 nsPagePrintTimer::~nsPagePrintTimer()
55 // "Destroy" the document viewer; this normally doesn't actually
56 // destroy it because of the IncrementDestroyRefCount call below
57 // XXX This is messy; the document viewer should use a single approach
58 // to keep itself alive during printing
59 nsCOMPtr<nsIContentViewer> cv(do_QueryInterface(mDocViewerPrint));
60 if (cv) {
61 cv->Destroy();
65 nsresult
66 nsPagePrintTimer::StartTimer(PRBool aUseDelay)
68 nsresult result;
69 mTimer = do_CreateInstance("@mozilla.org/timer;1", &result);
70 if (NS_FAILED(result)) {
71 NS_WARNING("unable to start the timer");
72 } else {
73 PRUint32 delay = 0;
74 if (aUseDelay) {
75 if (mFiringCount < 10) {
76 // Longer delay for the few first pages.
77 delay = mDelay + ((10 - mFiringCount) * 100);
78 } else {
79 delay = mDelay;
82 mTimer->InitWithCallback(this, delay, nsITimer::TYPE_ONE_SHOT);
84 return result;
89 // nsITimerCallback
90 NS_IMETHODIMP
91 nsPagePrintTimer::Notify(nsITimer *timer)
93 if (mDocViewerPrint) {
94 PRPackedBool initNewTimer = PR_TRUE;
95 // Check to see if we are done
96 // inRange will be true if a page is actually printed
97 PRBool inRange;
98 // donePrinting will be true if it completed successfully or
99 // if the printing was cancelled
100 PRBool donePrinting = mPrintEngine->PrintPage(mPrintObj, inRange);
101 if (donePrinting) {
102 // now clean up print or print the next webshell
103 if (mPrintEngine->DonePrintingPages(mPrintObj, NS_OK)) {
104 initNewTimer = PR_FALSE;
108 // Note that the Stop() destroys this after the print job finishes
109 // (The PrintEngine stops holding a reference when DonePrintingPages
110 // returns true.)
111 Stop();
112 if (initNewTimer) {
113 ++mFiringCount;
114 nsresult result = StartTimer(inRange);
115 if (NS_FAILED(result)) {
116 donePrinting = PR_TRUE; // had a failure.. we are finished..
117 mPrintEngine->SetIsPrinting(PR_FALSE);
121 return NS_OK;
124 void
125 nsPagePrintTimer::Init(nsPrintEngine* aPrintEngine,
126 nsIDocumentViewerPrint* aDocViewerPrint,
127 PRUint32 aDelay)
129 mPrintEngine = aPrintEngine;
130 mDocViewerPrint = aDocViewerPrint;
131 mDelay = aDelay;
133 mDocViewerPrint->IncrementDestroyRefCount();
136 nsresult
137 nsPagePrintTimer::Start(nsPrintObject* aPO)
139 mPrintObj = aPO;
140 return StartTimer(PR_FALSE);
144 void
145 nsPagePrintTimer::Stop()
147 if (mTimer) {
148 mTimer->Cancel();
149 mTimer = nsnull;
153 nsresult NS_NewPagePrintTimer(nsPagePrintTimer **aResult)
156 NS_PRECONDITION(aResult, "null param");
158 nsPagePrintTimer* result = new nsPagePrintTimer;
160 if (!result) {
161 *aResult = nsnull;
162 return NS_ERROR_OUT_OF_MEMORY;
165 NS_ADDREF(result);
166 *aResult = result;
168 return NS_OK;