OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2011 The Android Open Source Project | 2 * Copyright 2011 The Android Open Source Project |
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 "SkFontConfigParser_android.h" | 8 #include "SkFontConfigParser_android.h" |
9 #include "SkFontMgr_android.h" | 9 #include "SkFontMgr_android.h" |
10 #include "SkStream.h" | 10 #include "SkStream.h" |
(...skipping 245 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
256 size_t len = strlen(tag); | 256 size_t len = strlen(tag); |
257 if (MEMEQ("family", tag, len)) { | 257 if (MEMEQ("family", tag, len)) { |
258 family_element_handler(self, attributes); | 258 family_element_handler(self, attributes); |
259 } else if (MEMEQ("font", tag, len)) { | 259 } else if (MEMEQ("font", tag, len)) { |
260 font_element_handler(self, attributes); | 260 font_element_handler(self, attributes); |
261 } else if (MEMEQ("alias", tag, len)) { | 261 } else if (MEMEQ("alias", tag, len)) { |
262 alias_element_handler(self, attributes); | 262 alias_element_handler(self, attributes); |
263 } | 263 } |
264 } | 264 } |
265 | 265 |
266 static void trim_string(SkString* s) { | |
267 char* str = s->writable_str(); | |
268 const char* start = str; | |
269 const char* end = start + s->size(); | |
270 for (; *start == ' ' || *start == '\n'|| *start == '\r' || *start == '\t'; + +start) { } | |
djsollen
2015/05/08 13:56:13
while I can appreciate the compactness of this it
bungeman-skia
2015/05/08 15:05:04
Done.
| |
271 if (start != end) { | |
272 for (--end; *end == ' ' || *end == '\n'|| *end == '\r' || *end == '\t'; --end) { } | |
djsollen
2015/05/08 13:56:13
comment why you need the --end at the begin and en
bungeman-skia
2015/05/08 15:05:04
Done.
| |
273 ++end; | |
274 } | |
275 memmove(str, start, end - start); | |
276 s->resize(end - start); | |
277 } | |
278 | |
266 static void XMLCALL end_element_handler(void* data, const char* tag) { | 279 static void XMLCALL end_element_handler(void* data, const char* tag) { |
267 FamilyData* self = static_cast<FamilyData*>(data); | 280 FamilyData* self = static_cast<FamilyData*>(data); |
268 size_t len = strlen(tag); | 281 size_t len = strlen(tag); |
269 if (MEMEQ("family", tag, len)) { | 282 if (MEMEQ("family", tag, len)) { |
270 *self->fFamilies.append() = self->fCurrentFamily.detach(); | 283 *self->fFamilies.append() = self->fCurrentFamily.detach(); |
271 } else if (MEMEQ("font", tag, len)) { | 284 } else if (MEMEQ("font", tag, len)) { |
272 XML_SetCharacterDataHandler(self->fParser, NULL); | 285 XML_SetCharacterDataHandler(self->fParser, NULL); |
286 trim_string(&self->fCurrentFontInfo->fFileName); | |
273 } | 287 } |
274 } | 288 } |
275 | 289 |
276 } // lmpParser | 290 } // lmpParser |
277 | 291 |
278 namespace jbParser { | 292 namespace jbParser { |
279 | 293 |
280 /** | 294 /** |
281 * Handler for arbitrary text. This is used to parse the text inside each name | 295 * Handler for arbitrary text. This is used to parse the text inside each name |
282 * or file tag. The resulting strings are put into the fNames or FontFileInfo ar rays. | 296 * or file tag. The resulting strings are put into the fNames or FontFileInfo ar rays. |
(...skipping 367 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
650 const char* tag = fTag.c_str(); | 664 const char* tag = fTag.c_str(); |
651 | 665 |
652 // strip off the rightmost "-.*" | 666 // strip off the rightmost "-.*" |
653 const char* parentTagEnd = strrchr(tag, '-'); | 667 const char* parentTagEnd = strrchr(tag, '-'); |
654 if (parentTagEnd == NULL) { | 668 if (parentTagEnd == NULL) { |
655 return SkLanguage(); | 669 return SkLanguage(); |
656 } | 670 } |
657 size_t parentTagLen = parentTagEnd - tag; | 671 size_t parentTagLen = parentTagEnd - tag; |
658 return SkLanguage(tag, parentTagLen); | 672 return SkLanguage(tag, parentTagLen); |
659 } | 673 } |
OLD | NEW |