aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core
diff options
context:
space:
mode:
Diffstat (limited to 'src/core')
-rw-r--r--src/core/SkGlyph.h45
-rw-r--r--src/core/SkScalerContext.cpp2
2 files changed, 34 insertions, 13 deletions
diff --git a/src/core/SkGlyph.h b/src/core/SkGlyph.h
index 06c1d76fb3..b54635277b 100644
--- a/src/core/SkGlyph.h
+++ b/src/core/SkGlyph.h
@@ -172,34 +172,57 @@ public:
*/
static unsigned ComputeRowBytes(unsigned width, SkMask::Format format) {
unsigned rb = width;
- if (SkMask::kBW_Format == format) {
+ switch (format) {
+ case SkMask::kBW_Format:
rb = BitsToBytes(rb);
- } else if (SkMask::kARGB32_Format == format) {
+ break;
+ case SkMask::kA8_Format:
+ rb = SkAlign4(rb);
+ break;
+ case SkMask::k3D_Format:
+ rb = SkAlign4(rb);
+ break;
+ case SkMask::kARGB32_Format:
rb <<= 2;
- } else if (SkMask::kLCD16_Format == format) {
+ break;
+ case SkMask::kLCD16_Format:
rb = SkAlign4(rb << 1);
- } else {
- rb = SkAlign4(rb);
+ break;
+ default:
+ SK_ABORT("Unknown mask format.");
+ break;
}
return rb;
}
size_t allocImage(SkArenaAlloc* alloc) {
size_t allocSize;
- if (SkMask::kBW_Format == fMaskFormat) {
+ switch (static_cast<SkMask::Format>(fMaskFormat)) {
+ case SkMask::kBW_Format:
allocSize = BitsToBytes(fWidth) * fHeight;
fImage = alloc->makeArrayDefault<char>(allocSize);
- } else if (SkMask::kARGB32_Format == fMaskFormat) {
+ break;
+ case SkMask::kA8_Format:
+ allocSize = SkAlign4(fWidth) * fHeight;
+ fImage = alloc->makeArrayDefault<char>(allocSize);
+ break;
+ case SkMask::k3D_Format:
+ allocSize = SkAlign4(fWidth) * fHeight * 3;
+ fImage = alloc->makeArrayDefault<char>(allocSize);
+ break;
+ case SkMask::kARGB32_Format:
allocSize = fWidth * fHeight;
fImage = alloc->makeArrayDefault<uint32_t>(fWidth * fHeight);
allocSize *= sizeof(uint32_t);
- } else if (SkMask::kLCD16_Format == fMaskFormat) {
+ break;
+ case SkMask::kLCD16_Format:
allocSize = SkAlign2(fWidth) * fHeight;
fImage = alloc->makeArrayDefault<uint16_t>(allocSize);
allocSize *= sizeof(uint16_t);
- } else {
- allocSize = SkAlign4(fWidth) * fHeight;
- fImage = alloc->makeArrayDefault<char>(allocSize);
+ break;
+ default:
+ SK_ABORT("Unknown mask format.");
+ break;
}
return allocSize;
}
diff --git a/src/core/SkScalerContext.cpp b/src/core/SkScalerContext.cpp
index 8a1ab60ae8..828f978287 100644
--- a/src/core/SkScalerContext.cpp
+++ b/src/core/SkScalerContext.cpp
@@ -26,8 +26,6 @@
#include "SkStrokeRec.h"
#include "SkWriteBuffer.h"
-#define ComputeBWRowBytes(width) (((unsigned)(width) + 7) >> 3)
-
void SkGlyph::toMask(SkMask* mask) const {
SkASSERT(mask);