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
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.
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() :
52 nsPagePrintTimer::~nsPagePrintTimer()
54 // "Destroy" the document viewer; this normally doesn't actually
55 // destroy it because of the IncrementDestroyRefCount call below
56 // XXX This is messy; the document viewer should use a single approach
57 // to keep itself alive during printing
58 nsCOMPtr
<nsIContentViewer
> cv(do_QueryInterface(mDocViewerPrint
));
65 nsPagePrintTimer::StartTimer(PRBool aUseDelay
)
68 mTimer
= do_CreateInstance("@mozilla.org/timer;1", &result
);
69 if (NS_FAILED(result
)) {
70 NS_WARNING("unable to start the timer");
72 mTimer
->InitWithCallback(this, aUseDelay
?mDelay
:0, nsITimer::TYPE_ONE_SHOT
);
81 nsPagePrintTimer::Notify(nsITimer
*timer
)
83 if (mDocViewerPrint
) {
84 PRPackedBool initNewTimer
= PR_TRUE
;
85 // Check to see if we are done
86 // inRange will be true if a page is actually printed
88 // donePrinting will be true if it completed successfully or
89 // if the printing was cancelled
90 PRBool donePrinting
= mPrintEngine
->PrintPage(mPrintObj
, inRange
);
92 // now clean up print or print the next webshell
93 if (mPrintEngine
->DonePrintingPages(mPrintObj
, NS_OK
)) {
94 initNewTimer
= PR_FALSE
;
98 // Note that the Stop() destroys this after the print job finishes
99 // (The PrintEngine stops holding a reference when DonePrintingPages
103 nsresult result
= StartTimer(inRange
);
104 if (NS_FAILED(result
)) {
105 donePrinting
= PR_TRUE
; // had a failure.. we are finished..
106 mPrintEngine
->SetIsPrinting(PR_FALSE
);
114 nsPagePrintTimer::Init(nsPrintEngine
* aPrintEngine
,
115 nsIDocumentViewerPrint
* aDocViewerPrint
,
118 mPrintEngine
= aPrintEngine
;
119 mDocViewerPrint
= aDocViewerPrint
;
122 mDocViewerPrint
->IncrementDestroyRefCount();
126 nsPagePrintTimer::Start(nsPrintObject
* aPO
)
129 return StartTimer(PR_FALSE
);
134 nsPagePrintTimer::Stop()
142 nsresult
NS_NewPagePrintTimer(nsPagePrintTimer
**aResult
)
145 NS_PRECONDITION(aResult
, "null param");
147 nsPagePrintTimer
* result
= new nsPagePrintTimer
;
151 return NS_ERROR_OUT_OF_MEMORY
;