add debugging test for building SkDescriptor
update some samples



git-svn-id: http://skia.googlecode.com/svn/trunk@1237 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/samplecode/SampleTestGL.cpp b/samplecode/SampleTestGL.cpp
deleted file mode 100644
index a0dfea3..0000000
--- a/samplecode/SampleTestGL.cpp
+++ /dev/null
@@ -1,242 +0,0 @@
-#include "SampleCode.h"
-#include "SkView.h"
-#include "SkCanvas.h"
-#include "SkCornerPathEffect.h"
-#include "SkCullPoints.h"
-#include "SkGradientShader.h"
-#include "SkPath.h"
-#include "SkRegion.h"
-#include "SkShader.h"
-#include "SkUtils.h"
-
-#include <AGL/agl.h>
-#include <OpenGL/gl.h>
-
-static void test_draw_gl(SkCanvas* canvas) {
-    const float verts[] = {
-        10, 10, 250, 250, 490, 10
-    };
-    const float texs[] = {
-        0, 0, 0.5f, 0, 1, 1
-    };
-    const uint8_t colors[] = {
-        0, 0, 0, 1,
-        128, 0, 0, 1,
-        255, 255, 0, 1
-    };
-    
-    glEnableClientState(GL_VERTEX_ARRAY);
-    glVertexPointer(2, GL_FLOAT, 0, verts);
-
-    glDisableClientState(GL_TEXTURE_COORD_ARRAY);
-//    glTexCoordPointer(2, GL_FLOAT, 0, texs);
-
-    glEnableClientState(GL_COLOR_ARRAY);
-    glColorPointer(4, GL_UNSIGNED_BYTE, 0, colors);
-
-    glDrawArrays(GL_TRIANGLES, 0, 3);
-}
-
-static const char* gVertShaderText =
-    "varying vec2 uv;"
-    "void main(void) {"
-    "    gl_Position = gl_ModelViewProjectionMatrix * gl_Vertex;"
-    "    uv = vec2(gl_Color);"
-    "}";
-
-static const char* gFragShaderText =
-    "varying vec2 uv;"
-    "void main(void) {"
-    "    float u = uv.x;"
-    "    float v = uv.y;"
-    "    if (u*u > v) {"
-"    gl_FragColor = vec4(0.0, 0, 0, 0.0);"
-    "    } else {"
-    "    gl_FragColor = vec4(0, 1.0, 0, 1.0);"
-    "}"
-    "}";
-
-static bool compile_shader(GLuint shader) {
-    glCompileShader(shader);
-
-    GLint success;
-    glGetShaderiv(shader, GL_COMPILE_STATUS, &success);
-    if (!success) {
-        GLchar buffer[256];
-        glGetShaderInfoLog(shader, sizeof(buffer), NULL, buffer);
-        SkDebugf("---- glCompileShader failed: %s\n", buffer);
-        return false;
-    }
-    return true;
-}
-
-static bool link_program(GLuint program) {
-    glLinkProgram(program);
-    GLint success;
-    glGetProgramiv(program, GL_LINK_STATUS, &success);
-    if (!success) {
-        GLchar buffer[256];
-        glGetProgramInfoLog(program, sizeof(buffer), NULL, buffer);
-        SkDebugf("---- glLinkProgram failed: %s\n", buffer);
-        return false;
-    }
-    return true;
-}
-
-static void test_glshader(SkCanvas* canvas) {
-    GLuint vertShader = glCreateShader(GL_VERTEX_SHADER);
-    GLuint fragShader = glCreateShader(GL_FRAGMENT_SHADER);
-
-    glShaderSource(vertShader, 1, &gVertShaderText, NULL);
-    glShaderSource(fragShader, 1, &gFragShaderText, NULL);
-
-    if (!compile_shader(vertShader)) { return; }
-    if (!compile_shader(fragShader)) { return; }
-
-    GLuint program = glCreateProgram();
-    glAttachShader(program, vertShader);
-    glAttachShader(program, fragShader);
-    if (link_program(program)) {
-        glUseProgram(program);
-        test_draw_gl(canvas);
-        glUseProgram(0);
-    }
-    glDeleteProgram(program);
-    glDeleteShader(vertShader);
-    glDeleteShader(fragShader);
-}
-
-static void setmatrix6(SkMatrix* matrix, const float val[]) {
-    matrix->reset();
-    for (int i = 0; i < 6; i++) {
-        matrix->set(i, val[i]);
-    }
-}
-
-static void testinvert() {
-    SkMatrix matrix;
-
-    const float vals[] = { 0,9,.000001,10000,0,0 };
-    setmatrix6(&matrix, vals);
-
-    const float vals2[] = { 0,100,71,9,0,7 };
-    SkMatrix tmp;
-    setmatrix6(&tmp, vals2);
-    
-    matrix.preConcat(tmp);
-    matrix.dump();
-
-    SkMatrix inverse;
-    matrix.invert(&inverse);
-    inverse.dump();
-    
-    matrix.preConcat(inverse);
-    matrix.dump();
-
-//    o2dContext.setTransform(0,9,.000001,10000,0,0);
-//    o2dContext.transform(0,100,71,9,0,7);
-//    o2dContext.setTransform(0,6,95,4,1,0);
-}
-
-/*
- [0]	9.9999997e-005	float
- [1]	9.0000003e-006	float
- [2]	7.0000001e-006	float
- [3]	1000000.0	float
- [4]	90639.000	float
- [5]	70000.000	float
- [6]	0.00000000	float
- [7]	0.00000000	float
- [8]	1.0000000	float
- */
-static void testinvert2() {
-    const float val[] = {
-        9.9999997e-005, 9.0000003e-006, 7.0000001e-006,
-        1000000.0, 90639.000, 70000.000
-    };
-    SkMatrix matrix;
-    setmatrix6(&matrix, val);
-    matrix.dump();
-
-    SkMatrix inverse;
-    matrix.invert(&inverse);
-    inverse.dump();
-
-    matrix.preConcat(inverse);
-    matrix.dump();
-    // result is that matrix[3] is 49550 instead of 0 :(
-}
-
-static void show_ramp(SkCanvas* canvas, const SkRect& r) {
-    SkPoint pts[] = { r.fLeft, 0, r.fRight, 0 };
-    SkColor colors[] = { SK_ColorRED, SK_ColorBLUE };
-    SkShader* s = SkGradientShader::CreateLinear(pts, colors, NULL, 2,
-                                                 SkShader::kRepeat_TileMode);
-    SkPaint p;
-    p.setShader(s)->unref();
-    canvas->drawRect(r, p);
-    canvas->translate(r.width() + SkIntToScalar(8), 0);
-    p.setDither(true);
-    canvas->drawRect(r, p);
-}
-
-class TestGLView : public SkView {
-public:
-	TestGLView() {
-        testinvert2();
-    }
-    
-protected:
-    // overrides from SkEventSink
-    virtual bool onQuery(SkEvent* evt) {
-        if (SampleCode::TitleQ(*evt)) {
-            SampleCode::TitleR(evt, "TestGL");
-            return true;
-        }
-        return this->INHERITED::onQuery(evt);
-    }
-    
-    void drawBG(SkCanvas* canvas) {
-        canvas->drawColor(0xFFDDDDDD);
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        drawBG(canvas);
-
-        if (canvas->getViewport(NULL)) {
-            test_glshader(canvas);
-            return;
-        }
-        
-        SkRect r;
-        r.set(0, 0, 100, 100);
-        
-        canvas->translate(SkIntToScalar(20), SkIntToScalar(20));
-        
-        SkPaint paint;
-        paint.setAntiAlias(false);
-        paint.setColor(SK_ColorRED);
-        
-        canvas->drawRect(r, paint);
-
-        canvas->translate(r.width() + SkIntToScalar(20), 0);
-        paint.setStyle(SkPaint::kStroke_Style);
-        canvas->drawRect(r, paint);
-
-        canvas->translate(r.width() + SkIntToScalar(20), 0);
-        paint.setStrokeWidth(SkIntToScalar(5));
-        canvas->drawRect(r, paint);
-        
-        canvas->translate(r.width() * 10/9, 0);
-        show_ramp(canvas, r);
-    }
-    
-private:
-    typedef SkView INHERITED;
-};
-
-//////////////////////////////////////////////////////////////////////////////
-
-static SkView* MyFactory() { return new TestGLView; }
-static SkViewRegister reg(MyFactory);
-
diff --git a/samplecode/SampleTextBox.cpp b/samplecode/SampleTextBox.cpp
index a2db011..37a6be0 100644
--- a/samplecode/SampleTextBox.cpp
+++ b/samplecode/SampleTextBox.cpp
@@ -32,7 +32,7 @@
 	"a decent respect to the opinions of mankind requires that they should "
 	"declare the causes which impel them to the separation.";
 
