// Copyright (c) 2010 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef PRINTING_PRINTING_CONTEXT_H_ #define PRINTING_PRINTING_CONTEXT_H_ #include "build/build_config.h" #if defined(OS_WIN) #include #include #endif #include #include "base/basictypes.h" #include "base/callback.h" #if !(defined(OS_WIN) || defined(OS_MACOSX)) // TODO(port) Remove after implementing PrintingContext::context() #include "base/logging.h" #endif #include "base/scoped_ptr.h" #include "base/string16.h" #include "gfx/native_widget_types.h" #include "printing/print_settings.h" #if defined(OS_MACOSX) #include "base/scoped_cftyperef.h" #ifdef __OBJC__ @class NSPrintInfo; #else class NSPrintInfo; #endif // __OBJC__ #endif // OS_MACOSX namespace printing { // Describe the user selected printing context for Windows. This includes the // OS-dependent UI to ask the user about the print settings. This class directly // talk to the printer and manages the document and pages breaks. class PrintingContext { public: // Tri-state result for user behavior-dependent functions. enum Result { OK, CANCEL, FAILED, }; PrintingContext(); ~PrintingContext(); // Callback of AskUserForSettings, used to notify the PrintJobWorker when // print settings are available. typedef Callback1::Type PrintSettingsCallback; // Asks the user what printer and format should be used to print. Updates the // context with the select device settings. The result of the call is returned // in the callback. This is necessary for Linux, which only has an // asynchronous printing API. void AskUserForSettings(gfx::NativeView parent_view, int max_pages, bool has_selection, PrintSettingsCallback* callback); #if defined(OS_WIN) && defined(UNIT_TEST) // Sets a fake PrintDlgEx function pointer in tests. void SetPrintDialog(HRESULT (__stdcall *print_dialog_func)(LPPRINTDLGEX)) { print_dialog_func_ = print_dialog_func; } #endif #if defined(OS_WIN) // Allocates the HDC for a specific DEVMODE. static bool AllocateContext(const std::wstring& printer_name, const DEVMODE* dev_mode, gfx::NativeDrawingContext* context); // Retrieves the content of a GetPrinter call. static void GetPrinterHelper(HANDLE printer, int level, scoped_array* buffer); #endif // Selects the user's default printer and format. Updates the context with the // default device settings. Result UseDefaultSettings(); void SetUseOverlays(bool use_overlays) { settings_.use_overlays = use_overlays; } // Initializes with predefined settings. Result InitWithSettings(const PrintSettings& settings); // Reinitializes the settings to uninitialized for object reuse. void ResetSettings(); // Does platform specific setup of the printer before the printing. Signal the // printer that a document is about to be spooled. // Warning: This function enters a message loop. That may cause side effects // like IPC message processing! Some printers have side-effects on this call // like virtual printers that ask the user for the path of the saved document; // for example a PDF printer. Result NewDocument(const string16& document_name); // Starts a new page. Result NewPage(); // Closes the printed page. Result PageDone(); // Closes the printing job. After this call the object is ready to start a new // document. Result DocumentDone(); // Cancels printing. Can be used in a multi-threaded context. Takes effect // immediately. void Cancel(); // Dismiss the Print... dialog box if shown. void DismissDialog(); gfx::NativeDrawingContext context() { #if defined(OS_WIN) || defined(OS_MACOSX) return context_; #else NOTIMPLEMENTED(); return NULL; #endif } const PrintSettings& settings() const { return settings_; } private: // Class that manages the PrintDlgEx() callbacks. This is meant to be a // temporary object used during the Print... dialog display. class CallbackHandler; // Does bookkeeping when an error occurs. PrintingContext::Result OnError(); #if defined(OS_WIN) // Used in response to the user canceling the printing. static BOOL CALLBACK AbortProc(HDC hdc, int nCode); // Reads the settings from the selected device context. Updates settings_ and // its margins. bool InitializeSettings(const DEVMODE& dev_mode, const std::wstring& new_device_name, const PRINTPAGERANGE* ranges, int number_ranges, bool selection_only); // Retrieves the printer's default low-level settings. On Windows, context_ is // allocated with this call. bool GetPrinterSettings(HANDLE printer, const std::wstring& device_name); // Parses the result of a PRINTDLGEX result. Result ParseDialogResultEx(const PRINTDLGEX& dialog_options); Result ParseDialogResult(const PRINTDLG& dialog_options); #elif defined(OS_MACOSX) // Read the settings from the given NSPrintInfo (and cache it for later use). void ParsePrintInfo(NSPrintInfo* print_info); #endif // On Windows, the selected printer context. // On Mac, the current page's context; only valid between NewPage and PageDone // call pairs. gfx::NativeDrawingContext context_; #if defined(OS_MACOSX) // The native print info object. NSPrintInfo* print_info_; #endif // Complete print context settings. PrintSettings settings_; #ifndef NDEBUG // Current page number in the print job. int page_number_; #endif #if defined(OS_WIN) // The dialog box for the time it is shown. volatile HWND dialog_box_; // Function pointer that defaults to PrintDlgEx. It can be changed using // SetPrintDialog() in tests. HRESULT (__stdcall *print_dialog_func_)(LPPRINTDLGEX); #endif // The dialog box has been dismissed. volatile bool dialog_box_dismissed_; // Is a print job being done. volatile bool in_print_job_; // Did the user cancel the print job. volatile bool abort_printing_; DISALLOW_COPY_AND_ASSIGN(PrintingContext); }; } // namespace printing #endif // PRINTING_PRINTING_CONTEXT_H_