Update the Skia gyp files to use the external android sources.
Review URL: http://codereview.appspot.com/5336048

git-svn-id: http://skia.googlecode.com/svn/trunk@2598 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/gyp/android_system.gyp b/gyp/android_system.gyp
index 6818f69..85e70b8 100644
--- a/gyp/android_system.gyp
+++ b/gyp/android_system.gyp
@@ -16,7 +16,7 @@
   # toolchain and they are not expected to be present on the host OS.
   #
   'variables': {
-    'android_repo%': '../../android_tools',
+    'android_repo%': '../../android',
   },
   'android_repo%': '<(android_repo)',
 
@@ -29,29 +29,29 @@
       'target_name': 'ft2',
       'type': 'static_library',
       'sources': [
-        '<(android_repo)/external/freetype/src/base/ftbbox.c',
-        '<(android_repo)/external/freetype/src/base/ftbitmap.c',
-        '<(android_repo)/external/freetype/src/base/ftglyph.c',
-        '<(android_repo)/external/freetype/src/base/ftlcdfil.c',
-        '<(android_repo)/external/freetype/src/base/ftstroke.c',
-        '<(android_repo)/external/freetype/src/base/ftxf86.c',
-        '<(android_repo)/external/freetype/src/base/ftbase.c',
-        '<(android_repo)/external/freetype/src/base/ftsystem.c',
-        '<(android_repo)/external/freetype/src/base/ftinit.c',
-        '<(android_repo)/external/freetype/src/base/ftgasp.c',
-        '<(android_repo)/external/freetype/src/base/ftfstype.c',
-        '<(android_repo)/external/freetype/src/raster/raster.c',
-        '<(android_repo)/external/freetype/src/sfnt/sfnt.c',
-        '<(android_repo)/external/freetype/src/smooth/smooth.c',
-        '<(android_repo)/external/freetype/src/autofit/autofit.c',
-        '<(android_repo)/external/freetype/src/truetype/truetype.c',
-        '<(android_repo)/external/freetype/src/cff/cff.c',
-        '<(android_repo)/external/freetype/src/psnames/psnames.c',
-        '<(android_repo)/external/freetype/src/pshinter/pshinter.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftbbox.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftbitmap.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftglyph.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftlcdfil.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftstroke.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftxf86.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftbase.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftsystem.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftinit.c',
+        '<(android_repo)/third_party/externals/freetype/src/base/ftgasp.c',
+#        '<(android_repo)/third_party/externals/freetype/src/base/ftfstype.c',
+        '<(android_repo)/third_party/externals/freetype/src/raster/raster.c',
+        '<(android_repo)/third_party/externals/freetype/src/sfnt/sfnt.c',
+        '<(android_repo)/third_party/externals/freetype/src/smooth/smooth.c',
+        '<(android_repo)/third_party/externals/freetype/src/autofit/autofit.c',
+        '<(android_repo)/third_party/externals/freetype/src/truetype/truetype.c',
+        '<(android_repo)/third_party/externals/freetype/src/cff/cff.c',
+        '<(android_repo)/third_party/externals/freetype/src/psnames/psnames.c',
+        '<(android_repo)/third_party/externals/freetype/src/pshinter/pshinter.c',
       ],
       'include_dirs': [
-        '<(android_repo)/external/freetype/builds',
-        '<(android_repo)/external/freetype/include',
+        '<(android_repo)/third_party/externals/freetype/builds',
+        '<(android_repo)/third_party/externals/freetype/include',
       ],
       'cflags': [
         '-W',
@@ -64,7 +64,7 @@
       ],
       'direct_dependent_settings': {
         'include_dirs': [
-          '<(android_repo)/external/freetype/include',  # For ft2build.h
+          '<(android_repo)/third_party/externals/freetype/include',  # For ft2build.h
         ],
       }
     },
@@ -72,13 +72,13 @@
       'target_name': 'expat',
       'type': 'static_library',
       'sources': [
-        '<(android_repo)/external/expat/lib/xmlparse.c',
-        '<(android_repo)/external/expat/lib/xmlrole.c',
-        '<(android_repo)/external/expat/lib/xmltok.c',
+        '<(android_repo)/third_party/externals/expat/lib/xmlparse.c',
+        '<(android_repo)/third_party/externals/expat/lib/xmlrole.c',
+        '<(android_repo)/third_party/externals/expat/lib/xmltok.c',
       ],
       'include_dirs': [
-        '<(android_repo)/external/expat',
-        '<(android_repo)/external/expat/lib',
+        '<(android_repo)/third_party/externals/expat',
+        '<(android_repo)/third_party/externals/expat/lib',
       ],
       'cflags': [
         '-Wall',
@@ -89,7 +89,7 @@
       ],
       'direct_dependent_settings': {
         'include_dirs': [
-          '<(android_repo)/external/expat/lib',  # For expat.h
+          '<(android_repo)/third_party/externals/expat/lib',  # For expat.h
         ],
       }
     },
