Index: printing/printing_context_cairo.cc |
diff --git a/printing/printing_context_cairo.cc b/printing/printing_context_cairo.cc |
deleted file mode 100644 |
index 81d8d92cbae3ffcd8f2c4eb3dc22edb29c7a3081..0000000000000000000000000000000000000000 |
--- a/printing/printing_context_cairo.cc |
+++ /dev/null |
@@ -1,237 +0,0 @@ |
-// Copyright (c) 2011 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. |
- |
-#include "printing/printing_context_cairo.h" |
- |
-// TODO(abodenha@chromium.org) The number of #ifdefs here has gotten too |
-// large. Refactor this code into separate files for Linux and Chrome OS. |
- |
-#include "base/logging.h" |
-#include "base/values.h" |
-#include "printing/metafile.h" |
-#include "printing/print_job_constants.h" |
-#include "printing/units.h" |
- |
-#if defined(OS_CHROMEOS) |
-#include <unicode/ulocdata.h> |
-#include "printing/print_settings_initializer_gtk.h" |
-#else |
-#include <gtk/gtk.h> |
-#include <gtk/gtkprintunixdialog.h> |
-#include "printing/print_dialog_gtk_interface.h" |
-#endif // defined(OS_CHROMEOS) |
- |
-#if !defined(OS_CHROMEOS) |
-namespace { |
- // Function pointer for creating print dialogs. |callback| is only used when |
- // |show_dialog| is true. |
- static printing::PrintDialogGtkInterface* (*create_dialog_func_)( |
- printing::PrintingContextCairo* context) = NULL; |
-} // namespace |
-#endif // !defined(OS_CHROMEOS) |
- |
-namespace printing { |
- |
-// static |
-PrintingContext* PrintingContext::Create(const std::string& app_locale) { |
- return static_cast<PrintingContext*>(new PrintingContextCairo(app_locale)); |
-} |
- |
-PrintingContextCairo::PrintingContextCairo(const std::string& app_locale) |
-#if defined(OS_CHROMEOS) |
- : PrintingContext(app_locale) { |
-#else |
- : PrintingContext(app_locale), |
- print_dialog_(NULL) { |
-#endif |
-} |
- |
-PrintingContextCairo::~PrintingContextCairo() { |
- ReleaseContext(); |
- |
-#if !defined(OS_CHROMEOS) |
- if (print_dialog_) |
- print_dialog_->ReleaseDialog(); |
-#endif |
-} |
- |
-#if !defined(OS_CHROMEOS) |
-// static |
-void PrintingContextCairo::SetCreatePrintDialogFunction( |
- PrintDialogGtkInterface* (*create_dialog_func)( |
- PrintingContextCairo* context)) { |
- DCHECK(create_dialog_func); |
- DCHECK(!create_dialog_func_); |
- create_dialog_func_ = create_dialog_func; |
-} |
- |
-void PrintingContextCairo::PrintDocument(const Metafile* metafile) { |
- DCHECK(print_dialog_); |
- DCHECK(metafile); |
- print_dialog_->PrintDocument(metafile, document_name_); |
-} |
-#endif // !defined(OS_CHROMEOS) |
- |
-void PrintingContextCairo::AskUserForSettings( |
- gfx::NativeView parent_view, |
- int max_pages, |
- bool has_selection, |
- PrintSettingsCallback* callback) { |
-#if defined(OS_CHROMEOS) |
- callback->Run(OK); |
-#else |
- print_dialog_->ShowDialog(callback); |
-#endif // defined(OS_CHROMEOS) |
-} |
- |
-PrintingContext::Result PrintingContextCairo::UseDefaultSettings() { |
- DCHECK(!in_print_job_); |
- |
- ResetSettings(); |
-#if defined(OS_CHROMEOS) |
- // For Chrome OS use default values based on the app locale rather than rely |
- // on GTK. Note that relying on the app locale does not work well if it is |
- // different from the system locale, e.g. a user using Chinese ChromeOS in the |
- // US. Eventually we need to get the defaults from the printer. |
- // TODO(sanjeevr): We need a better feedback loop between the cloud print |
- // dialog and this code. |
- int dpi = 300; |
- gfx::Size physical_size_device_units; |
- gfx::Rect printable_area_device_units; |
- int32_t width = 0; |
- int32_t height = 0; |
- UErrorCode error = U_ZERO_ERROR; |
- ulocdata_getPaperSize(app_locale_.c_str(), &height, &width, &error); |
- if (error != U_ZERO_ERROR) { |
- // If the call failed, assume a paper size of 8.5 x 11 inches. |
- LOG(WARNING) << "ulocdata_getPaperSize failed, using 8.5 x 11, error: " |
- << error; |
- width = static_cast<int>(8.5 * dpi); |
- height = static_cast<int>(11 * dpi); |
- } else { |
- // ulocdata_getPaperSize returns the width and height in mm. |
- // Convert this to pixels based on the dpi. |
- width = static_cast<int>(ConvertUnitDouble(width, 25.4, 1.0) * dpi); |
- height = static_cast<int>(ConvertUnitDouble(height, 25.4, 1.0) * dpi); |
- } |
- |
- physical_size_device_units.SetSize(width, height); |
- printable_area_device_units.SetRect( |
- static_cast<int>(PrintSettingsInitializerGtk::kLeftMarginInInch * dpi), |
- static_cast<int>(PrintSettingsInitializerGtk::kTopMarginInInch * dpi), |
- width - (PrintSettingsInitializerGtk::kLeftMarginInInch + |
- PrintSettingsInitializerGtk::kRightMarginInInch) * dpi, |
- height - (PrintSettingsInitializerGtk::kTopMarginInInch + |
- PrintSettingsInitializerGtk::kBottomMarginInInch) * dpi); |
- |
- settings_.set_dpi(dpi); |
- settings_.SetPrinterPrintableArea(physical_size_device_units, |
- printable_area_device_units, |
- dpi); |
-#else |
- if (!print_dialog_) { |
- print_dialog_ = create_dialog_func_(this); |
- print_dialog_->AddRefToDialog(); |
- } |
- print_dialog_->UseDefaultSettings(); |
-#endif // defined(OS_CHROMEOS) |
- |
- return OK; |
-} |
- |
-PrintingContext::Result PrintingContextCairo::UpdatePrinterSettings( |
- const DictionaryValue& job_settings, const PageRanges& ranges) { |
-#if defined(OS_CHROMEOS) |
- bool landscape = false; |
- |
- if (!job_settings.GetBoolean(kSettingLandscape, &landscape)) |
- return OnError(); |
- |
- if (settings_.dpi() == 0) |
- UseDefaultSettings(); |
- |
- settings_.SetOrientation(landscape); |
- settings_.ranges = ranges; |
- |
- return OK; |
-#else |
- DCHECK(!in_print_job_); |
- |
- if (!print_dialog_) { |
- print_dialog_ = create_dialog_func_(this); |
- print_dialog_->AddRefToDialog(); |
- } |
- |
- if (!print_dialog_->UpdateSettings(job_settings, ranges, &settings_)) |
- return OnError(); |
- |
- return OK; |
-#endif |
-} |
- |
-PrintingContext::Result PrintingContextCairo::InitWithSettings( |
- const PrintSettings& settings) { |
- DCHECK(!in_print_job_); |
- |
- settings_ = settings; |
- |
- return OK; |
-} |
- |
-PrintingContext::Result PrintingContextCairo::NewDocument( |
- const string16& document_name) { |
- DCHECK(!in_print_job_); |
- in_print_job_ = true; |
- |
-#if !defined(OS_CHROMEOS) |
- document_name_ = document_name; |
-#endif // !defined(OS_CHROMEOS) |
- |
- return OK; |
-} |
- |
-PrintingContext::Result PrintingContextCairo::NewPage() { |
- if (abort_printing_) |
- return CANCEL; |
- DCHECK(in_print_job_); |
- |
- // Intentional No-op. |
- |
- return OK; |
-} |
- |
-PrintingContext::Result PrintingContextCairo::PageDone() { |
- if (abort_printing_) |
- return CANCEL; |
- DCHECK(in_print_job_); |
- |
- // Intentional No-op. |
- |
- return OK; |
-} |
- |
-PrintingContext::Result PrintingContextCairo::DocumentDone() { |
- if (abort_printing_) |
- return CANCEL; |
- DCHECK(in_print_job_); |
- |
- ResetSettings(); |
- return OK; |
-} |
- |
-void PrintingContextCairo::Cancel() { |
- abort_printing_ = true; |
- in_print_job_ = false; |
-} |
- |
-void PrintingContextCairo::ReleaseContext() { |
- // Intentional No-op. |
-} |
- |
-gfx::NativeDrawingContext PrintingContextCairo::context() const { |
- // Intentional No-op. |
- return NULL; |
-} |
- |
-} // namespace printing |