| // 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. |
| |
| #ifndef PRINTING_NATIVE_METAFILE_LINUX_H_ |
| #define PRINTING_NATIVE_METAFILE_LINUX_H_ |
| |
| #include "base/basictypes.h" |
| |
| typedef struct _cairo_surface cairo_surface_t; |
| typedef struct _cairo cairo_t; |
| |
| namespace base { |
| struct FileDescriptor; |
| } |
| |
| class FilePath; |
| |
| namespace printing { |
| |
| // This class is used to generate a PDF stream and to store rendering results |
| // in a string buffer. |
| class NativeMetafile { |
| public: |
| virtual ~NativeMetafile() {} |
| |
| // Initializes to a fresh new metafile. Returns true on success. |
| // Note: It should only be called from the renderer process to allocate |
| // rendering resources. |
| virtual bool Init() = 0; |
| |
| // 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: It should only be called from the browser process to initialize |
| // |data_|. |
| virtual bool Init(const void* src_buffer, uint32 src_buffer_size) = 0; |
| |
| // 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) = 0; |
| |
| // 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, |
| double margin_top_in_points, |
| double margin_right_in_points, |
| double margin_bottom_in_points, |
| double margin_left_in_points) = 0; |
| |
| // 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() = 0; |
| |
| // Closes resulting PDF file. No further rendering is allowed. |
| virtual void Close() = 0; |
| |
| // Returns size of PDF contents stored in buffer |data_|. |
| // This function should ONLY be called after PDF file is closed. |
| virtual uint32 GetDataSize() const = 0; |
| |
| // 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 = 0; |
| |
| // 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 = 0; |
| }; |
| |
| } // namespace printing |
| |
| #endif // PRINTING_NATIVE_METAFILE_LINUX_H_ |