Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(178)

Unified Diff: printing/pdf_ps_metafile_cairo.h

Issue 6544028: Create a Factory for NativeMetafile. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: ARM compile failure fix Created 9 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « printing/pdf_metafile_mac_unittest.cc ('k') | printing/pdf_ps_metafile_cairo_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: printing/pdf_ps_metafile_cairo.h
diff --git a/printing/pdf_ps_metafile_cairo.h b/printing/pdf_ps_metafile_cairo.h
index 7274dd8c9ee4ed152fffad88fd55db610c463472..645a462b4e7fafe96e908699e0b6afccf657e69e 100644
--- a/printing/pdf_ps_metafile_cairo.h
+++ b/printing/pdf_ps_metafile_cairo.h
@@ -8,6 +8,8 @@
#include <string>
#include "base/basictypes.h"
+#include "base/gtest_prod_util.h"
+#include "printing/native_metafile_linux.h"
typedef struct _cairo_surface cairo_surface_t;
typedef struct _cairo cairo_t;
@@ -22,59 +24,58 @@ namespace printing {
// This class uses Cairo graphics library to generate PostScript/PDF stream
// and stores rendering results in a string buffer.
-class PdfPsMetafile {
+class PdfPsMetafile : public NativeMetafile {
public:
- PdfPsMetafile();
- ~PdfPsMetafile();
+ virtual ~PdfPsMetafile();
// Initializes to a fresh new metafile. Returns true on success.
// Note: Only call in the renderer to allocate rendering resources.
- bool Init();
+ virtual bool Init();
// Initializes a copy of metafile from PDF stream data.
// Returns true on success.
// |src_buffer| should point to the shared memory which stores PDF
// contents generated in the renderer.
// Note: Only call in the browser to initialize |data_|.
- bool Init(const void* src_buffer, uint32 src_buffer_size);
+ virtual bool Init(const void* src_buffer, uint32 src_buffer_size);
// Sets raw PDF data for the document. This is used when a cairo drawing
// surface has already been created. This method will cause all subsequent
// drawing on the surface to be discarded (in Close()). If Init() has not yet
// been called this method simply calls the second version of Init.
- bool SetRawData(const void* src_buffer, uint32 src_buffer_size);
+ virtual bool SetRawData(const void* src_buffer, uint32 src_buffer_size);
// Prepares a new cairo surface/context for rendering a new page.
// The unit is in point (=1/72 in).
// Returns NULL when failed.
- cairo_t* StartPage(double width_in_points,
- double height_in_points,
- double margin_top_in_points,
- double margin_right_in_points,
- double margin_bottom_in_points,
- double margin_left_in_points);
+ virtual cairo_t* StartPage(double width_in_points,
+ double height_in_points,
+ double margin_top_in_points,
+ double margin_right_in_points,
+ double margin_bottom_in_points,
+ double margin_left_in_points);
// Destroys the surface and the context used in rendering current page.
// The results of current page will be appended into buffer |data_|.
// Returns true on success.
- bool FinishPage();
+ virtual bool FinishPage();
// Closes resulting PDF file. No further rendering is allowed.
- void Close();
+ virtual void Close();
// Returns size of PDF contents stored in buffer |data_|.
// This function should ONLY be called after PDF file is closed.
- uint32 GetDataSize() const;
+ virtual uint32 GetDataSize() const;
// Copies PDF contents stored in buffer |data_| into |dst_buffer|.
// This function should ONLY be called after PDF file is closed.
// Returns true only when success.
- bool GetData(void* dst_buffer, uint32 dst_buffer_size) const;
+ virtual bool GetData(void* dst_buffer, uint32 dst_buffer_size) const;
// Saves PDF contents stored in buffer |data_| into the file
// associated with |fd|.
// This function should ONLY be called after PDF file is closed.
- bool SaveTo(const base::FileDescriptor& fd) const;
+ virtual bool SaveTo(const base::FileDescriptor& fd) const;
// The hardcoded margins, in points. These values are based on 72 dpi,
// with 0.25 margins on top, left, and right, and 0.56 on bottom.
@@ -87,7 +88,13 @@ class PdfPsMetafile {
// if the context was not created by a PdfPsMetafile object.
static PdfPsMetafile* FromCairoContext(cairo_t* context);
+ protected:
+ PdfPsMetafile();
+
private:
+ friend class NativeMetafileFactory;
+ FRIEND_TEST_ALL_PREFIXES(PdfPsTest, Pdf);
+
// Cleans up all resources.
void CleanUpAll();
« no previous file with comments | « printing/pdf_metafile_mac_unittest.cc ('k') | printing/pdf_ps_metafile_cairo_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698