blob: c7d806cf3f576c8750fbf68f7ccf7586eff23dc8 [file] [log] [blame]
license.botbf09a502008-08-24 00:55:551// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commit09911bf2008-07-26 23:55:294
[email protected]8ff1d422009-07-07 21:31:395#ifndef PRINTING_PRINTED_DOCUMENT_H_
6#define PRINTING_PRINTED_DOCUMENT_H_
initial.commit09911bf2008-07-26 23:55:297
8#include <map>
9
[email protected]b75dca82009-10-13 18:46:2110#include "app/gfx/native_widget_types.h"
initial.commit09911bf2008-07-26 23:55:2911#include "base/lock.h"
12#include "base/ref_counted.h"
13#include "base/scoped_ptr.h"
initial.commit09911bf2008-07-26 23:55:2914#include "googleurl/src/gurl.h"
[email protected]8ff1d422009-07-07 21:31:3915#include "printing/print_settings.h"
16#include "printing/native_metafile.h"
initial.commit09911bf2008-07-26 23:55:2917
initial.commit09911bf2008-07-26 23:55:2918class MessageLoop;
19
20namespace gfx {
[email protected]7322c4402009-05-15 02:16:1021class Font;
initial.commit09911bf2008-07-26 23:55:2922}
23
24namespace printing {
25
26class PrintedPage;
27class PrintedPagesSource;
28
[email protected]4ecd07452009-03-31 14:34:4329// A collection of rendered pages. The settings are immutable. If the print
initial.commit09911bf2008-07-26 23:55:2930// settings are changed, a new PrintedDocument must be created.
31// Warning: May be accessed from many threads at the same time. Only one thread
32// will have write access. Sensible functions are protected by a lock.
33// Warning: Once a page is loaded, it cannot be replaced. Pages may be discarded
34// under low memory conditions.
35class PrintedDocument : public base::RefCountedThreadSafe<PrintedDocument> {
36 public:
37 // The cookie shall be unique and has a specific relationship with its
38 // originating source and settings.
39 PrintedDocument(const PrintSettings& settings,
40 PrintedPagesSource* source,
41 int cookie);
initial.commit09911bf2008-07-26 23:55:2942
[email protected]0e0fca32009-07-06 15:25:5043 // Sets a page's data. 0-based. Takes metafile ownership.
initial.commit09911bf2008-07-26 23:55:2944 // Note: locks for a short amount of time.
[email protected]0e0fca32009-07-06 15:25:5045 void SetPage(int page_number, NativeMetafile* metafile, double shrink);
initial.commit09911bf2008-07-26 23:55:2946
47 // Retrieves a page. If the page is not available right now, it
48 // requests to have this page be rendered and returns false.
49 // Note: locks for a short amount of time.
50 bool GetPage(int page_number, scoped_refptr<PrintedPage>* page);
51
52 // Draws the page in the context.
53 // Note: locks for a short amount of time in debug only.
[email protected]b75dca82009-10-13 18:46:2154 void RenderPrintedPage(const PrintedPage& page,
55 gfx::NativeDrawingContext context) const;
initial.commit09911bf2008-07-26 23:55:2956
57 // Draws the page in the context. If the page is not available right now, it
58 // requests to have this page be rendered and returns false.
59 // Note: locks for a short amount of time.
[email protected]b75dca82009-10-13 18:46:2160 bool RenderPrintedPageNumber(int page_number,
61 gfx::NativeDrawingContext context);
initial.commit09911bf2008-07-26 23:55:2962
63 // Returns true if all the necessary pages for the settings are already
64 // rendered.
65 // Note: locks while parsing the whole tree.
66 bool IsComplete() const;
67
initial.commit09911bf2008-07-26 23:55:2968 // Disconnects the PrintedPage source (PrintedPagesSource). It is done when
69 // the source is being destroyed.
70 void DisconnectSource();
71
72 // Retrieves the current memory usage of the renderer pages.
73 // Note: locks for a short amount of time.
74 size_t MemoryUsage() const;
75
76 // Sets the number of pages in the document to be rendered. Can only be set
77 // once.
78 // Note: locks for a short amount of time.
79 void set_page_count(int max_page);
80
81 // Number of pages in the document. Used for headers/footers.
82 // Note: locks for a short amount of time.
83 int page_count() const;
84
85 // Returns the number of expected pages to be rendered. It is a non-linear
86 // series if settings().ranges is not empty. It is the same value as
87 // document_page_count() otherwise.
88 // Note: locks for a short amount of time.
89 int expected_page_count() const;
90
[email protected]4ecd07452009-03-31 14:34:4391 // Getters. All these items are immutable hence thread-safe.
initial.commit09911bf2008-07-26 23:55:2992 const PrintSettings& settings() const { return immutable_.settings_; }
93 const std::wstring& name() const {
94 return immutable_.name_;
95 }
96 const GURL& url() const { return immutable_.url_; }
97 const std::wstring& date() const { return immutable_.date_; }
98 const std::wstring& time() const { return immutable_.time_; }
99 const int cookie() const { return immutable_.cookie_; }
100
[email protected]e1504d82009-07-03 15:27:15101 // Sets a path where to dump printing output files for debugging. If never set
102 // no files are generated.
103 static void set_debug_dump_path(const std::wstring& debug_dump_path);
104
105 static const std::wstring& debug_dump_path();
106
initial.commit09911bf2008-07-26 23:55:29107 private:
[email protected]877d55d2009-11-05 21:53:08108 friend class base::RefCountedThreadSafe<PrintedDocument>;
109
110 ~PrintedDocument();
111
[email protected]0e0fca32009-07-06 15:25:50112 // Array of data for each print previewed page.
[email protected]8ff1d422009-07-07 21:31:39113 typedef std::map<int, scoped_refptr<PrintedPage> > PrintedPages;
initial.commit09911bf2008-07-26 23:55:29114
115 // Contains all the mutable stuff. All this stuff MUST be accessed with the
116 // lock held.
117 struct Mutable {
118 Mutable(PrintedPagesSource* source);
119
[email protected]57c6a652009-05-04 07:58:34120 // Source that generates the PrintedPage's (i.e. a TabContents). It will be
initial.commit09911bf2008-07-26 23:55:29121 // set back to NULL if the source is deleted before this object.
122 PrintedPagesSource* source_;
123
124 // Contains the pages' representation. This is a collection of PrintedPage.
125 // Warning: Lock must be held when accessing this member.
126 PrintedPages pages_;
127
128 // Number of expected pages to be rendered.
129 // Warning: Lock must be held when accessing this member.
130 int expected_page_count_;
131
132 // The total number of pages in the document.
133 int page_count_;
134
135 // Shrink done in comparison to desired_dpi.
136 double shrink_factor;
137 };
138
139 // Contains all the immutable stuff. All this stuff can be accessed without
140 // any lock held. This is because it can't be changed after the object's
141 // construction.
142 struct Immutable {
143 Immutable(const PrintSettings& settings, PrintedPagesSource* source,
144 int cookie);
145
[email protected]4ecd07452009-03-31 14:34:43146 // Print settings used to generate this document. Immutable.
initial.commit09911bf2008-07-26 23:55:29147 PrintSettings settings_;
148
149 // Native thread for the render source.
150 MessageLoop* source_message_loop_;
151
[email protected]4ecd07452009-03-31 14:34:43152 // Document name. Immutable.
initial.commit09911bf2008-07-26 23:55:29153 std::wstring name_;
154
[email protected]4ecd07452009-03-31 14:34:43155 // URL that generated this document. Immutable.
initial.commit09911bf2008-07-26 23:55:29156 GURL url_;
157
[email protected]4ecd07452009-03-31 14:34:43158 // The date on which this job started. Immutable.
initial.commit09911bf2008-07-26 23:55:29159 std::wstring date_;
160
[email protected]4ecd07452009-03-31 14:34:43161 // The time at which this job started. Immutable.
initial.commit09911bf2008-07-26 23:55:29162 std::wstring time_;
163
164 // Cookie to uniquely identify this document. It is used to make sure that a
165 // PrintedPage is correctly belonging to the PrintedDocument. Since
166 // PrintedPage generation is completely asynchronous, it could be easy to
167 // mess up and send the page to the wrong document. It can be viewed as a
168 // simpler hash of PrintSettings since a new document is made each time the
169 // print settings change.
170 int cookie_;
171 };
172
173 // Prints the headers and footers for one page in the specified context
174 // according to the current settings.
[email protected]b75dca82009-10-13 18:46:21175 void PrintHeaderFooter(gfx::NativeDrawingContext context,
initial.commit09911bf2008-07-26 23:55:29176 const PrintedPage& page,
177 PageOverlays::HorizontalPosition x,
178 PageOverlays::VerticalPosition y,
[email protected]7322c4402009-05-15 02:16:10179 const gfx::Font& font) const;
initial.commit09911bf2008-07-26 23:55:29180
[email protected]e1504d82009-07-03 15:27:15181 void DebugDump(const PrintedPage& page);
182
initial.commit09911bf2008-07-26 23:55:29183 // All writable data member access must be guarded by this lock. Needs to be
184 // mutable since it can be acquired from const member functions.
185 mutable Lock lock_;
186
187 // All the mutable members.
188 Mutable mutable_;
189
190 // All the immutable members.
191 const Immutable immutable_;
192
193 DISALLOW_EVIL_CONSTRUCTORS(PrintedDocument);
194};
195
196} // namespace printing
197
[email protected]8ff1d422009-07-07 21:31:39198#endif // PRINTING_PRINTED_DOCUMENT_H_