| Index: bench/CmapBench.cpp
|
| diff --git a/bench/CmapBench.cpp b/bench/CmapBench.cpp
|
| index 9697477850e81a96586338c74eb4b295e6be4830..27498ceb9bc15e8796ac398bd72c65f0f3bf209e 100644
|
| --- a/bench/CmapBench.cpp
|
| +++ b/bench/CmapBench.cpp
|
| @@ -53,6 +53,16 @@ static void charsToGlyphs_proc(const SkPaint& paint, const void* text,
|
| }
|
| }
|
|
|
| +static void charsToGlyphsNull_proc(const SkPaint& paint, const void* text,
|
| + size_t len, int glyphCount) {
|
| + SkTypeface::Encoding encoding = paint2Encoding(paint);
|
| +
|
| + SkTypeface* face = paint.getTypeface();
|
| + for (int i = 0; i < LOOP; ++i) {
|
| + face->charsToGlyphs(text, encoding, NULL, glyphCount);
|
| + }
|
| +}
|
| +
|
| class CMAPBench : public SkBenchmark {
|
| TypefaceProc fProc;
|
| SkString fName;
|
| @@ -66,7 +76,7 @@ public:
|
|
|
| for (int i = 0; i < NGLYPHS; ++i) {
|
| // we're just jamming values into utf8, so we must keep it legal
|
| - fText[i] = i;
|
| + fText[i] = 'A' + i;
|
| }
|
| fPaint.setTypeface(SkTypeface::RefDefault())->unref();
|
| }
|
| @@ -90,4 +100,5 @@ private:
|
| DEF_BENCH( return new CMAPBench(p, containsText_proc, "paint_containsText"); )
|
| DEF_BENCH( return new CMAPBench(p, textToGlyphs_proc, "paint_textToGlyphs"); )
|
| DEF_BENCH( return new CMAPBench(p, charsToGlyphs_proc, "face_charsToGlyphs"); )
|
| +DEF_BENCH( return new CMAPBench(p, charsToGlyphsNull_proc, "face_charsToGlyphs_null"); )
|
|
|
|
|