add SkSafeRef / SkSafeUnref as inline static functions, to use in place of our
existing obj->safeRef(), which is unsafe since it can its 'if (this)' can be optimized away by some compilers. fix some overflows in mimpmap generation git-svn-id: http://skia.googlecode.com/svn/trunk@181 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
parent
ba974ccbdd
commit
149e2f6159
@ -130,5 +130,22 @@ private:
|
|||||||
dst = src; \
|
dst = src; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
|
||||||
|
/** Check if the argument is non-null, and if so, call obj->ref()
|
||||||
|
*/
|
||||||
|
template <typename T> static inline void SkSafeRef(T* obj) {
|
||||||
|
if (obj) {
|
||||||
|
obj->ref();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Check if the argument is non-null, and if so, call obj->unref()
|
||||||
|
*/
|
||||||
|
template <typename T> static inline void SkSafeUnref(T* obj) {
|
||||||
|
if (obj) {
|
||||||
|
obj->unref();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -149,12 +149,26 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
void drawBG(SkCanvas* canvas) {
|
void drawBG(SkCanvas* canvas) {
|
||||||
canvas->drawColor(SK_ColorWHITE);
|
canvas->drawColor(SK_ColorGRAY);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void onDraw(SkCanvas* canvas) {
|
virtual void onDraw(SkCanvas* canvas) {
|
||||||
this->drawBG(canvas);
|
this->drawBG(canvas);
|
||||||
|
|
||||||
|
if (true) {
|
||||||
|
SkRect r;
|
||||||
|
r.set(SkIntToScalar(0), SkIntToScalar(0),
|
||||||
|
SkIntToScalar(220), SkIntToScalar(120));
|
||||||
|
SkPaint p;
|
||||||
|
canvas->saveLayer(&r, &p);
|
||||||
|
canvas->drawColor(0xFFFF0000);
|
||||||
|
p.setAlpha(1); // or 0
|
||||||
|
p.setPorterDuffXfermode(SkPorterDuff::kSrc_Mode);
|
||||||
|
canvas->drawOval(r, p);
|
||||||
|
canvas->restore();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (false) {
|
if (false) {
|
||||||
SkRect r;
|
SkRect r;
|
||||||
r.set(SkIntToScalar(0), SkIntToScalar(0),
|
r.set(SkIntToScalar(0), SkIntToScalar(0),
|
||||||
|
@ -26,6 +26,10 @@
|
|||||||
#include "SkPackBits.h"
|
#include "SkPackBits.h"
|
||||||
#include <new>
|
#include <new>
|
||||||
|
|
||||||
|
static bool isPos32Bits(const Sk64& value) {
|
||||||
|
return !value.isNeg() && value.is32();
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef SK_SUPPORT_MIPMAP
|
#ifdef SK_SUPPORT_MIPMAP
|
||||||
struct MipLevel {
|
struct MipLevel {
|
||||||
void* fPixels;
|
void* fPixels;
|
||||||
@ -40,9 +44,17 @@ struct SkBitmap::MipMap : SkNoncopyable {
|
|||||||
// Pixels[]
|
// Pixels[]
|
||||||
|
|
||||||
static MipMap* Alloc(int levelCount, size_t pixelSize) {
|
static MipMap* Alloc(int levelCount, size_t pixelSize) {
|
||||||
MipMap* mm = (MipMap*)sk_malloc_throw(sizeof(MipMap) +
|
if (levelCount < 0) {
|
||||||
levelCount * sizeof(MipLevel) +
|
return NULL;
|
||||||
pixelSize);
|
}
|
||||||
|
Sk64 size;
|
||||||
|
size.setMul(levelCount + 1, sizeof(MipLevel));
|
||||||
|
size.add(sizeof(MipMap));
|
||||||
|
size.add(pixelSize);
|
||||||
|
if (!isPos32Bits(size)) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
MipMap* mm = (MipMap*)sk_malloc_throw(size.get32());
|
||||||
mm->fRefCnt = 1;
|
mm->fRefCnt = 1;
|
||||||
mm->fLevelCount = levelCount;
|
mm->fLevelCount = levelCount;
|
||||||
return mm;
|
return mm;
|
||||||
@ -54,18 +66,15 @@ struct SkBitmap::MipMap : SkNoncopyable {
|
|||||||
const void* pixels() const { return levels() + fLevelCount; }
|
const void* pixels() const { return levels() + fLevelCount; }
|
||||||
void* pixels() { return levels() + fLevelCount; }
|
void* pixels() { return levels() + fLevelCount; }
|
||||||
|
|
||||||
void safeRef() {
|
void ref() {
|
||||||
if (this) {
|
if (SK_MaxS32 == sk_atomic_inc(&fRefCnt)) {
|
||||||
SkASSERT(fRefCnt > 0);
|
sk_throw();
|
||||||
sk_atomic_inc(&fRefCnt);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void safeUnref() {
|
void unref() {
|
||||||
if (this) {
|
SkASSERT(fRefCnt > 0);
|
||||||
SkASSERT(fRefCnt > 0);
|
if (sk_atomic_dec(&fRefCnt) == 1) {
|
||||||
if (sk_atomic_dec(&fRefCnt) == 1) {
|
sk_free(this);
|
||||||
sk_free(this);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -98,7 +107,7 @@ SkBitmap& SkBitmap::operator=(const SkBitmap& src) {
|
|||||||
// inc src reference counts
|
// inc src reference counts
|
||||||
src.fPixelRef->safeRef();
|
src.fPixelRef->safeRef();
|
||||||
#ifdef SK_SUPPORT_MIPMAP
|
#ifdef SK_SUPPORT_MIPMAP
|
||||||
src.fMipMap->safeRef();
|
SkSafeRef(src.fMipMap);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// we reset our locks if we get blown away
|
// we reset our locks if we get blown away
|
||||||
@ -175,33 +184,40 @@ int SkBitmap::ComputeBytesPerPixel(SkBitmap::Config config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int SkBitmap::ComputeRowBytes(Config c, int width) {
|
int SkBitmap::ComputeRowBytes(Config c, int width) {
|
||||||
int rowBytes = 0;
|
if (width < 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
Sk64 rowBytes;
|
||||||
|
rowBytes.setZero();
|
||||||
|
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case kNo_Config:
|
case kNo_Config:
|
||||||
case kRLE_Index8_Config:
|
case kRLE_Index8_Config:
|
||||||
// assume that the bitmap has no pixels to draw to
|
|
||||||
rowBytes = 0;
|
|
||||||
break;
|
break;
|
||||||
case kA1_Config:
|
case kA1_Config:
|
||||||
rowBytes = (width + 7) >> 3;
|
rowBytes.set(width);
|
||||||
|
rowBytes.add(7);
|
||||||
|
rowBytes.shiftRight(3);
|
||||||
break;
|
break;
|
||||||
case kA8_Config:
|
case kA8_Config:
|
||||||
case kIndex8_Config:
|
case kIndex8_Config:
|
||||||
rowBytes = width;
|
rowBytes.set(width);
|
||||||
break;
|
break;
|
||||||
case kRGB_565_Config:
|
case kRGB_565_Config:
|
||||||
case kARGB_4444_Config:
|
case kARGB_4444_Config:
|
||||||
rowBytes = width << 1;
|
rowBytes.set(width);
|
||||||
|
rowBytes.shiftLeft(1);
|
||||||
break;
|
break;
|
||||||
case kARGB_8888_Config:
|
case kARGB_8888_Config:
|
||||||
rowBytes = width << 2;
|
rowBytes.set(width);
|
||||||
|
rowBytes.shiftLeft(2);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
SkASSERT(!"unknown config");
|
SkASSERT(!"unknown config");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return rowBytes;
|
return isPos32Bits(rowBytes) ? rowBytes.get32() : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sk64 SkBitmap::ComputeSize64(Config c, int width, int height) {
|
Sk64 SkBitmap::ComputeSize64(Config c, int width, int height) {
|
||||||
@ -212,18 +228,25 @@ Sk64 SkBitmap::ComputeSize64(Config c, int width, int height) {
|
|||||||
|
|
||||||
size_t SkBitmap::ComputeSize(Config c, int width, int height) {
|
size_t SkBitmap::ComputeSize(Config c, int width, int height) {
|
||||||
Sk64 size = SkBitmap::ComputeSize64(c, width, height);
|
Sk64 size = SkBitmap::ComputeSize64(c, width, height);
|
||||||
if (size.isNeg() || !size.is32()) {
|
return isPos32Bits(size) ? size.get32() : 0;
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
return size.get32();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SkBitmap::setConfig(Config c, int width, int height, int rowBytes) {
|
void SkBitmap::setConfig(Config c, int width, int height, int rowBytes) {
|
||||||
this->freePixels();
|
this->freePixels();
|
||||||
|
|
||||||
|
if ((width | height | rowBytes) < 0) {
|
||||||
|
ERROR:
|
||||||
|
this->reset();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (rowBytes == 0) {
|
if (rowBytes == 0) {
|
||||||
rowBytes = SkBitmap::ComputeRowBytes(c, width);
|
rowBytes = SkBitmap::ComputeRowBytes(c, width);
|
||||||
|
if (0 == rowBytes && kNo_Config != c) {
|
||||||
|
goto ERROR;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fConfig = SkToU8(c);
|
fConfig = SkToU8(c);
|
||||||
fWidth = width;
|
fWidth = width;
|
||||||
fHeight = height;
|
fHeight = height;
|
||||||
@ -248,8 +271,10 @@ void SkBitmap::updatePixelsFromRef() const {
|
|||||||
} else {
|
} else {
|
||||||
SkASSERT(0 == fPixelLockCount);
|
SkASSERT(0 == fPixelLockCount);
|
||||||
fPixels = NULL;
|
fPixels = NULL;
|
||||||
fColorTable->safeUnref();
|
if (fColorTable) {
|
||||||
fColorTable = NULL;
|
fColorTable->unref();
|
||||||
|
fColorTable = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -315,8 +340,10 @@ void SkBitmap::freePixels() {
|
|||||||
// if we're gonna free the pixels, we certainly need to free the mipmap
|
// if we're gonna free the pixels, we certainly need to free the mipmap
|
||||||
this->freeMipMap();
|
this->freeMipMap();
|
||||||
|
|
||||||
fColorTable->safeUnref();
|
if (fColorTable) {
|
||||||
fColorTable = NULL;
|
fColorTable->unref();
|
||||||
|
fColorTable = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if (NULL != fPixelRef) {
|
if (NULL != fPixelRef) {
|
||||||
if (fPixelLockCount > 0) {
|
if (fPixelLockCount > 0) {
|
||||||
@ -332,8 +359,10 @@ void SkBitmap::freePixels() {
|
|||||||
|
|
||||||
void SkBitmap::freeMipMap() {
|
void SkBitmap::freeMipMap() {
|
||||||
#ifdef SK_SUPPORT_MIPMAP
|
#ifdef SK_SUPPORT_MIPMAP
|
||||||
fMipMap->safeUnref();
|
if (fMipMap) {
|
||||||
fMipMap = NULL;
|
fMipMap->unref();
|
||||||
|
fMipMap = NULL;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -359,7 +388,7 @@ SkMallocPixelRef::SkMallocPixelRef(void* storage, size_t size,
|
|||||||
}
|
}
|
||||||
|
|
||||||
SkMallocPixelRef::~SkMallocPixelRef() {
|
SkMallocPixelRef::~SkMallocPixelRef() {
|
||||||
fCTable->safeUnref();
|
SkSafeUnref(fCTable);
|
||||||
sk_free(fStorage);
|
sk_free(fStorage);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -899,12 +928,17 @@ void SkBitmap::buildMipMap(bool forceRebuild) {
|
|||||||
return; // don't build mipmaps for these configs
|
return; // don't build mipmaps for these configs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SkAutoLockPixels alp(*this);
|
||||||
|
if (!this->readyToDraw()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// whip through our loop to compute the exact size needed
|
// whip through our loop to compute the exact size needed
|
||||||
size_t size = 0;
|
size_t size = 0;
|
||||||
int maxLevels = 0;
|
int maxLevels = 0;
|
||||||
{
|
{
|
||||||
unsigned width = this->width();
|
int width = this->width();
|
||||||
unsigned height = this->height();
|
int height = this->height();
|
||||||
for (;;) {
|
for (;;) {
|
||||||
width >>= 1;
|
width >>= 1;
|
||||||
height >>= 1;
|
height >>= 1;
|
||||||
@ -915,20 +949,29 @@ void SkBitmap::buildMipMap(bool forceRebuild) {
|
|||||||
maxLevels += 1;
|
maxLevels += 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// nothing to build
|
||||||
if (0 == maxLevels) {
|
if (0 == maxLevels) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
MipMap* mm = MipMap::Alloc(maxLevels, size);
|
SkBitmap srcBM(*this);
|
||||||
|
srcBM.lockPixels();
|
||||||
|
if (!srcBM.readyToDraw()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
MipMap* mm = MipMap::Alloc(maxLevels, size);
|
||||||
|
if (NULL == mm) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
MipLevel* level = mm->levels();
|
MipLevel* level = mm->levels();
|
||||||
uint8_t* addr = (uint8_t*)mm->pixels();
|
uint8_t* addr = (uint8_t*)mm->pixels();
|
||||||
|
int width = this->width();
|
||||||
unsigned width = this->width();
|
int height = this->height();
|
||||||
unsigned height = this->height();
|
|
||||||
unsigned rowBytes = this->rowBytes();
|
unsigned rowBytes = this->rowBytes();
|
||||||
SkBitmap srcBM(*this), dstBM;
|
SkBitmap dstBM;
|
||||||
|
|
||||||
srcBM.lockPixels();
|
|
||||||
|
|
||||||
for (int i = 0; i < maxLevels; i++) {
|
for (int i = 0; i < maxLevels; i++) {
|
||||||
width >>= 1;
|
width >>= 1;
|
||||||
@ -943,8 +986,8 @@ void SkBitmap::buildMipMap(bool forceRebuild) {
|
|||||||
dstBM.setConfig(config, width, height, rowBytes);
|
dstBM.setConfig(config, width, height, rowBytes);
|
||||||
dstBM.setPixels(addr);
|
dstBM.setPixels(addr);
|
||||||
|
|
||||||
for (unsigned y = 0; y < height; y++) {
|
for (int y = 0; y < height; y++) {
|
||||||
for (unsigned x = 0; x < width; x++) {
|
for (int x = 0; x < width; x++) {
|
||||||
proc(&dstBM, x, y, srcBM);
|
proc(&dstBM, x, y, srcBM);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1251,7 +1294,7 @@ void SkBitmap::unflatten(SkFlattenableReadBuffer& buffer) {
|
|||||||
} else {
|
} else {
|
||||||
buffer.skip(size);
|
buffer.skip(size);
|
||||||
}
|
}
|
||||||
ctable->safeUnref();
|
SkSafeUnref(ctable);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SERIALIZE_PIXELTYPE_NONE:
|
case SERIALIZE_PIXELTYPE_NONE:
|
||||||
|
@ -73,8 +73,8 @@
|
|||||||
009490320FB0A5B90063C792 /* SampleLayerMask.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 009490310FB0A5B90063C792 /* SampleLayerMask.cpp */; };
|
009490320FB0A5B90063C792 /* SampleLayerMask.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 009490310FB0A5B90063C792 /* SampleLayerMask.cpp */; };
|
||||||
009CC9190F65918A002185BE /* SampleFontScalerTest.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 009CC9180F65918A002185BE /* SampleFontScalerTest.cpp */; };
|
009CC9190F65918A002185BE /* SampleFontScalerTest.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 009CC9180F65918A002185BE /* SampleFontScalerTest.cpp */; };
|
||||||
00A41E4B0EFC312F00C9CBEB /* SampleArc.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 00A41E4A0EFC312F00C9CBEB /* SampleArc.cpp */; };
|
00A41E4B0EFC312F00C9CBEB /* SampleArc.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 00A41E4A0EFC312F00C9CBEB /* SampleArc.cpp */; };
|
||||||
00A8A3EE0FC25993006ED638 /* SampleEffects.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 00A8A3ED0FC25993006ED638 /* SampleEffects.cpp */; };
|
|
||||||
00C55DA10F8552DC000CAC09 /* SampleGradients.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 00C55DA00F8552DC000CAC09 /* SampleGradients.cpp */; };
|
00C55DA10F8552DC000CAC09 /* SampleGradients.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 00C55DA00F8552DC000CAC09 /* SampleGradients.cpp */; };
|
||||||
|
00FF39140FC6ED2C00915187 /* SampleEffects.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 00FF39130FC6ED2C00915187 /* SampleEffects.cpp */; };
|
||||||
0156F80407C56A3000C6122B /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 0156F80307C56A3000C6122B /* Foundation.framework */; };
|
0156F80407C56A3000C6122B /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 0156F80307C56A3000C6122B /* Foundation.framework */; };
|
||||||
01FC44D507BD3BB800D228F4 /* Quartz.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 01FC44D407BD3BB800D228F4 /* Quartz.framework */; };
|
01FC44D507BD3BB800D228F4 /* Quartz.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 01FC44D407BD3BB800D228F4 /* Quartz.framework */; };
|
||||||
8D0C4E8D0486CD37000505A6 /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 0867D6AAFE840B52C02AAC07 /* InfoPlist.strings */; };
|
8D0C4E8D0486CD37000505A6 /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 0867D6AAFE840B52C02AAC07 /* InfoPlist.strings */; };
|
||||||
@ -198,9 +198,9 @@
|
|||||||
009490310FB0A5B90063C792 /* SampleLayerMask.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleLayerMask.cpp; path = ../../samplecode/SampleLayerMask.cpp; sourceTree = SOURCE_ROOT; };
|
009490310FB0A5B90063C792 /* SampleLayerMask.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleLayerMask.cpp; path = ../../samplecode/SampleLayerMask.cpp; sourceTree = SOURCE_ROOT; };
|
||||||
009CC9180F65918A002185BE /* SampleFontScalerTest.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleFontScalerTest.cpp; path = ../../samplecode/SampleFontScalerTest.cpp; sourceTree = SOURCE_ROOT; };
|
009CC9180F65918A002185BE /* SampleFontScalerTest.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleFontScalerTest.cpp; path = ../../samplecode/SampleFontScalerTest.cpp; sourceTree = SOURCE_ROOT; };
|
||||||
00A41E4A0EFC312F00C9CBEB /* SampleArc.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleArc.cpp; path = ../../samplecode/SampleArc.cpp; sourceTree = SOURCE_ROOT; };
|
00A41E4A0EFC312F00C9CBEB /* SampleArc.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleArc.cpp; path = ../../samplecode/SampleArc.cpp; sourceTree = SOURCE_ROOT; };
|
||||||
00A8A3ED0FC25993006ED638 /* SampleEffects.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleEffects.cpp; path = ../../samplecode/SampleEffects.cpp; sourceTree = SOURCE_ROOT; };
|
|
||||||
00C55DA00F8552DC000CAC09 /* SampleGradients.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleGradients.cpp; path = ../../samplecode/SampleGradients.cpp; sourceTree = SOURCE_ROOT; };
|
00C55DA00F8552DC000CAC09 /* SampleGradients.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleGradients.cpp; path = ../../samplecode/SampleGradients.cpp; sourceTree = SOURCE_ROOT; };
|
||||||
00D6B5CB0F72DC4300C466B9 /* SampleFuzz.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleFuzz.cpp; path = ../../samplecode/SampleFuzz.cpp; sourceTree = SOURCE_ROOT; };
|
00D6B5CB0F72DC4300C466B9 /* SampleFuzz.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleFuzz.cpp; path = ../../samplecode/SampleFuzz.cpp; sourceTree = SOURCE_ROOT; };
|
||||||
|
00FF39130FC6ED2C00915187 /* SampleEffects.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = SampleEffects.cpp; path = ../../samplecode/SampleEffects.cpp; sourceTree = SOURCE_ROOT; };
|
||||||
0156F80307C56A3000C6122B /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = /System/Library/Frameworks/Foundation.framework; sourceTree = "<absolute>"; };
|
0156F80307C56A3000C6122B /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = /System/Library/Frameworks/Foundation.framework; sourceTree = "<absolute>"; };
|
||||||
01FC44D407BD3BB800D228F4 /* Quartz.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Quartz.framework; path = /System/Library/Frameworks/Quartz.framework; sourceTree = "<absolute>"; };
|
01FC44D407BD3BB800D228F4 /* Quartz.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Quartz.framework; path = /System/Library/Frameworks/Quartz.framework; sourceTree = "<absolute>"; };
|
||||||
0867D6ABFE840B52C02AAC07 /* English */ = {isa = PBXFileReference; fileEncoding = 10; lastKnownFileType = text.plist.strings; name = English; path = English.lproj/InfoPlist.strings; sourceTree = "<group>"; };
|
0867D6ABFE840B52C02AAC07 /* English */ = {isa = PBXFileReference; fileEncoding = 10; lastKnownFileType = text.plist.strings; name = English; path = English.lproj/InfoPlist.strings; sourceTree = "<group>"; };
|
||||||
@ -233,11 +233,11 @@
|
|||||||
00003C610EFC2287000FF73A /* samples */ = {
|
00003C610EFC2287000FF73A /* samples */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
00FF39130FC6ED2C00915187 /* SampleEffects.cpp */,
|
||||||
007A7CA40F01658C00A2D6EE /* SamplePicture.cpp */,
|
007A7CA40F01658C00A2D6EE /* SamplePicture.cpp */,
|
||||||
00D6B5CB0F72DC4300C466B9 /* SampleFuzz.cpp */,
|
00D6B5CB0F72DC4300C466B9 /* SampleFuzz.cpp */,
|
||||||
00C55DA00F8552DC000CAC09 /* SampleGradients.cpp */,
|
00C55DA00F8552DC000CAC09 /* SampleGradients.cpp */,
|
||||||
009490310FB0A5B90063C792 /* SampleLayerMask.cpp */,
|
009490310FB0A5B90063C792 /* SampleLayerMask.cpp */,
|
||||||
00A8A3ED0FC25993006ED638 /* SampleEffects.cpp */,
|
|
||||||
003145310FB9B48F00B10956 /* SampleShapes.cpp */,
|
003145310FB9B48F00B10956 /* SampleShapes.cpp */,
|
||||||
009CC9180F65918A002185BE /* SampleFontScalerTest.cpp */,
|
009CC9180F65918A002185BE /* SampleFontScalerTest.cpp */,
|
||||||
007A7CA50F01658C00A2D6EE /* SamplePoints.cpp */,
|
007A7CA50F01658C00A2D6EE /* SamplePoints.cpp */,
|
||||||
@ -490,6 +490,7 @@
|
|||||||
files = (
|
files = (
|
||||||
00003C660EFC22A8000FF73A /* SampleApp.cpp in Sources */,
|
00003C660EFC22A8000FF73A /* SampleApp.cpp in Sources */,
|
||||||
00003C680EFC22A8000FF73A /* SamplePath.cpp in Sources */,
|
00003C680EFC22A8000FF73A /* SamplePath.cpp in Sources */,
|
||||||
|
00003C690EFC22A8000FF73A /* SamplePathEffects.cpp in Sources */,
|
||||||
00003C740EFC22CE000FF73A /* SkEvent.cpp in Sources */,
|
00003C740EFC22CE000FF73A /* SkEvent.cpp in Sources */,
|
||||||
00003C750EFC22CE000FF73A /* SkEventSink.cpp in Sources */,
|
00003C750EFC22CE000FF73A /* SkEventSink.cpp in Sources */,
|
||||||
00003C760EFC22CE000FF73A /* SkMetaData.cpp in Sources */,
|
00003C760EFC22CE000FF73A /* SkMetaData.cpp in Sources */,
|
||||||
@ -532,6 +533,7 @@
|
|||||||
007A7CB80F01658C00A2D6EE /* SampleStrokeText.cpp in Sources */,
|
007A7CB80F01658C00A2D6EE /* SampleStrokeText.cpp in Sources */,
|
||||||
007A7CBA0F01658C00A2D6EE /* SampleText.cpp in Sources */,
|
007A7CBA0F01658C00A2D6EE /* SampleText.cpp in Sources */,
|
||||||
007A7CBB0F01658C00A2D6EE /* SampleTextAlpha.cpp in Sources */,
|
007A7CBB0F01658C00A2D6EE /* SampleTextAlpha.cpp in Sources */,
|
||||||
|
007A7CBC0F01658C00A2D6EE /* SampleTextEffects.cpp in Sources */,
|
||||||
007A7CBD0F01658C00A2D6EE /* SampleTextOnPath.cpp in Sources */,
|
007A7CBD0F01658C00A2D6EE /* SampleTextOnPath.cpp in Sources */,
|
||||||
007A7CBE0F01658C00A2D6EE /* SampleTiling.cpp in Sources */,
|
007A7CBE0F01658C00A2D6EE /* SampleTiling.cpp in Sources */,
|
||||||
007A7CBF0F01658C00A2D6EE /* SampleTypeface.cpp in Sources */,
|
007A7CBF0F01658C00A2D6EE /* SampleTypeface.cpp in Sources */,
|
||||||
@ -550,9 +552,7 @@
|
|||||||
003145200FB99CCE00B10956 /* SkRectShape.cpp in Sources */,
|
003145200FB99CCE00B10956 /* SkRectShape.cpp in Sources */,
|
||||||
003145320FB9B48F00B10956 /* SampleShapes.cpp in Sources */,
|
003145320FB9B48F00B10956 /* SampleShapes.cpp in Sources */,
|
||||||
003145370FB9BA4000B10956 /* SkGroupShape.cpp in Sources */,
|
003145370FB9BA4000B10956 /* SkGroupShape.cpp in Sources */,
|
||||||
007A7CBC0F01658C00A2D6EE /* SampleTextEffects.cpp in Sources */,
|
00FF39140FC6ED2C00915187 /* SampleEffects.cpp in Sources */,
|
||||||
00003C690EFC22A8000FF73A /* SamplePathEffects.cpp in Sources */,
|
|
||||||
00A8A3EE0FC25993006ED638 /* SampleEffects.cpp in Sources */,
|
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user