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

Side by Side Diff: src/pdf/SkPDFStream.cpp

Issue 387863005: Move SkPDFStream back to SkStream to save memory. (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: make compiler happy Created 6 years, 5 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 unified diff | Download patch
« no previous file with comments | « src/pdf/SkPDFStream.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 1
2 /* 2 /*
3 * Copyright 2010 Google Inc. 3 * Copyright 2010 Google Inc.
4 * 4 *
5 * Use of this source code is governed by a BSD-style license that can be 5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file. 6 * found in the LICENSE file.
7 */ 7 */
8 8
9 9
10 #include "SkData.h" 10 #include "SkData.h"
(...skipping 12 matching lines...) Expand all
23 this->setData(stream); 23 this->setData(stream);
24 } 24 }
25 25
26 SkPDFStream::SkPDFStream(SkData* data) : fState(kUnused_State) { 26 SkPDFStream::SkPDFStream(SkData* data) : fState(kUnused_State) {
27 this->setData(data); 27 this->setData(data);
28 } 28 }
29 29
30 SkPDFStream::SkPDFStream(const SkPDFStream& pdfStream) 30 SkPDFStream::SkPDFStream(const SkPDFStream& pdfStream)
31 : SkPDFDict(), 31 : SkPDFDict(),
32 fState(kUnused_State) { 32 fState(kUnused_State) {
33 this->setData(pdfStream.fData.get()); 33 this->setData(pdfStream.fDataStream.get());
34 bool removeLength = true; 34 bool removeLength = true;
35 // Don't uncompress an already compressed stream, but we could. 35 // Don't uncompress an already compressed stream, but we could.
36 if (pdfStream.fState == kCompressed_State) { 36 if (pdfStream.fState == kCompressed_State) {
37 fState = kCompressed_State; 37 fState = kCompressed_State;
38 removeLength = false; 38 removeLength = false;
39 } 39 }
40 this->mergeFrom(pdfStream); 40 this->mergeFrom(pdfStream);
41 if (removeLength) { 41 if (removeLength) {
42 this->remove("Length"); 42 this->remove("Length");
43 } 43 }
44 } 44 }
45 45
46 SkPDFStream::~SkPDFStream() {} 46 SkPDFStream::~SkPDFStream() {}
47 47
48 void SkPDFStream::emitObject(SkWStream* stream, SkPDFCatalog* catalog, 48 void SkPDFStream::emitObject(SkWStream* stream, SkPDFCatalog* catalog,
49 bool indirect) { 49 bool indirect) {
50 if (indirect) { 50 if (indirect) {
51 return emitIndirectObject(stream, catalog); 51 return emitIndirectObject(stream, catalog);
52 } 52 }
53 SkAutoMutexAcquire lock(fMutex); // multiple threads could be calling emit 53 SkAutoMutexAcquire lock(fMutex); // multiple threads could be calling emit
54 if (!this->populate(catalog)) { 54 if (!this->populate(catalog)) {
55 return fSubstitute->emitObject(stream, catalog, indirect); 55 return fSubstitute->emitObject(stream, catalog, indirect);
56 } 56 }
57 57
58 this->INHERITED::emitObject(stream, catalog, false); 58 this->INHERITED::emitObject(stream, catalog, false);
59 stream->writeText(" stream\n"); 59 stream->writeText(" stream\n");
60 if (fData.get()) { 60 stream->writeStream(fDataStream.get(), fDataStream->getLength());
61 stream->write(fData->data(), fData->size()); 61 SkAssertResult(fDataStream->rewind());
62 }
63 stream->writeText("\nendstream"); 62 stream->writeText("\nendstream");
64 } 63 }
65 64
66 size_t SkPDFStream::getOutputSize(SkPDFCatalog* catalog, bool indirect) { 65 size_t SkPDFStream::getOutputSize(SkPDFCatalog* catalog, bool indirect) {
67 if (indirect) { 66 if (indirect) {
68 return getIndirectOutputSize(catalog); 67 return getIndirectOutputSize(catalog);
69 } 68 }
70 SkAutoMutexAcquire lock(fMutex); // multiple threads could be calling emit 69 SkAutoMutexAcquire lock(fMutex); // multiple threads could be calling emit
71 if (!this->populate(catalog)) { 70 if (!this->populate(catalog)) {
72 return fSubstitute->getOutputSize(catalog, indirect); 71 return fSubstitute->getOutputSize(catalog, indirect);
73 } 72 }
74 73
75 return this->INHERITED::getOutputSize(catalog, false) + 74 return this->INHERITED::getOutputSize(catalog, false) +
76 strlen(" stream\n\nendstream") + this->dataSize(); 75 strlen(" stream\n\nendstream") + this->dataSize();
77 } 76 }
78 77
79 SkPDFStream::SkPDFStream() : fState(kUnused_State) {} 78 SkPDFStream::SkPDFStream() : fState(kUnused_State) {}
80 79
81 void SkPDFStream::setData(SkData* data) { 80 void SkPDFStream::setData(SkData* data) {
82 fData.reset(SkSafeRef(data)); 81 fMemoryStream.setData(data);
82 if (&fMemoryStream != fDataStream.get()) {
83 fDataStream.reset(SkRef(&fMemoryStream));
84 }
83 } 85 }
84 86
85 void SkPDFStream::setData(SkStream* stream) { 87 void SkPDFStream::setData(SkStream* stream) {
86 // Code assumes that the stream starts at the beginning and is rewindable. 88 // Code assumes that the stream starts at the beginning and is rewindable.
89 if (&fMemoryStream == fDataStream.get()) {
90 SkASSERT(&fMemoryStream != stream);
91 fMemoryStream.setData(NULL);
92 }
93 SkASSERT(0 == fMemoryStream.getLength());
87 if (stream) { 94 if (stream) {
88 SkASSERT(stream->getPosition() == 0); 95 // SkStreamRewindableFromSkStream will try stream->duplicate().
89 fData.reset(SkCopyStreamToData(stream)); 96 fDataStream.reset(SkStreamRewindableFromSkStream(stream));
90 SkAssertResult(stream->rewind()); 97 SkASSERT(fDataStream.get());
91 } else { 98 } else {
92 fData.reset(NULL); 99 fDataStream.reset(SkRef(&fMemoryStream));
93 } 100 }
94 } 101 }
95 102
96 size_t SkPDFStream::dataSize() const { 103 size_t SkPDFStream::dataSize() const {
97 return fData.get() ? fData->size() : 0; 104 SkASSERT(fDataStream->hasLength());
105 return fDataStream->getLength();
98 } 106 }
99 107
100 bool SkPDFStream::populate(SkPDFCatalog* catalog) { 108 bool SkPDFStream::populate(SkPDFCatalog* catalog) {
101 if (fState == kUnused_State) { 109 if (fState == kUnused_State) {
102 if (!skip_compression(catalog) && SkFlate::HaveFlate()) { 110 if (!skip_compression(catalog) && SkFlate::HaveFlate()) {
103 SkDynamicMemoryWStream compressedData; 111 SkDynamicMemoryWStream compressedData;
104 112
105 SkAssertResult(SkFlate::Deflate(fData.get(), &compressedData)); 113 SkAssertResult(
114 SkFlate::Deflate(fDataStream.get(), &compressedData));
115 SkAssertResult(fDataStream->rewind());
106 if (compressedData.getOffset() < this->dataSize()) { 116 if (compressedData.getOffset() < this->dataSize()) {
107 fData.reset(compressedData.copyToData()); 117 this->setData(compressedData.detachAsStream());
108 insertName("Filter", "FlateDecode"); 118 insertName("Filter", "FlateDecode");
109 } 119 }
110 fState = kCompressed_State; 120 fState = kCompressed_State;
111 } else { 121 } else {
112 fState = kNoCompression_State; 122 fState = kNoCompression_State;
113 } 123 }
114 insertInt("Length", this->dataSize()); 124 insertInt("Length", this->dataSize());
115 } else if (fState == kNoCompression_State && !skip_compression(catalog) && 125 } else if (fState == kNoCompression_State && !skip_compression(catalog) &&
116 SkFlate::HaveFlate()) { 126 SkFlate::HaveFlate()) {
117 if (!fSubstitute.get()) { 127 if (!fSubstitute.get()) {
118 fSubstitute.reset(new SkPDFStream(*this)); 128 fSubstitute.reset(new SkPDFStream(*this));
119 catalog->setSubstitute(this, fSubstitute.get()); 129 catalog->setSubstitute(this, fSubstitute.get());
120 } 130 }
121 return false; 131 return false;
122 } 132 }
123 return true; 133 return true;
124 } 134 }
OLDNEW
« no previous file with comments | « src/pdf/SkPDFStream.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698