| Index: src/core/SkBitmapProcState_utils.h
|
| diff --git a/src/core/SkBitmapProcState_utils.h b/src/core/SkBitmapProcState_utils.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..3c4c1fa8c67fd1c1dfddc95b018f109a66d4d500
|
| --- /dev/null
|
| +++ b/src/core/SkBitmapProcState_utils.h
|
| @@ -0,0 +1,40 @@
|
| +#ifndef SkBitmapProcState_utils_DEFINED
|
| +#define SkBitmapProcState_utils_DEFINED
|
| +
|
| +// Helper to ensure that when we shift down, we do it w/o sign-extension
|
| +// so the caller doesn't have to manually mask off the top 16 bits
|
| +//
|
| +static unsigned SK_USHIFT16(unsigned x) {
|
| + return x >> 16;
|
| +}
|
| +
|
| +/*
|
| + * The decal_ functions require that
|
| + * 1. dx > 0
|
| + * 2. [fx, fx+dx, fx+2dx, fx+3dx, ... fx+(count-1)dx] are all <= maxX
|
| + *
|
| + * In addition, we use SkFractionalInt to keep more fractional precision than
|
| + * just SkFixed, so we will abort the decal_ call if dx is very small, since
|
| + * the decal_ function just operates on SkFixed. If that were changed, we could
|
| + * skip the very_small test here.
|
| + */
|
| +static inline bool can_truncate_to_fixed_for_decal(SkFractionalInt frX,
|
| + SkFractionalInt frDx,
|
| + int count, unsigned max) {
|
| + SkFixed dx = SkFractionalIntToFixed(frDx);
|
| +
|
| + // if decal_ kept SkFractionalInt precision, this would just be dx <= 0
|
| + // I just made up the 1/256. Just don't want to perceive accumulated error
|
| + // if we truncate frDx and lose its low bits.
|
| + if (dx <= SK_Fixed1 / 256) {
|
| + return false;
|
| + }
|
| +
|
| + // We cast to unsigned so we don't have to check for negative values, which
|
| + // will now appear as very large positive values, and thus fail our test!
|
| + SkFixed fx = SkFractionalIntToFixed(frX);
|
| + return (unsigned)SkFixedFloorToInt(fx) <= max &&
|
| + (unsigned)SkFixedFloorToInt(fx + dx * (count - 1)) < max;
|
| +}
|
| +
|
| +#endif /* #ifndef SkBitmapProcState_utils_DEFINED */
|
|
|