blob: 4bee8715f12cccbbaa1be1d52565a27ac403d6dd [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"
10
11/* TODO(chudy): Replace all std::strings with char */
12
chudy@google.com97cee972012-08-07 20:41:37 +000013SkString* SkObjectParser::BitmapToString(const SkBitmap& bitmap) {
robertphillips@google.com195952f2012-10-23 12:13:35 +000014 SkString* mBitmap = new SkString("SkBitmap: ");
15 mBitmap->append("W: ");
16 mBitmap->appendS32(bitmap.width());
17 mBitmap->append(" H: ");
18 mBitmap->appendS32(bitmap.height());
19
20 const char* gConfigStrings[] = {
21 "None", "A1", "A8", "Index8", "RGB565", "ARGB4444", "ARGB8888", "RLE8"
22 };
23 SkASSERT(SkBitmap::kConfigCount == 8);
24
25 mBitmap->append(" Config: ");
26 mBitmap->append(gConfigStrings[bitmap.getConfig()]);
27
28 if (bitmap.isOpaque()) {
29 mBitmap->append(" opaque");
30 } else {
31 mBitmap->append(" not-opaque");
32 }
33
34 if (bitmap.isImmutable()) {
35 mBitmap->append(" immutable");
36 } else {
37 mBitmap->append(" not-immutable");
38 }
39
40 if (bitmap.isVolatile()) {
41 mBitmap->append(" volatile");
42 } else {
43 mBitmap->append(" not-volatile");
44 }
45
46 mBitmap->append(" genID: ");
47 mBitmap->appendS32(bitmap.getGenerationID());
48
chudy@google.com902ebe52012-06-29 14:21:22 +000049 return mBitmap;
50}
51
chudy@google.com97cee972012-08-07 20:41:37 +000052SkString* SkObjectParser::BoolToString(bool doAA) {
53 SkString* mBool = new SkString("Bool doAA: ");
chudy@google.com902ebe52012-06-29 14:21:22 +000054 if (doAA) {
chudy@google.com97cee972012-08-07 20:41:37 +000055 mBool->append("True");
chudy@google.com902ebe52012-06-29 14:21:22 +000056 } else {
chudy@google.com97cee972012-08-07 20:41:37 +000057 mBool->append("False");
chudy@google.com902ebe52012-06-29 14:21:22 +000058 }
chudy@google.com97cee972012-08-07 20:41:37 +000059 return mBool;
chudy@google.com902ebe52012-06-29 14:21:22 +000060}
61
chudy@google.com97cee972012-08-07 20:41:37 +000062SkString* SkObjectParser::CustomTextToString(const char* text) {
63 SkString* mText = new SkString(text);
64 return mText;
chudy@google.com902ebe52012-06-29 14:21:22 +000065}
66
chudy@google.com97cee972012-08-07 20:41:37 +000067SkString* SkObjectParser::IntToString(int x, const char* text) {
68 SkString* mInt = new SkString(text);
69 mInt->append(" ");
70 mInt->appendScalar(SkIntToScalar(x));
71 return mInt;
chudy@google.com902ebe52012-06-29 14:21:22 +000072}
73
chudy@google.com97cee972012-08-07 20:41:37 +000074SkString* SkObjectParser::IRectToString(const SkIRect& rect) {
75 SkString* mRect = new SkString("SkIRect: ");
76 mRect->append("L: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000077 mRect->appendS32(rect.left());
chudy@google.com97cee972012-08-07 20:41:37 +000078 mRect->append(", T: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000079 mRect->appendS32(rect.top());
chudy@google.com97cee972012-08-07 20:41:37 +000080 mRect->append(", R: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000081 mRect->appendS32(rect.right());
chudy@google.com97cee972012-08-07 20:41:37 +000082 mRect->append(", B: ");
robertphillips@google.com195952f2012-10-23 12:13:35 +000083 mRect->appendS32(rect.bottom());
chudy@google.com902ebe52012-06-29 14:21:22 +000084 return mRect;
85}
86
chudy@google.com97cee972012-08-07 20:41:37 +000087SkString* SkObjectParser::MatrixToString(const SkMatrix& matrix) {
88 SkString* mMatrix = new SkString("SkMatrix: (");
89 for (int i = 0; i < 8; i++) {
90 mMatrix->appendScalar(matrix.get(i));
91 mMatrix->append("), (");
chudy@google.com902ebe52012-06-29 14:21:22 +000092 }
chudy@google.com97cee972012-08-07 20:41:37 +000093 mMatrix->appendScalar(matrix.get(8));
94 mMatrix->append(")");
95 return mMatrix;
96}
chudy@google.com902ebe52012-06-29 14:21:22 +000097
chudy@google.com97cee972012-08-07 20:41:37 +000098SkString* SkObjectParser::PaintToString(const SkPaint& paint) {
99 SkColor color = paint.getColor();
robertphillips@google.com195952f2012-10-23 12:13:35 +0000100 SkString* mPaint = new SkString("SkPaint: Color: 0x");
chudy@google.com97cee972012-08-07 20:41:37 +0000101 mPaint->appendHex(color);
robertphillips@google.com195952f2012-10-23 12:13:35 +0000102
chudy@google.com97cee972012-08-07 20:41:37 +0000103 return mPaint;
104}
105
106SkString* SkObjectParser::PathToString(const SkPath& path) {
robertphillips@google.com87201762012-10-18 13:30:18 +0000107 SkString* mPath = new SkString("Path (");
108
109 static const char* gConvexityStrings[] = {
skia.committer@gmail.com6a748ad2012-10-19 02:01:19 +0000110 "Unknown", "Convex", "Concave"
robertphillips@google.com87201762012-10-18 13:30:18 +0000111 };
112 SkASSERT(SkPath::kConcave_Convexity == 2);
113
114 mPath->append(gConvexityStrings[path.getConvexity()]);
115 mPath->append(", ");
116
robertphillips@google.com195952f2012-10-23 12:13:35 +0000117 if (path.isRect(NULL)) {
118 mPath->append("isRect, ");
119 } else {
120 mPath->append("isNotRect, ");
121 }
122
robertphillips@google.com87201762012-10-18 13:30:18 +0000123 mPath->appendS32(path.countVerbs());
124 mPath->append("V, ");
125 mPath->appendS32(path.countPoints());
126 mPath->append("P): ");
127
128 static const char* gVerbStrings[] = {
129 "Move", "Line", "Quad", "Cubic", "Close", "Done"
130 };
131 static const int gPtsPerVerb[] = { 1, 1, 2, 3, 0, 0 };
132 static const int gPtOffsetPerVerb[] = { 0, 1, 1, 1, 0, 0 };
133 SkASSERT(SkPath::kDone_Verb == 5);
134
135 SkPath::Iter iter(const_cast<SkPath&>(path), false);
136 SkPath::Verb verb;
137 SkPoint points[4];
138
skia.committer@gmail.com6a748ad2012-10-19 02:01:19 +0000139 for(verb = iter.next(points, false);
140 verb != SkPath::kDone_Verb;
robertphillips@google.com87201762012-10-18 13:30:18 +0000141 verb = iter.next(points, false)) {
142
143 mPath->append(gVerbStrings[verb]);
144 mPath->append(" ");
145
146 for (int i = 0; i < gPtsPerVerb[verb]; ++i) {
147 mPath->append("(");
148 mPath->appendScalar(points[gPtOffsetPerVerb[verb]+i].fX);
149 mPath->append(", ");
150 mPath->appendScalar(points[gPtOffsetPerVerb[verb]+i].fY);
151 mPath->append(") ");
152 }
chudy@google.com97cee972012-08-07 20:41:37 +0000153 }
robertphillips@google.com87201762012-10-18 13:30:18 +0000154
chudy@google.com97cee972012-08-07 20:41:37 +0000155 return mPath;
156}
157
158SkString* SkObjectParser::PointsToString(const SkPoint pts[], size_t count) {
159 SkString* mPoints = new SkString("SkPoints pts[]: ");
160 for (unsigned int i = 0; i < count; i++) {
161 mPoints->append("(");
162 mPoints->appendScalar(pts[i].fX);
163 mPoints->append(",");
164 mPoints->appendScalar(pts[i].fY);
165 mPoints->append(")");
166 }
167 return mPoints;
168}
169
170SkString* SkObjectParser::PointModeToString(SkCanvas::PointMode mode) {
171 SkString* mMode = new SkString("SkCanvas::PointMode: ");
172 if (mode == SkCanvas::kPoints_PointMode) {
173 mMode->append("kPoints_PointMode");
174 } else if (mode == SkCanvas::kLines_PointMode) {
175 mMode->append("kLines_Mode");
176 } else if (mode == SkCanvas::kPolygon_PointMode) {
177 mMode->append("kPolygon_PointMode");
178 }
179 return mMode;
180}
181
182SkString* SkObjectParser::RectToString(const SkRect& rect) {
183 SkString* mRect = new SkString("SkRect: ");
184 mRect->append("(");
185 mRect->appendScalar(rect.left());
186 mRect->append(", ");
187 mRect->appendScalar(rect.top());
188 mRect->append(", ");
189 mRect->appendScalar(rect.right());
190 mRect->append(", ");
191 mRect->appendScalar(rect.bottom());
192 mRect->append(")");
193 return mRect;
194}
195
196SkString* SkObjectParser::RegionOpToString(SkRegion::Op op) {
197 SkString* mOp = new SkString("SkRegion::Op: ");
198 if (op == SkRegion::kDifference_Op) {
199 mOp->append("kDifference_Op");
200 } else if (op == SkRegion::kIntersect_Op) {
201 mOp->append("kIntersect_Op");
202 } else if (op == SkRegion::kUnion_Op) {
203 mOp->append("kUnion_Op");
204 } else if (op == SkRegion::kXOR_Op) {
205 mOp->append("kXOR_Op");
206 } else if (op == SkRegion::kReverseDifference_Op) {
207 mOp->append("kReverseDifference_Op");
208 } else if (op == SkRegion::kReplace_Op) {
209 mOp->append("kReplace_Op");
210 } else {
211 mOp->append("Unknown Type");
212 }
chudy@google.com902ebe52012-06-29 14:21:22 +0000213 return mOp;
214}
215
chudy@google.com97cee972012-08-07 20:41:37 +0000216SkString* SkObjectParser::RegionToString(const SkRegion& region) {
217 SkString* mRegion = new SkString("SkRegion: Data unavailable.");
218 return mRegion;
chudy@google.com902ebe52012-06-29 14:21:22 +0000219}
220
chudy@google.com97cee972012-08-07 20:41:37 +0000221SkString* SkObjectParser::SaveFlagsToString(SkCanvas::SaveFlags flags) {
222 SkString* mFlags = new SkString("SkCanvas::SaveFlags: ");
chudy@google.com902ebe52012-06-29 14:21:22 +0000223 if(flags == SkCanvas::kMatrixClip_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000224 mFlags->append("kMatrixClip_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000225 } else if (flags == SkCanvas::kClip_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000226 mFlags->append("kClip_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000227 } else if (flags == SkCanvas::kHasAlphaLayer_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000228 mFlags->append("kHasAlphaLayer_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000229 } else if (flags == SkCanvas::kFullColorLayer_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000230 mFlags->append("kFullColorLayer_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000231 } else if (flags == SkCanvas::kClipToLayer_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000232 mFlags->append("kClipToLayer_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000233 } else if (flags == SkCanvas::kMatrixClip_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000234 mFlags->append("kMatrixClip_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000235 } else if (flags == SkCanvas::kARGB_NoClipLayer_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000236 mFlags->append("kARGB_NoClipLayer_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000237 } else if (flags == SkCanvas::kARGB_ClipLayer_SaveFlag) {
chudy@google.com97cee972012-08-07 20:41:37 +0000238 mFlags->append("kARGB_ClipLayer_SaveFlag");
chudy@google.com902ebe52012-06-29 14:21:22 +0000239 } else {
chudy@google.com97cee972012-08-07 20:41:37 +0000240 mFlags->append("Data Unavailable");
chudy@google.com902ebe52012-06-29 14:21:22 +0000241 }
chudy@google.com902ebe52012-06-29 14:21:22 +0000242 return mFlags;
243}
244
chudy@google.com97cee972012-08-07 20:41:37 +0000245SkString* SkObjectParser::ScalarToString(SkScalar x, const char* text) {
246 SkString* mScalar = new SkString(text);
247 mScalar->append(" ");
248 mScalar->appendScalar(x);
chudy@google.com902ebe52012-06-29 14:21:22 +0000249 return mScalar;
250}
251
chudy@google.com97cee972012-08-07 20:41:37 +0000252SkString* SkObjectParser::TextToString(const void* text, size_t byteLength) {
robertphillips@google.com94acc702012-09-06 18:43:21 +0000253 SkString* mText = new SkString(6+byteLength+1);
254 mText->append("Text: ");
255 mText->append((char*) text, byteLength);
chudy@google.com97cee972012-08-07 20:41:37 +0000256 return mText;
chudy@google.com902ebe52012-06-29 14:21:22 +0000257}