| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "SkCanvas.h" | 8 #include "SkCanvas.h" |
| 9 #include "SkData.h" | 9 #include "SkData.h" |
| 10 #include "SkDOM.h" | 10 #include "SkDOM.h" |
| 11 #include "SkParse.h" | 11 #include "SkParse.h" |
| 12 #include "SkStream.h" | 12 #include "SkStream.h" |
| 13 #include "SkSVGCanvas.h" | 13 #include "SkSVGCanvas.h" |
| 14 #include "SkXMLWriter.h" | 14 #include "SkXMLWriter.h" |
| 15 #include "Test.h" | 15 #include "Test.h" |
| 16 | 16 |
| 17 #include <string.h> | 17 #include <string.h> |
| 18 | 18 |
| 19 namespace { | 19 namespace { |
| 20 | 20 |
| 21 void check_text_node(skiatest::Reporter* reporter, | 21 void check_text_node(skiatest::Reporter* reporter, |
| 22 const SkDOM& dom, | 22 const SkDOM& dom, |
| 23 const SkDOM::Node* root, | 23 const SkDOM::Node* root, |
| 24 const SkPoint& offset, | 24 const SkPoint& offset, |
| 25 unsigned scalarsPerPos, | 25 unsigned scalarsPerPos, |
| 26 const char* expected) { | 26 const char* expected) { |
| 27 if (root == NULL) { | 27 if (root == nullptr) { |
| 28 ERRORF(reporter, "root element not found."); | 28 ERRORF(reporter, "root element not found."); |
| 29 return; | 29 return; |
| 30 } | 30 } |
| 31 | 31 |
| 32 const SkDOM::Node* textElem = dom.getFirstChild(root, "text"); | 32 const SkDOM::Node* textElem = dom.getFirstChild(root, "text"); |
| 33 if (textElem == NULL) { | 33 if (textElem == nullptr) { |
| 34 ERRORF(reporter, "<text> element not found."); | 34 ERRORF(reporter, "<text> element not found."); |
| 35 return; | 35 return; |
| 36 } | 36 } |
| 37 REPORTER_ASSERT(reporter, dom.getType(textElem) == SkDOM::kElement_Type); | 37 REPORTER_ASSERT(reporter, dom.getType(textElem) == SkDOM::kElement_Type); |
| 38 | 38 |
| 39 const SkDOM::Node* textNode= dom.getFirstChild(textElem); | 39 const SkDOM::Node* textNode= dom.getFirstChild(textElem); |
| 40 REPORTER_ASSERT(reporter, textNode != NULL); | 40 REPORTER_ASSERT(reporter, textNode != nullptr); |
| 41 if (textNode != NULL) { | 41 if (textNode != nullptr) { |
| 42 REPORTER_ASSERT(reporter, dom.getType(textNode) == SkDOM::kText_Type); | 42 REPORTER_ASSERT(reporter, dom.getType(textNode) == SkDOM::kText_Type); |
| 43 REPORTER_ASSERT(reporter, strcmp(expected, dom.getName(textNode)) == 0); | 43 REPORTER_ASSERT(reporter, strcmp(expected, dom.getName(textNode)) == 0); |
| 44 } | 44 } |
| 45 | 45 |
| 46 int textLen = SkToInt(strlen(expected)); | 46 int textLen = SkToInt(strlen(expected)); |
| 47 | 47 |
| 48 const char* x = dom.findAttr(textElem, "x"); | 48 const char* x = dom.findAttr(textElem, "x"); |
| 49 REPORTER_ASSERT(reporter, x != NULL); | 49 REPORTER_ASSERT(reporter, x != nullptr); |
| 50 if (x != NULL) { | 50 if (x != nullptr) { |
| 51 int xposCount = (scalarsPerPos < 1) ? 1 : textLen; | 51 int xposCount = (scalarsPerPos < 1) ? 1 : textLen; |
| 52 REPORTER_ASSERT(reporter, SkParse::Count(x) == xposCount); | 52 REPORTER_ASSERT(reporter, SkParse::Count(x) == xposCount); |
| 53 | 53 |
| 54 SkAutoTMalloc<SkScalar> xpos(xposCount); | 54 SkAutoTMalloc<SkScalar> xpos(xposCount); |
| 55 SkParse::FindScalars(x, xpos.get(), xposCount); | 55 SkParse::FindScalars(x, xpos.get(), xposCount); |
| 56 if (scalarsPerPos < 1) { | 56 if (scalarsPerPos < 1) { |
| 57 REPORTER_ASSERT(reporter, xpos[0] == offset.x()); | 57 REPORTER_ASSERT(reporter, xpos[0] == offset.x()); |
| 58 } else { | 58 } else { |
| 59 for (int i = 0; i < xposCount; ++i) { | 59 for (int i = 0; i < xposCount; ++i) { |
| 60 REPORTER_ASSERT(reporter, xpos[i] == SkIntToScalar(expected[i]))
; | 60 REPORTER_ASSERT(reporter, xpos[i] == SkIntToScalar(expected[i]))
; |
| 61 } | 61 } |
| 62 } | 62 } |
| 63 } | 63 } |
| 64 | 64 |
| 65 const char* y = dom.findAttr(textElem, "y"); | 65 const char* y = dom.findAttr(textElem, "y"); |
| 66 REPORTER_ASSERT(reporter, y != NULL); | 66 REPORTER_ASSERT(reporter, y != nullptr); |
| 67 if (y != NULL) { | 67 if (y != nullptr) { |
| 68 int yposCount = (scalarsPerPos < 2) ? 1 : textLen; | 68 int yposCount = (scalarsPerPos < 2) ? 1 : textLen; |
| 69 REPORTER_ASSERT(reporter, SkParse::Count(y) == yposCount); | 69 REPORTER_ASSERT(reporter, SkParse::Count(y) == yposCount); |
| 70 | 70 |
| 71 SkAutoTMalloc<SkScalar> ypos(yposCount); | 71 SkAutoTMalloc<SkScalar> ypos(yposCount); |
| 72 SkParse::FindScalars(y, ypos.get(), yposCount); | 72 SkParse::FindScalars(y, ypos.get(), yposCount); |
| 73 if (scalarsPerPos < 2) { | 73 if (scalarsPerPos < 2) { |
| 74 REPORTER_ASSERT(reporter, ypos[0] == offset.y()); | 74 REPORTER_ASSERT(reporter, ypos[0] == offset.y()); |
| 75 } else { | 75 } else { |
| 76 for (int i = 0; i < yposCount; ++i) { | 76 for (int i = 0; i < yposCount; ++i) { |
| 77 REPORTER_ASSERT(reporter, ypos[i] == -SkIntToScalar(expected[i])
); | 77 REPORTER_ASSERT(reporter, ypos[i] == -SkIntToScalar(expected[i])
); |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 140 { "abcd " , "abcd " }, // we allow one trailing whitespace char | 140 { "abcd " , "abcd " }, // we allow one trailing whitespace char |
| 141 { "abcd " , "abcd " }, // because it makes no difference and | 141 { "abcd " , "abcd " }, // because it makes no difference and |
| 142 { "abcd\t " , "abcd\t" }, // simplifies the implementation | 142 { "abcd\t " , "abcd\t" }, // simplifies the implementation |
| 143 { "\t\t \t ab \t\t \t cd \t\t \t ", "ab cd " }, | 143 { "\t\t \t ab \t\t \t cd \t\t \t ", "ab cd " }, |
| 144 }; | 144 }; |
| 145 | 145 |
| 146 for (unsigned i = 0; i < SK_ARRAY_COUNT(tests); ++i) { | 146 for (unsigned i = 0; i < SK_ARRAY_COUNT(tests); ++i) { |
| 147 test_whitespace_pos(reporter, tests[i].tst_in, tests[i].tst_out); | 147 test_whitespace_pos(reporter, tests[i].tst_in, tests[i].tst_out); |
| 148 } | 148 } |
| 149 } | 149 } |
| OLD | NEW |