| Index: third_party/sqlite/patches/0009-Custom-shell.c-helpers-to-load-Chromium-s-ICU-data.patch | 
| diff --git a/third_party/sqlite/patches/0009-Custom-shell.c-helpers-to-load-Chromium-s-ICU-data.patch b/third_party/sqlite/patches/0009-Custom-shell.c-helpers-to-load-Chromium-s-ICU-data.patch | 
| deleted file mode 100644 | 
| index a8d2ad0d8cf27ceead97cfce4254a9b3cd9a70c6..0000000000000000000000000000000000000000 | 
| --- a/third_party/sqlite/patches/0009-Custom-shell.c-helpers-to-load-Chromium-s-ICU-data.patch | 
| +++ /dev/null | 
| @@ -1,145 +0,0 @@ | 
| -From 787cbd4344a6ab9c5915b77dfd02f91697f60b01 Mon Sep 17 00:00:00 2001 | 
| -From: "tc@google.com" <tc@google.com> | 
| -Date: Tue, 6 Jan 2009 22:39:41 +0000 | 
| -Subject: [PATCH 09/23] Custom shell.c helpers to load Chromium's ICU data. | 
| - | 
| -History uses fts3 with an icu-based segmenter.  These changes allow building a | 
| -sqlite3 binary for Linux or Windows which can read those files. | 
| - | 
| -Original review URL: https://codereview.chromium.org/42250 | 
| ---- | 
| - third_party/sqlite/src/Makefile.linux-gcc    |  7 ++++++ | 
| - third_party/sqlite/src/main.mk               |  2 +- | 
| - third_party/sqlite/src/src/shell.c           | 10 +++++++++ | 
| - third_party/sqlite/src/src/shell_icu_linux.c | 27 +++++++++++++++++++++++ | 
| - third_party/sqlite/src/src/shell_icu_win.c   | 32 ++++++++++++++++++++++++++++ | 
| - 5 files changed, 77 insertions(+), 1 deletion(-) | 
| - create mode 100644 third_party/sqlite/src/src/shell_icu_linux.c | 
| - create mode 100644 third_party/sqlite/src/src/shell_icu_win.c | 
| - | 
| -diff --git a/third_party/sqlite/src/Makefile.linux-gcc b/third_party/sqlite/src/Makefile.linux-gcc | 
| -index e631816..f60f1a1 100644 | 
| ---- a/third_party/sqlite/src/Makefile.linux-gcc | 
| -+++ b/third_party/sqlite/src/Makefile.linux-gcc | 
| -@@ -86,6 +86,13 @@ OPTS += -DOS_UNIX=1 | 
| - # purposes. | 
| - OPTS += -DDEFAULT_ENABLE_RECOVER=1 | 
| - | 
| -+# Support for loading Chromium ICU data in sqlite3. | 
| -+ifeq ($(shell uname -s),Darwin) | 
| -+SHELL_ICU = | 
| -+else | 
| -+SHELL_ICU = $(TOP)/src/shell_icu_linux.c -licuuc | 
| -+endif | 
| -+ | 
| - #### The suffix to add to executable files.  ".exe" for windows. | 
| - #    Nothing for unix. | 
| - # | 
| -diff --git a/third_party/sqlite/src/main.mk b/third_party/sqlite/src/main.mk | 
| -index 65dd690..d20103f 100644 | 
| ---- a/third_party/sqlite/src/main.mk | 
| -+++ b/third_party/sqlite/src/main.mk | 
| -@@ -358,7 +358,7 @@ libsqlite3.a:	$(LIBOBJ) | 
| - | 
| - sqlite3$(EXE):	$(TOP)/src/shell.c libsqlite3.a sqlite3.h | 
| - 	$(TCCX) $(READLINE_FLAGS) -o sqlite3$(EXE)                  \ | 
| --		$(TOP)/src/shell.c                                  \ | 
| -+		$(TOP)/src/shell.c $(SHELL_ICU)                     \ | 
| - 		libsqlite3.a $(LIBREADLINE) $(TLIBS) $(THREADLIB) | 
| - | 
| - # This target creates a directory named "tsrc" and fills it with | 
| -diff --git a/third_party/sqlite/src/src/shell.c b/third_party/sqlite/src/src/shell.c | 
| -index aab70b2..ffb4698 100644 | 
| ---- a/third_party/sqlite/src/src/shell.c | 
| -+++ b/third_party/sqlite/src/src/shell.c | 
| -@@ -2663,6 +2663,16 @@ int main(int argc, char **argv){ | 
| -   int i; | 
| -   int rc = 0; | 
| - | 
| -+  /* Begin evanm patch. */ | 
| -+#if !defined(__APPLE__) | 
| -+  extern int sqlite_shell_init_icu(); | 
| -+  if( !sqlite_shell_init_icu() ){ | 
| -+    fprintf(stderr, "%s: warning: couldn't find icudt38.dll; " | 
| -+                    "queries against ICU FTS tables will fail.\n", argv[0]); | 
| -+  } | 
| -+#endif /* !defined(__APPLE__) */ | 
| -+  /* End evanm patch. */ | 
| -+ | 
| -   Argv0 = argv[0]; | 
| -   main_init(&data); | 
| -   stdin_is_interactive = isatty(0); | 
| -diff --git a/third_party/sqlite/src/src/shell_icu_linux.c b/third_party/sqlite/src/src/shell_icu_linux.c | 
| -new file mode 100644 | 
| -index 0000000..4ad0e42 | 
| ---- /dev/null | 
| -+++ b/third_party/sqlite/src/src/shell_icu_linux.c | 
| -@@ -0,0 +1,27 @@ | 
| -+/* Copyright 2007 Google Inc. All Rights Reserved. | 
| -+**/ | 
| -+ | 
| -+#include <limits.h> | 
| -+#include <unistd.h> | 
| -+#include "unicode/putil.h" | 
| -+#include "unicode/udata.h" | 
| -+ | 
| -+/* | 
| -+** This function attempts to load the ICU data tables from a data file. | 
| -+** Returns 0 on failure, nonzero on success. | 
| -+** This a hack job of icu_utils.cc:Initialize().  It's Chrome-specific code. | 
| -+*/ | 
| -+int sqlite_shell_init_icu() { | 
| -+  char bin_dir[PATH_MAX + 1]; | 
| -+  int bin_dir_size = readlink("/proc/self/exe", bin_dir, PATH_MAX); | 
| -+  if (bin_dir_size < 0 || bin_dir_size > PATH_MAX) | 
| -+    return 0; | 
| -+  bin_dir[bin_dir_size] = 0;; | 
| -+ | 
| -+  u_setDataDirectory(bin_dir); | 
| -+  // Only look for the packaged data file; | 
| -+  // the default behavior is to look for individual files. | 
| -+  UErrorCode err = U_ZERO_ERROR; | 
| -+  udata_setFileAccess(UDATA_ONLY_PACKAGES, &err); | 
| -+  return err == U_ZERO_ERROR; | 
| -+} | 
| -diff --git a/third_party/sqlite/src/src/shell_icu_win.c b/third_party/sqlite/src/src/shell_icu_win.c | 
| -new file mode 100644 | 
| -index 0000000..67ebbf4 | 
| ---- /dev/null | 
| -+++ b/third_party/sqlite/src/src/shell_icu_win.c | 
| -@@ -0,0 +1,32 @@ | 
| -+/* Copyright 2011 Google Inc. All Rights Reserved. | 
| -+**/ | 
| -+ | 
| -+#include <windows.h> | 
| -+#include "unicode/udata.h" | 
| -+ | 
| -+/* | 
| -+** This function attempts to load the ICU data tables from a DLL. | 
| -+** Returns 0 on failure, nonzero on success. | 
| -+** This a hack job of icu_utils.cc:Initialize().  It's Chrome-specific code. | 
| -+*/ | 
| -+ | 
| -+#define ICU_DATA_SYMBOL "icudt" U_ICU_VERSION_SHORT "_dat" | 
| -+int sqlite_shell_init_icu() { | 
| -+  HMODULE module; | 
| -+  FARPROC addr; | 
| -+  UErrorCode err; | 
| -+ | 
| -+  // Chrome dropped U_ICU_VERSION_SHORT from the icu data dll name. | 
| -+  module = LoadLibrary(L"icudt.dll"); | 
| -+  if (!module) | 
| -+    return 0; | 
| -+ | 
| -+  addr = GetProcAddress(module, ICU_DATA_SYMBOL); | 
| -+  if (!addr) | 
| -+    return 0; | 
| -+ | 
| -+  err = U_ZERO_ERROR; | 
| -+  udata_setCommonData(addr, &err); | 
| -+ | 
| -+  return 1; | 
| -+} | 
| --- | 
| -2.2.1 | 
| - | 
|  |