blob: 798db952239be67453fb46b2ae0ba166ace4c307 [file] [log] [blame]
chudy@google.com902ebe52012-06-29 14:21:22 +00001
2/*
3 * Copyright 2012 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8
9#include "SkObjectParser.h"
humper@google.comf515ffc2013-01-07 15:48:19 +000010#include "SkData.h"
11#include "SkFontDescriptor.h"
robertphillips@google.com4991b8f2013-01-28 20:21:59 +000012#include "SkRRect.h"
13#include "SkShader.h"
14#include "SkStream.h"
15#include "SkStringUtils.h"
16#include "SkTypeface.h"
bungeman@google.com428fc4a2013-03-07 20:30:32 +000017#include "SkUtils.h"
chudy@google.com902ebe52012-06-29 14:21:22 +000018
19/* TODO(chudy): Replace all std::strings with char */
20
chudy@google.com97cee972012-08-07 20:41:37 +000021SkString* SkObjectParser::BitmapToString(const SkBitmap& bitmap) {
robertphillips@google.com195952f2012-10-23 12:13:35 +000022 SkString* mBitmap = new SkString("SkBitmap: ");
23 mBitmap->append("W: ");
24 mBitmap->appendS32(bitmap.width());
25 mBitmap->append(" H: ");
26 mBitmap->appendS32(bitmap.height());
27
reedc77392e2014-06-02 13:07:26 -070028 const char* gColorTypeStrings[] = {
29 "None", "A8", "565", "4444", "RGBA", "BGRA", "Index8"
robertphillips@google.com195952f2012-10-23 12:13:35 +000030 };
reedc77392e2014-06-02 13:07:26 -070031 SkASSERT(kLastEnum_SkColorType + 1 == SK_ARRAY_COUNT(gColorTypeStrings));
robertphillips@google.com195952f2012-10-23 12:13:35 +000032
reedc77392e2014-06-02 13:07:26 -070033 mBitmap->append(" ColorType: ");
34 mBitmap->append(gColorTypeStrings[bitmap.colorType()]);
robertphillips@google.com195952f2012-10-23 12:13:35 +000035
36 if (bitmap.isOpaque()) {
37 mBitmap->append(" opaque");
38 } else {
39 mBitmap->append(" not-opaque");
40 }
41
42 if (bitmap.isImmutable()) {
43 mBitmap->append(" immutable");
44 } else {
45 mBitmap->append(" not-immutable");
46 }
47
48 if (bitmap.isVolatile()) {
49 mBitmap->append(" volatile");
50 } else {
51 mBitmap->append(" not-volatile");
52 }
53
54 mBitmap->append(" genID: ");
55 mBitmap->appendS32(bitmap.getGenerationID());
56
chudy@google.com902ebe52012-06-29 14:21:22 +000057 return mBitmap;
58}
59
chudy@google.com97cee972012-08-07 20:41:37 +000060SkString* SkObjectParser::BoolToString(bool doAA) {
61 SkString* mBool = new SkString("Bool doAA: ");
chudy@google.com902ebe52012-06-29 14:21:22 +000062 if (doAA) {
chudy@google.com97cee972012-08-07 20:41:37 +000063 mBool->append("True");
chudy@google.com902ebe52012-06-29 14:21:22 +000064 } else {
chudy@google.com97cee972012-08-07 20:41:37 +000065 mBool->append("False");
chudy@google.com902ebe52012-06-29 14:21:22 +000066 }
chudy@google.com97cee972012-08-07 20:41:37 +000067 return mBool;
chudy@google.com902ebe52012-06-29 14:21:22 +000068}
69
chudy@google.com97cee972012-08-07 20:41:37 +000070SkString* SkObjectParser::CustomTextToString(const char* text) {
71 SkString* mText = new SkString(text);
72 return mText;
chudy@google.com902ebe52012-06-29 14:21:22 +000073}
74
chudy@google.com97cee972012-08-07 20:41:37 +000075SkString* SkObjectParser::IntToString(int x, const char* text) {
76 SkString* mInt = new SkString(text);
77 mInt->append(" ");
78 mInt->appendScalar(SkIntToScalar(x));
79 return mInt;
chudy@google.com902ebe52012-06-29 14:21:22 +000080}
81
chudy@google.com97cee972012-08-07 20:41:37 +000082SkString* SkObjectParser::IRectToString(const SkIRect& rect) {
83 SkString* mRect = new SkString("SkIRect: ");
84 mRect->append("L: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000085 mRect->appendS32(rect.left());
chudy@google.com97cee972012-08-07 20:41:37 +000086 mRect->append(", T: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000087 mRect->appendS32(rect.top());
chudy@google.com97cee972012-08-07 20:41:37 +000088 mRect->append(", R: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000089 mRect->appendS32(rect.right());
chudy@google.com97cee972012-08-07 20:41:37 +000090 mRect->append(", B: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000091 mRect->appendS32(rect.bottom());
chudy@google.com902ebe52012-06-29 14:21:22 +000092 return mRect;
93}
94
chudy@google.com97cee972012-08-07 20:41:37 +000095SkString* SkObjectParser::MatrixToString(const SkMatrix& matrix) {
robertphillips@google.com791f12e2013-02-14 13:53:53 +000096 SkString* str = new SkString("SkMatrix: ");
commit-bot@chromium.org0f10f7b2014-03-13 18:02:17 +000097#ifndef SK_IGNORE_TO_STRING
robertphillips@google.com791f12e2013-02-14 13:53:53 +000098 matrix.toString(str);
robertphillips@google.com37a2b392013-02-14 14:40:27 +000099#endif
robertphillips@google.com791f12e2013-02-14 13:53:53 +0000100 return str;
chudy@google.com97cee972012-08-07 20:41:37 +0000101}
chudy@google.com902ebe52012-06-29 14:21:22 +0000102
robertphillips@google.com735edb02013-01-10 18:54:11 +0000103SkString* SkObjectParser::PaintToString(const SkPaint& paint) {
robertphillips@google.com791f12e2013-02-14 13:53:53 +0000104 SkString* str = new SkString;
commit-bot@chromium.org0f10f7b2014-03-13 18:02:17 +0000105#ifndef SK_IGNORE_TO_STRING
robertphillips@google.com791f12e2013-02-14 13:53:53 +0000106 paint.toString(str);
robertphillips@google.com37a2b392013-02-14 14:40:27 +0000107#endif
robertphillips@google.com791f12e2013-02-14 13:53:53 +0000108 return str;
chudy@google.com97cee972012-08-07 20:41:37 +0000109}
110
111SkString* SkObjectParser::PathToString(const SkPath& path) {
robertphillips@google.com87201762012-10-18 13:30:18 +0000112 SkString* mPath = new SkString("Path (");
113
robertphillips@google.com51185fe2012-12-05 19:34:33 +0000114 static const char* gFillStrings[] = {
115 "Winding", "EvenOdd", "InverseWinding", "InverseEvenOdd"
116 };
117
118 mPath->append(gFillStrings[path.getFillType()]);
119 mPath->append(", ");
120
robertphillips@google.com87201762012-10-18 13:30:18 +0000121 static const char* gConvexityStrings[] = {
skia.committer@gmail.com6a748ad2012-10-19 02:01:19 +0000122 "Unknown", "Convex", "Concave"
robertphillips@google.com87201762012-10-18 13:30:18 +0000123 };
124 SkASSERT(SkPath::kConcave_Convexity == 2);
125
126 mPath->append(gConvexityStrings[path.getConvexity()]);
127 mPath->append(", ");
128
robertphillips@google.com195952f2012-10-23 12:13:35 +0000129 if (path.isRect(NULL)) {
130 mPath->append("isRect, ");
131 } else {
132 mPath->append("isNotRect, ");
133 }
134
robertphillips@google.com87201762012-10-18 13:30:18 +0000135 mPath->appendS32(path.countVerbs());
136 mPath->append("V, ");
137 mPath->appendS32(path.countPoints());
138 mPath->append("P): ");
139
140 static const char* gVerbStrings[] = {
commit-bot@chromium.org4a3ca942013-06-04 21:51:06 +0000141 "Move", "Line", "Quad", "Conic", "Cubic", "Close", "Done"
robertphillips@google.com87201762012-10-18 13:30:18 +0000142 };
commit-bot@chromium.org4a3ca942013-06-04 21:51:06 +0000143 static const int gPtsPerVerb[] = { 1, 1, 2, 2, 3, 0, 0 };
144 static const int gPtOffsetPerVerb[] = { 0, 1, 1, 1, 1, 0, 0 };
145 SkASSERT(SkPath::kDone_Verb == 6);
robertphillips@google.com87201762012-10-18 13:30:18 +0000146
147 SkPath::Iter iter(const_cast<SkPath&>(path), false);
148 SkPath::Verb verb;
149 SkPoint points[4];
150
skia.committer@gmail.com6a748ad2012-10-19 02:01:19 +0000151 for(verb = iter.next(points, false);
152 verb != SkPath::kDone_Verb;
robertphillips@google.com87201762012-10-18 13:30:18 +0000153 verb = iter.next(points, false)) {
154
155 mPath->append(gVerbStrings[verb]);
156 mPath->append(" ");
157
158 for (int i = 0; i < gPtsPerVerb[verb]; ++i) {
159 mPath->append("(");
160 mPath->appendScalar(points[gPtOffsetPerVerb[verb]+i].fX);
161 mPath->append(", ");
162 mPath->appendScalar(points[gPtOffsetPerVerb[verb]+i].fY);
commit-bot@chromium.org4a3ca942013-06-04 21:51:06 +0000163 mPath->append(")");
robertphillips@google.com87201762012-10-18 13:30:18 +0000164 }
commit-bot@chromium.org4a3ca942013-06-04 21:51:06 +0000165
166 if (SkPath::kConic_Verb == verb) {
167 mPath->append("(");
168 mPath->appendScalar(iter.conicWeight());
169 mPath->append(")");
170 }
171
172 mPath->append(" ");
chudy@google.com97cee972012-08-07 20:41:37 +0000173 }
robertphillips@google.com87201762012-10-18 13:30:18 +0000174
robertphillips@google.com30d35f22012-11-06 16:45:36 +0000175 SkString* boundStr = SkObjectParser::RectToString(path.getBounds(), " Bound: ");
176
bsalomon49f085d2014-09-05 13:34:00 -0700177 if (boundStr) {
robertphillips@google.com30d35f22012-11-06 16:45:36 +0000178 mPath->append(*boundStr);
179 SkDELETE(boundStr);
180 }
181
chudy@google.com97cee972012-08-07 20:41:37 +0000182 return mPath;
183}
184
185SkString* SkObjectParser::PointsToString(const SkPoint pts[], size_t count) {
186 SkString* mPoints = new SkString("SkPoints pts[]: ");
187 for (unsigned int i = 0; i < count; i++) {
188 mPoints->append("(");
189 mPoints->appendScalar(pts[i].fX);
190 mPoints->append(",");
191 mPoints->appendScalar(pts[i].fY);
192 mPoints->append(")");
193 }
194 return mPoints;
195}
196
197SkString* SkObjectParser::PointModeToString(SkCanvas::PointMode mode) {
198 SkString* mMode = new SkString("SkCanvas::PointMode: ");
199 if (mode == SkCanvas::kPoints_PointMode) {
200 mMode->append("kPoints_PointMode");
201 } else if (mode == SkCanvas::kLines_PointMode) {
202 mMode->append("kLines_Mode");
203 } else if (mode == SkCanvas::kPolygon_PointMode) {
204 mMode->append("kPolygon_PointMode");
205 }
206 return mMode;
207}
208
robertphillips@google.com30d35f22012-11-06 16:45:36 +0000209SkString* SkObjectParser::RectToString(const SkRect& rect, const char* title) {
210
211 SkString* mRect = new SkString;
skia.committer@gmail.com72b2e6f2012-11-08 02:03:56 +0000212
robertphillips@google.com30d35f22012-11-06 16:45:36 +0000213 if (NULL == title) {
214 mRect->append("SkRect: ");
215 } else {
216 mRect->append(title);
217 }
chudy@google.com97cee972012-08-07 20:41:37 +0000218 mRect->append("(");
219 mRect->appendScalar(rect.left());
220 mRect->append(", ");
221 mRect->appendScalar(rect.top());
222 mRect->append(", ");
223 mRect->appendScalar(rect.right());
224 mRect->append(", ");
225 mRect->appendScalar(rect.bottom());
226 mRect->append(")");
227 return mRect;
228}
229
robertphillips@google.com67baba42013-01-02 20:20:31 +0000230SkString* SkObjectParser::RRectToString(const SkRRect& rrect, const char* title) {
231
232 SkString* mRRect = new SkString;
233
234 if (NULL == title) {
235 mRRect->append("SkRRect (");
236 if (rrect.isEmpty()) {
237 mRRect->append("empty");
238 } else if (rrect.isRect()) {
239 mRRect->append("rect");
240 } else if (rrect.isOval()) {
241 mRRect->append("oval");
242 } else if (rrect.isSimple()) {
243 mRRect->append("simple");
commit-bot@chromium.orgf338d7c2014-03-17 21:17:30 +0000244 } else if (rrect.isNinePatch()) {
245 mRRect->append("nine-patch");
robertphillips@google.com67baba42013-01-02 20:20:31 +0000246 } else {
247 SkASSERT(rrect.isComplex());
248 mRRect->append("complex");
249 }
250 mRRect->append("): ");
251 } else {
252 mRRect->append(title);
253 }
254 mRRect->append("(");
255 mRRect->appendScalar(rrect.rect().left());
256 mRRect->append(", ");
257 mRRect->appendScalar(rrect.rect().top());
258 mRRect->append(", ");
259 mRRect->appendScalar(rrect.rect().right());
260 mRRect->append(", ");
261 mRRect->appendScalar(rrect.rect().bottom());
262 mRRect->append(") radii: (");
263 for (int i = 0; i < 4; ++i) {
264 const SkVector& radii = rrect.radii((SkRRect::Corner) i);
265 mRRect->appendScalar(radii.fX);
266 mRRect->append(", ");
267 mRRect->appendScalar(radii.fY);
268 if (i < 3) {
269 mRRect->append(", ");
270 }
271 }
272 mRRect->append(")");
273 return mRRect;
274}
275
chudy@google.com97cee972012-08-07 20:41:37 +0000276SkString* SkObjectParser::RegionOpToString(SkRegion::Op op) {
277 SkString* mOp = new SkString("SkRegion::Op: ");
278 if (op == SkRegion::kDifference_Op) {
279 mOp->append("kDifference_Op");
280 } else if (op == SkRegion::kIntersect_Op) {
281 mOp->append("kIntersect_Op");
282 } else if (op == SkRegion::kUnion_Op) {
283 mOp->append("kUnion_Op");
284 } else if (op == SkRegion::kXOR_Op) {
285 mOp->append("kXOR_Op");
286 } else if (op == SkRegion::kReverseDifference_Op) {
287 mOp->append("kReverseDifference_Op");
288 } else if (op == SkRegion::kReplace_Op) {
289 mOp->append("kReplace_Op");
290 } else {
291 mOp->append("Unknown Type");
292 }
chudy@google.com902ebe52012-06-29 14:21:22 +0000293 return mOp;
294}
295
chudy@google.com97cee972012-08-07 20:41:37 +0000296SkString* SkObjectParser::RegionToString(const SkRegion& region) {
297 SkString* mRegion = new SkString("SkRegion: Data unavailable.");
298 return mRegion;
chudy@google.com902ebe52012-06-29 14:21:22 +0000299}
300
chudy@google.com97cee972012-08-07 20:41:37 +0000301SkString* SkObjectParser::SaveFlagsToString(SkCanvas::SaveFlags flags) {
302 SkString* mFlags = new SkString("SkCanvas::SaveFlags: ");
fmalita@google.comd3ae1d62013-07-11 16:25:55 +0000303 if (flags & SkCanvas::kHasAlphaLayer_SaveFlag) {
304 mFlags->append("kHasAlphaLayer_SaveFlag ");
305 }
306 if (flags & SkCanvas::kFullColorLayer_SaveFlag) {
307 mFlags->append("kFullColorLayer_SaveFlag ");
308 }
309 if (flags & SkCanvas::kClipToLayer_SaveFlag) {
310 mFlags->append("kClipToLayer_SaveFlag ");
chudy@google.com902ebe52012-06-29 14:21:22 +0000311 }
chudy@google.com902ebe52012-06-29 14:21:22 +0000312 return mFlags;
313}
314
chudy@google.com97cee972012-08-07 20:41:37 +0000315SkString* SkObjectParser::ScalarToString(SkScalar x, const char* text) {
316 SkString* mScalar = new SkString(text);
317 mScalar->append(" ");
318 mScalar->appendScalar(x);
chudy@google.com902ebe52012-06-29 14:21:22 +0000319 return mScalar;
320}
321
bungeman@google.com428fc4a2013-03-07 20:30:32 +0000322SkString* SkObjectParser::TextToString(const void* text, size_t byteLength,
323 SkPaint::TextEncoding encoding) {
324
325 SkString* decodedText = new SkString();
326 switch (encoding) {
327 case SkPaint::kUTF8_TextEncoding: {
328 decodedText->append("UTF-8: ");
329 decodedText->append((const char*)text, byteLength);
330 break;
331 }
332 case SkPaint::kUTF16_TextEncoding: {
333 decodedText->append("UTF-16: ");
skia.committer@gmail.comf61ebc02013-11-22 07:02:24 +0000334 size_t sizeNeeded = SkUTF16_ToUTF8((uint16_t*)text,
335 SkToS32(byteLength / 2),
robertphillips@google.coma4662862013-11-21 14:24:16 +0000336 NULL);
scroggo@google.comb9050d72013-08-26 21:20:04 +0000337 SkAutoSTMalloc<0x100, char> utf8(sizeNeeded);
robertphillips@google.coma4662862013-11-21 14:24:16 +0000338 SkUTF16_ToUTF8((uint16_t*)text, SkToS32(byteLength / 2), utf8);
bungeman@google.com428fc4a2013-03-07 20:30:32 +0000339 decodedText->append(utf8, sizeNeeded);
bungeman@google.com428fc4a2013-03-07 20:30:32 +0000340 break;
341 }
342 case SkPaint::kUTF32_TextEncoding: {
343 decodedText->append("UTF-32: ");
344 const SkUnichar* begin = (const SkUnichar*)text;
345 const SkUnichar* end = (const SkUnichar*)((const char*)text + byteLength);
346 for (const SkUnichar* unichar = begin; unichar < end; ++unichar) {
347 decodedText->appendUnichar(*unichar);
348 }
349 break;
350 }
351 case SkPaint::kGlyphID_TextEncoding: {
352 decodedText->append("GlyphID: ");
353 const uint16_t* begin = (const uint16_t*)text;
354 const uint16_t* end = (const uint16_t*)((const char*)text + byteLength);
355 for (const uint16_t* glyph = begin; glyph < end; ++glyph) {
356 decodedText->append("0x");
357 decodedText->appendHex(*glyph);
358 decodedText->append(" ");
359 }
360 break;
361 }
362 default:
363 decodedText->append("Unknown text encoding.");
364 break;
365 }
366
367 return decodedText;
chudy@google.com902ebe52012-06-29 14:21:22 +0000368}