| Index: printing/pdf_ps_metafile_cairo.h
|
| diff --git a/printing/pdf_ps_metafile_cairo.h b/printing/pdf_ps_metafile_cairo.h
|
| index 0b7514a5f32b1d26fa731ea778f1fe886af0fd48..aff8332e2a5d87a4082e38c8591071d185fe83b7 100644
|
| --- a/printing/pdf_ps_metafile_cairo.h
|
| +++ b/printing/pdf_ps_metafile_cairo.h
|
| @@ -9,73 +9,45 @@
|
|
|
| #include "base/basictypes.h"
|
| #include "base/gtest_prod_util.h"
|
| -#include "printing/native_metafile_linux.h"
|
| +#include "printing/native_metafile.h"
|
|
|
| typedef struct _cairo_surface cairo_surface_t;
|
| -typedef struct _cairo cairo_t;
|
| -
|
| -namespace base {
|
| -struct FileDescriptor;
|
| -}
|
| -
|
| -class FilePath;
|
|
|
| namespace printing {
|
|
|
| -// This class uses Cairo graphics library to generate PostScript/PDF stream
|
| -// and stores rendering results in a string buffer.
|
| -class PdfPsMetafile : public NativeMetafile {
|
| +// This class uses Cairo graphics library to generate PDF stream and stores
|
| +// rendering results in a string buffer.
|
| +class PdfPsMetafile : public NativeMetafile {
|
| public:
|
| virtual ~PdfPsMetafile();
|
|
|
| - // Initializes to a fresh new metafile. Returns true on success.
|
| - // Note: Only call in the renderer to allocate rendering resources.
|
| + // NativeMetafile methods.
|
| 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_|.
|
| 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.
|
| - 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.
|
| - virtual cairo_t* StartPage(double width_in_points,
|
| - double height_in_points,
|
| + virtual cairo_t* StartPage(const gfx::Size& page_size,
|
| 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.
|
| virtual bool FinishPage();
|
| + virtual bool Close();
|
|
|
| - // Closes resulting PDF file. No further rendering is allowed.
|
| - virtual void Close();
|
| -
|
| - // Returns size of PDF contents stored in buffer |data_|.
|
| - // This function should ONLY be called after PDF file is closed.
|
| 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.
|
| 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.
|
| - virtual bool SaveTo(const base::FileDescriptor& fd) const;
|
| + virtual bool SaveTo(const FilePath& file_path) const;
|
| +
|
| + virtual gfx::Rect GetPageBounds(unsigned int page_number) const;
|
| + virtual unsigned int GetPageCount() const;
|
| +
|
| + virtual cairo_t* context() const {
|
| + return context_;
|
| + }
|
| +
|
| + virtual bool SetRawData(const void* src_buffer, uint32 src_buffer_size);
|
| +
|
| +#if defined(OS_CHROMEOS)
|
| + virtual bool SaveToFD(const base::FileDescriptor& fd) const;
|
| +#endif // if defined(OS_CHROMEOS)
|
|
|
| // Returns the PdfPsMetafile object that owns the given context. Returns NULL
|
| // if the context was not created by a PdfPsMetafile object.
|
|
|