diff options
author | Baligh Uddin <baligh@google.com> | 2013-11-01 16:01:55 -0700 |
---|---|---|
committer | Baligh Uddin <baligh@google.com> | 2013-11-01 16:01:55 -0700 |
commit | ec502fb532582da0f3141560bc451df3902ce463 (patch) | |
tree | bfd8e692b73dee4749734ca317b4707988dfae3a /core/SkPaintOptionsAndroid.cpp | |
parent | 5588ded0ae11d6fa36e1771747b82b7831db906b (diff) | |
parent | 53a521c76400a3e6d64dc96396390b746ec1e48e (diff) | |
download | src-idea133.tar.gz |
Merge remote-tracking branch 'origin/kitkat-dev'chromium_org-pre-replicationidea133
Diffstat (limited to 'core/SkPaintOptionsAndroid.cpp')
-rw-r--r-- | core/SkPaintOptionsAndroid.cpp | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/core/SkPaintOptionsAndroid.cpp b/core/SkPaintOptionsAndroid.cpp new file mode 100644 index 00000000..31f489cb --- /dev/null +++ b/core/SkPaintOptionsAndroid.cpp @@ -0,0 +1,44 @@ + +/* + * Copyright 2012 The Android Open Source Project + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + +#include "SkPaintOptionsAndroid.h" +#include "SkFlattenableBuffers.h" +#include "SkTDict.h" +#include "SkThread.h" +#include <cstring> + +#ifdef SK_BUILD_FOR_ANDROID + +SkLanguage SkLanguage::getParent() const { + SkASSERT(!fTag.isEmpty()); + const char* tag = fTag.c_str(); + + // strip off the rightmost "-.*" + char* parentTagEnd = strrchr(tag, '-'); + if (parentTagEnd == NULL) { + return SkLanguage(); + } + size_t parentTagLen = parentTagEnd - tag; + return SkLanguage(tag, parentTagLen); +} + +void SkPaintOptionsAndroid::flatten(SkFlattenableWriteBuffer& buffer) const { + buffer.writeUInt(fFontVariant); + buffer.writeString(fLanguage.getTag().c_str()); + buffer.writeBool(fUseFontFallbacks); +} + +void SkPaintOptionsAndroid::unflatten(SkFlattenableReadBuffer& buffer) { + fFontVariant = (FontVariant)buffer.readUInt(); + SkString tag; + buffer.readString(&tag); + fLanguage = SkLanguage(tag); + fUseFontFallbacks = buffer.readBool(); +} + +#endif |