-class TextBoxView : public SkView {
+class TextBoxView : public SampleView {
 public:
 	TextBoxView() {
 #ifdef SK_BUILD_FOR_WIN
@@ -60,13 +60,7 @@
         return this->INHERITED::onQuery(evt);
     }
 
-    void drawBG(SkCanvas* canvas) {
-        canvas->drawColor(SK_ColorWHITE);
-    }
-
-    virtual void onDraw(SkCanvas* canvas) {
-        this->drawBG(canvas);
-
+    virtual void onDrawContent(SkCanvas* canvas) {
 		SkScalar margin = 20;
         SkTextBox tbox;
 		tbox.setMode(SkTextBox::kLineBreak_Mode);
diff --git a/samplecode/SampleTinyBitmap.cpp b/samplecode/SampleTinyBitmap.cpp
index ffbff25..0841474 100644
--- a/samplecode/SampleTinyBitmap.cpp
+++ b/samplecode/SampleTinyBitmap.cpp
@@ -30,11 +30,12 @@
     return bm;
 }
 
-class TinyBitmapView : public SkView {
+class TinyBitmapView : public SampleView {
     SkBitmap    fBM;
 public:
 	TinyBitmapView() {
         fBM = make_bitmap();
+        this->setBGColor(0xFFDDDDDD);
     }
     
 protected:
@@ -47,14 +48,6 @@
         return this->INHERITED::onQuery(evt);
     }
     
-    void drawBG(SkCanvas* canvas) {
-        SkIPoint size;
-        if (canvas->getViewport(&size)) {
-            SkDebugf("");
-        }
-        canvas->drawColor(0xFFDDDDDD);
-    }
-    
     static void setBitmapOpaque(SkBitmap* bm, bool isOpaque) {
         SkAutoLockPixels alp(*bm);  // needed for ctable
         bm->setIsOpaque(isOpaque);
@@ -64,9 +57,7 @@
         }
     }
     
-    virtual void onDraw(SkCanvas* canvas) {
-        drawBG(canvas);
-        
+    virtual void onDrawContent(SkCanvas* canvas) {
         SkShader* s = SkShader::CreateBitmapShader(fBM, SkShader::kRepeat_TileMode,
                                                    SkShader::kMirror_TileMode);
         SkPaint paint;
diff --git a/src/core/SkPaint.cpp b/src/core/SkPaint.cpp
index 95b8ed3..14c0397 100644
--- a/src/core/SkPaint.cpp
+++ b/src/core/SkPaint.cpp
@@ -1315,6 +1315,10 @@
 
 #define MIN_SIZE_FOR_EFFECT_BUFFER  1024
 
+#ifdef SK_DEBUG
+    #define TEST_DESC
+#endif
+
 void SkPaint::descriptorProc(const SkMatrix* deviceMatrix,
                              void (*proc)(const SkDescriptor*, void*),
                              void* context, bool ignoreGamma) const {
@@ -1376,6 +1380,49 @@
     SkASSERT(descSize == desc->getLength());
     desc->computeChecksum();
 
+#ifdef TEST_DESC
+    {
+        // Check that we completely write the bytes in desc (our key), and that
+        // there are no uninitialized bytes. If there were, then we would get
+        // false-misses (or worse, false-hits) in our fontcache.
+        //
+        // We do this buy filling 2 others, one with 0s and the other with 1s
+        // and create those, and then check that all 3 are identical.
+        SkAutoDescriptor    ad1(descSize);
+        SkAutoDescriptor    ad2(descSize);
+        SkDescriptor*       desc1 = ad1.getDesc();
+        SkDescriptor*       desc2 = ad2.getDesc();
+        
+        memset(desc1, 0x00, descSize);
+        memset(desc2, 0xFF, descSize);
+        
+        desc1->init();
+        desc2->init();
+        desc1->addEntry(kRec_SkDescriptorTag, sizeof(rec), &rec);
+        desc2->addEntry(kRec_SkDescriptorTag, sizeof(rec), &rec);
+        
+        if (pe) {
+            add_flattenable(desc1, kPathEffect_SkDescriptorTag, &peBuffer);
+            add_flattenable(desc2, kPathEffect_SkDescriptorTag, &peBuffer);
+        }
+        if (mf) {
+            add_flattenable(desc1, kMaskFilter_SkDescriptorTag, &mfBuffer);
+            add_flattenable(desc2, kMaskFilter_SkDescriptorTag, &mfBuffer);
+        }
+        if (ra) {
+            add_flattenable(desc1, kRasterizer_SkDescriptorTag, &raBuffer);
+            add_flattenable(desc2, kRasterizer_SkDescriptorTag, &raBuffer);
+        }
+        
+        SkASSERT(descSize == desc1->getLength());
+        SkASSERT(descSize == desc2->getLength());
+        desc1->computeChecksum();
+        desc2->computeChecksum();
+        SkASSERT(!memcmp(desc, desc1, descSize));
+        SkASSERT(!memcmp(desc, desc2, descSize));
+    }
+#endif
+    
     proc(desc, context);
 }