summaryrefslogtreecommitdiffstats
path: root/skia/ext
diff options
context:
space:
mode:
authorsenorblanco@chromium.org <senorblanco@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-05-13 13:16:52 +0000
committersenorblanco@chromium.org <senorblanco@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-05-13 13:16:52 +0000
commitd5282e72b2da0b27b2a487d8376c44ad795736dc (patch)
tree7296767f5fcfa3b1cdd46f122e14dfaca1dd7e4a /skia/ext
parent3ac3f51f8261910dbc38ccfa4cdf3d491ba7ecdb (diff)
downloadchromium_src-d5282e72b2da0b27b2a487d8376c44ad795736dc.zip
chromium_src-d5282e72b2da0b27b2a487d8376c44ad795736dc.tar.gz
chromium_src-d5282e72b2da0b27b2a487d8376c44ad795736dc.tar.bz2
This CL updates chrome to the latest version of skia, retrieved via DEPS, and
placed in third_party. All relevant skia changes (for all 3 platforms) have been upstreamed. Most of this CL is mind-numbingly repetitive. Things of interest are: skia.gyp (now points at third_party versions), DEPS, and SkUserConfig.h. stdint.h: Skia now requires C99 integer types, which MSVC doesn't support natively. I have put typedefs in config/win/stdint.h. Note that the new version of skia appears to render rects whose coordinates are "backwards" (ie., x2 < x1 or y2 < y1), which were formerly culled. There were a couple obvious instances of this in the code which I fixed, but there may be more. There were ~35 layout test failures due to minor pixel differences which I rebaselined on Windows and Linux, and 8 genuine failures related to masks and stroked text, which I have put in text_expectations.txt and assigned to myself. (There was another change which broke ~1700 tests on each platform, but I put that change behind an #ifdef for now). R=brettw Review URL: http://codereview.chromium.org/65012 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@15949 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'skia/ext')
-rw-r--r--skia/ext/SkMemory_new_handler.cpp58
-rw-r--r--skia/ext/SkTypeface_fake.cpp17
-rw-r--r--skia/ext/image_operations.cc2
-rw-r--r--skia/ext/image_operations_unittest.cc2
-rw-r--r--skia/ext/skia_utils.cc3
-rw-r--r--skia/ext/skia_utils_unittest.cc2
6 files changed, 79 insertions, 5 deletions
diff --git a/skia/ext/SkMemory_new_handler.cpp b/skia/ext/SkMemory_new_handler.cpp
new file mode 100644
index 0000000..7e45d26
--- /dev/null
+++ b/skia/ext/SkMemory_new_handler.cpp
@@ -0,0 +1,58 @@
+#include "SkTypes.h"
+#include <stdio.h>
+#include <stdlib.h>
+#include <new>
+
+// This implementation of sk_malloc_flags() and friends is identical
+// to SkMemory_malloc.c, except that it disables the CRT's new_handler
+// during malloc(), when SK_MALLOC_THROW is not set (ie., when
+// sk_malloc_flags() would not abort on NULL).
+
+void sk_throw() {
+ SkASSERT(!"sk_throw");
+ abort();
+}
+
+void sk_out_of_memory(void) {
+ SkASSERT(!"sk_out_of_memory");
+ abort();
+}
+
+void* sk_malloc_throw(size_t size) {
+ return sk_malloc_flags(size, SK_MALLOC_THROW);
+}
+
+void* sk_realloc_throw(void* addr, size_t size) {
+ void* p = realloc(addr, size);
+ if (size == 0) {
+ return p;
+ }
+ if (p == NULL) {
+ sk_throw();
+ }
+ return p;
+}
+
+void sk_free(void* p) {
+ if (p) {
+ free(p);
+ }
+}
+
+void* sk_malloc_flags(size_t size, unsigned flags) {
+ std::new_handler old_handler;
+ if (!(flags & SK_MALLOC_THROW)) {
+ old_handler = std::set_new_handler(NULL);
+ }
+ void* p = malloc(size);
+ if (!(flags & SK_MALLOC_THROW)) {
+ std::set_new_handler(old_handler);
+ }
+ if (p == NULL) {
+ if (flags & SK_MALLOC_THROW) {
+ sk_throw();
+ }
+ }
+ return p;
+}
+
diff --git a/skia/ext/SkTypeface_fake.cpp b/skia/ext/SkTypeface_fake.cpp
new file mode 100644
index 0000000..6aaf3b0
--- /dev/null
+++ b/skia/ext/SkTypeface_fake.cpp
@@ -0,0 +1,17 @@
+#include "SkTypeface.h"
+
+// ===== Begin Chrome-specific definitions =====
+
+uint32_t SkTypeface::UniqueID(const SkTypeface* face)
+{
+ return 0;
+}
+
+void SkTypeface::serialize(SkWStream* stream) const {
+}
+
+SkTypeface* SkTypeface::Deserialize(SkStream* stream) {
+ return NULL;
+}
+
+// ===== End Chrome-specific definitions =====
diff --git a/skia/ext/image_operations.cc b/skia/ext/image_operations.cc
index 07fb97b..b6be37f 100644
--- a/skia/ext/image_operations.cc
+++ b/skia/ext/image_operations.cc
@@ -14,8 +14,8 @@
#include "base/logging.h"
#include "base/stack_container.h"
#include "SkBitmap.h"
+#include "SkColorPriv.h"
#include "skia/ext/convolver.h"
-#include "skia/include/SkColorPriv.h"
namespace skia {
diff --git a/skia/ext/image_operations_unittest.cc b/skia/ext/image_operations_unittest.cc
index 8f7e9be..4011c0e 100644
--- a/skia/ext/image_operations_unittest.cc
+++ b/skia/ext/image_operations_unittest.cc
@@ -5,8 +5,8 @@
#include <stdlib.h>
#include "skia/ext/image_operations.h"
-#include "skia/include/SkColorPriv.h"
#include "testing/gtest/include/gtest/gtest.h"
+#include "SkColorPriv.h"
#include "SkBitmap.h"
namespace {
diff --git a/skia/ext/skia_utils.cc b/skia/ext/skia_utils.cc
index 3b5484f..c665c58b 100644
--- a/skia/ext/skia_utils.cc
+++ b/skia/ext/skia_utils.cc
@@ -3,8 +3,7 @@
// found in the LICENSE file.
#include "skia/ext/skia_utils.h"
-#include "skia/include/SkColorPriv.h"
-
+#include "SkColorPriv.h"
#include "SkGradientShader.h"
namespace skia {
diff --git a/skia/ext/skia_utils_unittest.cc b/skia/ext/skia_utils_unittest.cc
index 444a5fc9..37815e5 100644
--- a/skia/ext/skia_utils_unittest.cc
+++ b/skia/ext/skia_utils_unittest.cc
@@ -5,8 +5,8 @@
#include <stdlib.h>
#include "skia/ext/skia_utils.h"
-#include "skia/include/SkColorPriv.h"
#include "testing/gtest/include/gtest/gtest.h"
+#include "SkColorPriv.h"
#include "SkBitmap.h"
TEST(SkiaUtils, SkColorToHSLRed) {