@@ -97,12 +97,12 @@
       'target_name': 'gif',
       'type': 'static_library',
       'sources': [
-        '<(android_repo)/external/gif/dgif_lib.c',
-        '<(android_repo)/external/gif/gifalloc.c',
-        '<(android_repo)/external/gif/gif_err.c',
+        '<(android_repo)/third_party/externals/gif/dgif_lib.c',
+        '<(android_repo)/third_party/externals/gif/gifalloc.c',
+        '<(android_repo)/third_party/externals/gif/gif_err.c',
       ],
       'include_dirs': [
-        '<(android_repo)/external/gif',
+        '<(android_repo)/third_party/externals/gif',
       ],
       'cflags': [
         '-Wno-format',
@@ -110,7 +110,7 @@
       ],
       'direct_dependent_settings': {
         'include_dirs': [
-          '<(android_repo)/external/gif',
+          '<(android_repo)/third_party/externals/gif',
         ],
       }
     },
@@ -118,33 +118,33 @@
       'target_name': 'png',
       'type': 'static_library',
       'sources': [
-        '<(android_repo)/external/png/png.c',
-        '<(android_repo)/external/png/pngerror.c',
-        '<(android_repo)/external/png/pnggccrd.c',
-        '<(android_repo)/external/png/pngget.c',
-        '<(android_repo)/external/png/pngmem.c',
-        '<(android_repo)/external/png/pngpread.c',
-        '<(android_repo)/external/png/pngread.c',
-        '<(android_repo)/external/png/pngrio.c',
-        '<(android_repo)/external/png/pngrtran.c',
-        '<(android_repo)/external/png/pngrutil.c',
-        '<(android_repo)/external/png/pngset.c',
-        '<(android_repo)/external/png/pngtrans.c',
-        '<(android_repo)/external/png/pngvcrd.c',
-        '<(android_repo)/external/png/pngwio.c',
-        '<(android_repo)/external/png/pngwrite.c',
-        '<(android_repo)/external/png/pngwtran.c',
-        '<(android_repo)/external/png/pngwutil.c',
+        '<(android_repo)/third_party/externals/png/png.c',
+        '<(android_repo)/third_party/externals/png/pngerror.c',
+        '<(android_repo)/third_party/externals/png/pnggccrd.c',
+        '<(android_repo)/third_party/externals/png/pngget.c',
+        '<(android_repo)/third_party/externals/png/pngmem.c',
+        '<(android_repo)/third_party/externals/png/pngpread.c',
+        '<(android_repo)/third_party/externals/png/pngread.c',
+        '<(android_repo)/third_party/externals/png/pngrio.c',
+        '<(android_repo)/third_party/externals/png/pngrtran.c',
+        '<(android_repo)/third_party/externals/png/pngrutil.c',
+        '<(android_repo)/third_party/externals/png/pngset.c',
+        '<(android_repo)/third_party/externals/png/pngtrans.c',
+        '<(android_repo)/third_party/externals/png/pngvcrd.c',
+        '<(android_repo)/third_party/externals/png/pngwio.c',
+        '<(android_repo)/third_party/externals/png/pngwrite.c',
+        '<(android_repo)/third_party/externals/png/pngwtran.c',
+        '<(android_repo)/third_party/externals/png/pngwutil.c',
       ],
       'include_dirs': [
-        '<(android_repo)/external/png',
+        '<(android_repo)/third_party/externals/png',
       ],
       'cflags': [
         '-fvisibility=hidden',
       ],
       'direct_dependent_settings': {
         'include_dirs': [
-          '<(android_repo)/external/png',
+          '<(android_repo)/third_party/externals/png',
         ],
       }
     },
diff --git a/gyp/common_conditions.gypi b/gyp/common_conditions.gypi
index 759d895..766a04f 100644
--- a/gyp/common_conditions.gypi
+++ b/gyp/common_conditions.gypi
@@ -157,6 +157,11 @@
 
         ],
         'conditions': [
+          [ 'skia_target_arch == "arm" and arm_thumb == 1', {
+            'cflags': [
+              '-mthumb',
+            ],
+          }],
           [ 'skia_target_arch == "arm" and armv7 == 1', {
             'defines': [
               '__ARM_ARCH__=7',
diff --git a/src/ports/SkFontHost_FreeType.cpp b/src/ports/SkFontHost_FreeType.cpp
index fa3c96a..1a3fad9 100644
--- a/src/ports/SkFontHost_FreeType.cpp
+++ b/src/ports/SkFontHost_FreeType.cpp
@@ -322,8 +322,10 @@
 }
 
 static bool canEmbed(FT_Face face) {
-// The android port of FreeType does not build
-#if defined(FT_FSTYPE_RESTRICTED_LICENSE_EMBEDDING)
+// The Android freetype library does not compile the FT_Get_FSType_Flags
+// function, so we are required to add the !defined(SK_BUILD_FOR_ANDROID) until
+// support is added to Androids port of freetype.
+#if defined(FT_FSTYPE_RESTRICTED_LICENSE_EMBEDDING) && !defined(SK_BUILD_FOR_ANDROID)
     FT_UShort fsType = FT_Get_FSType_Flags(face);
     return (fsType & (FT_FSTYPE_RESTRICTED_LICENSE_EMBEDDING |
                       FT_FSTYPE_BITMAP_EMBEDDING_ONLY)) == 0;