| Index: third_party/re2/Makefile | 
| diff --git a/third_party/re2/Makefile b/third_party/re2/Makefile | 
| index 4ded8ec00d7f033e0fa93845c532978fc41fe0fc..50684595dc5303265e374ad090856712ae47916e 100644 | 
| --- a/third_party/re2/Makefile | 
| +++ b/third_party/re2/Makefile | 
| @@ -2,21 +2,19 @@ | 
| # Use of this source code is governed by a BSD-style | 
| # license that can be found in the LICENSE file. | 
|  | 
| -all: obj/libre2.a obj/so/libre2.so | 
| - | 
| # to build against PCRE for testing or benchmarking, | 
| # uncomment the next two lines | 
| # CCPCRE=-I/usr/local/include -DUSEPCRE | 
| # LDPCRE=-L/usr/local/lib -lpcre | 
|  | 
| -CXX=g++ | 
| -CXXFLAGS=-Wall -O3 -g -pthread  # can override | 
| -RE2_CXXFLAGS=-Wno-sign-compare -c -I. $(CCPCRE)  # required | 
| -LDFLAGS=-pthread | 
| -AR=ar | 
| -ARFLAGS=rsc | 
| -NM=nm | 
| -NMFLAGS=-p | 
| +CXX?=g++ | 
| +CXXFLAGS?=-O3 -g  # can override | 
| +RE2_CXXFLAGS?=-Wall -Wextra -Wno-unused-parameter -Wno-missing-field-initializers -I. $(CCPCRE)  # required | 
| +LDFLAGS?=-pthread | 
| +AR?=ar | 
| +ARFLAGS?=rsc | 
| +NM?=nm | 
| +NMFLAGS?=-p | 
|  | 
| # Variables mandated by GNU, the arbiter of all good taste on the internet. | 
| # http://www.gnu.org/prep/standards/standards.html | 
| @@ -38,11 +36,24 @@ SONAME=0 | 
| # REBUILD_TABLES=1 | 
|  | 
| ifeq ($(shell uname),Darwin) | 
| -MAKE_SHARED_LIBRARY=$(CXX) -dynamiclib $(LDFLAGS) -exported_symbols_list libre2.symbols.darwin | 
| +SOEXT=dylib | 
| +SOEXTVER=$(SONAME).$(SOEXT) | 
| +SOEXTVER00=$(SONAME).0.0.$(SOEXT) | 
| +MAKE_SHARED_LIBRARY=$(CXX) -dynamiclib $(LDFLAGS) -Wl,-install_name,@rpath/libre2.$(SOEXTVER) -exported_symbols_list libre2.symbols.darwin | 
| +else ifeq ($(shell uname),SunOS) | 
| +SOEXT=so | 
| +SOEXTVER=$(SOEXT).$(SONAME) | 
| +SOEXTVER00=$(SOEXT).$(SONAME).0.0 | 
| +MAKE_SHARED_LIBRARY=$(CXX) -shared -Wl,-soname,libre2.$(SOEXTVER),-M,libre2.symbols $(LDFLAGS) | 
| else | 
| -MAKE_SHARED_LIBRARY=$(CXX) -shared -Wl,-soname,libre2.so.$(SONAME),--version-script=libre2.symbols $(LDFLAGS) | 
| +SOEXT=so | 
| +SOEXTVER=$(SOEXT).$(SONAME) | 
| +SOEXTVER00=$(SOEXT).$(SONAME).0.0 | 
| +MAKE_SHARED_LIBRARY=$(CXX) -shared -Wl,-soname,libre2.$(SOEXTVER),--version-script,libre2.symbols $(LDFLAGS) | 
| endif | 
|  | 
| +all: obj/libre2.a obj/so/libre2.$(SOEXT) | 
| + | 
| INSTALL_HFILES=\ | 
| re2/filtered_re2.h\ | 
| re2/re2.h\ | 
| @@ -51,7 +62,6 @@ INSTALL_HFILES=\ | 
| re2/variadic_function.h\ | 
|  | 
| HFILES=\ | 
| -	util/arena.h\ | 
| util/atomicops.h\ | 
| util/benchmark.h\ | 
| util/flags.h\ | 
| @@ -62,6 +72,7 @@ HFILES=\ | 
| util/sparse_array.h\ | 
| util/sparse_set.h\ | 
| util/test.h\ | 
| +	util/thread.h\ | 
| util/utf.h\ | 
| util/util.h\ | 
| util/valgrind.h\ | 
| @@ -83,10 +94,9 @@ HFILES=\ | 
| re2/walker-inl.h\ | 
|  | 
| OFILES=\ | 
| -	obj/util/arena.o\ | 
| obj/util/hash.o\ | 
| +	obj/util/logging.o\ | 
| obj/util/rune.o\ | 
| -	obj/util/stringpiece.o\ | 
| obj/util/stringprintf.o\ | 
| obj/util/strutil.o\ | 
| obj/util/valgrind.o\ | 
| @@ -106,6 +116,7 @@ OFILES=\ | 
| obj/re2/regexp.o\ | 
| obj/re2/set.o\ | 
| obj/re2/simplify.o\ | 
| +	obj/re2/stringpiece.o\ | 
| obj/re2/tostring.o\ | 
| obj/re2/unicode_casefold.o\ | 
| obj/re2/unicode_groups.o\ | 
| @@ -158,15 +169,15 @@ DBIGTESTS=$(patsubst obj/%,obj/dbg/%,$(BIGTESTS)) | 
|  | 
| obj/%.o: %.cc $(HFILES) | 
| @mkdir -p $$(dirname $@) | 
| -	$(CXX) -o $@ $(CPPFLAGS) $(CXXFLAGS) $(RE2_CXXFLAGS) -DNDEBUG $*.cc | 
| +	$(CXX) -c -o $@ $(CPPFLAGS) $(CXXFLAGS) $(RE2_CXXFLAGS) -DNDEBUG $*.cc | 
|  | 
| obj/dbg/%.o: %.cc $(HFILES) | 
| @mkdir -p $$(dirname $@) | 
| -	$(CXX) -o $@ -fPIC $(CPPFLAGS) $(CXXFLAGS) $(RE2_CXXFLAGS) $*.cc | 
| +	$(CXX) -c -o $@ $(CPPFLAGS) $(CXXFLAGS) $(RE2_CXXFLAGS) $*.cc | 
|  | 
| obj/so/%.o: %.cc $(HFILES) | 
| @mkdir -p $$(dirname $@) | 
| -	$(CXX) -o $@ -fPIC $(CPPFLAGS) $(CXXFLAGS) $(RE2_CXXFLAGS) -DNDEBUG $*.cc | 
| +	$(CXX) -c -o $@ -fPIC $(CPPFLAGS) $(CXXFLAGS) $(RE2_CXXFLAGS) -DNDEBUG $*.cc | 
|  | 
| obj/libre2.a: $(OFILES) | 
| @mkdir -p obj | 
| @@ -176,10 +187,10 @@ obj/dbg/libre2.a: $(DOFILES) | 
| @mkdir -p obj/dbg | 
| $(AR) $(ARFLAGS) obj/dbg/libre2.a $(DOFILES) | 
|  | 
| -obj/so/libre2.so: $(SOFILES) | 
| +obj/so/libre2.$(SOEXT): $(SOFILES) | 
| @mkdir -p obj/so | 
| -	$(MAKE_SHARED_LIBRARY) -o $@.$(SONAME) $(SOFILES) | 
| -	ln -sf libre2.so.$(SONAME) $@ | 
| +	$(MAKE_SHARED_LIBRARY) -o obj/so/libre2.$(SOEXTVER) $(SOFILES) | 
| +	ln -sf libre2.$(SOEXTVER) $@ | 
|  | 
| obj/test/%: obj/libre2.a obj/re2/testing/%.o $(TESTOFILES) obj/util/test.o | 
| @mkdir -p obj/test | 
| @@ -189,7 +200,7 @@ obj/dbg/test/%: obj/dbg/libre2.a obj/dbg/re2/testing/%.o $(DTESTOFILES) obj/dbg/ | 
| @mkdir -p obj/dbg/test | 
| $(CXX) -o $@ obj/dbg/re2/testing/$*.o $(DTESTOFILES) obj/dbg/util/test.o obj/dbg/libre2.a $(LDFLAGS) $(LDPCRE) | 
|  | 
| -obj/so/test/%: obj/so/libre2.so obj/libre2.a obj/so/re2/testing/%.o $(STESTOFILES) obj/so/util/test.o | 
| +obj/so/test/%: obj/so/libre2.$(SOEXT) obj/libre2.a obj/so/re2/testing/%.o $(STESTOFILES) obj/so/util/test.o | 
| @mkdir -p obj/so/test | 
| $(CXX) -o $@ obj/so/re2/testing/$*.o $(STESTOFILES) obj/so/util/test.o -Lobj/so -lre2 obj/libre2.a $(LDFLAGS) $(LDPCRE) | 
|  | 
| @@ -203,6 +214,8 @@ re2/perl_groups.cc: re2/make_perl_groups.pl | 
|  | 
| re2/unicode_%.cc: re2/make_unicode_%.py | 
| python $< > $@ | 
| + | 
| +.PRECIOUS: re2/perl_groups.cc re2/unicode_casefold.cc re2/unicode_groups.cc | 
| endif | 
|  | 
| distclean: clean | 
| @@ -245,23 +258,28 @@ shared-bigtest: $(STESTS) $(SBIGTESTS) | 
|  | 
| benchmark: obj/test/regexp_benchmark | 
|  | 
| -install: obj/libre2.a obj/so/libre2.so | 
| -	mkdir -p $(DESTDIR)$(includedir)/re2 $(DESTDIR)$(libdir) | 
| +install: obj/libre2.a obj/so/libre2.$(SOEXT) | 
| +	mkdir -p $(DESTDIR)$(includedir)/re2 $(DESTDIR)$(libdir)/pkgconfig | 
| $(INSTALL_DATA) $(INSTALL_HFILES) $(DESTDIR)$(includedir)/re2 | 
| $(INSTALL) obj/libre2.a $(DESTDIR)$(libdir)/libre2.a | 
| -	$(INSTALL) obj/so/libre2.so $(DESTDIR)$(libdir)/libre2.so.$(SONAME).0.0 | 
| -	ln -sf libre2.so.$(SONAME).0.0 $(DESTDIR)$(libdir)/libre2.so.$(SONAME) | 
| -	ln -sf libre2.so.$(SONAME).0.0 $(DESTDIR)$(libdir)/libre2.so | 
| +	$(INSTALL) obj/so/libre2.$(SOEXT) $(DESTDIR)$(libdir)/libre2.$(SOEXTVER00) | 
| +	ln -sf libre2.$(SOEXTVER00) $(DESTDIR)$(libdir)/libre2.$(SOEXTVER) | 
| +	ln -sf libre2.$(SOEXTVER00) $(DESTDIR)$(libdir)/libre2.$(SOEXT) | 
| +	sed -e "s#@prefix@#${prefix}#" re2.pc >$(DESTDIR)$(libdir)/pkgconfig/re2.pc | 
|  | 
| testinstall: | 
| @mkdir -p obj | 
| cp testinstall.cc obj | 
| +ifneq ($(shell uname),Darwin) | 
| +	(cd obj && $(CXX) -I$(DESTDIR)$(includedir) -L$(DESTDIR)$(libdir) testinstall.cc -lre2 -pthread -static -o testinstall) | 
| +	obj/testinstall | 
| +endif | 
| (cd obj && $(CXX) -I$(DESTDIR)$(includedir) -L$(DESTDIR)$(libdir) testinstall.cc -lre2 -pthread -o testinstall) | 
| LD_LIBRARY_PATH=$(DESTDIR)$(libdir) obj/testinstall | 
|  | 
| benchlog: obj/test/regexp_benchmark | 
| (echo '==BENCHMARK==' `hostname` `date`; \ | 
| -	  (uname -a; $(CXX) --version; hg identify; file obj/test/regexp_benchmark) | sed 's/^/# /'; \ | 
| +	  (uname -a; $(CXX) --version; git rev-parse --short HEAD; file obj/test/regexp_benchmark) | sed 's/^/# /'; \ | 
| echo; \ | 
| ./obj/test/regexp_benchmark 'PCRE|RE2') | tee -a benchlog.$$(hostname | sed 's/\..*//') | 
|  | 
| @@ -273,8 +291,9 @@ benchlog: obj/test/regexp_benchmark | 
| obj/test/% obj/so/test/% obj/dbg/test/% | 
|  | 
| log: | 
| -	make clean | 
| -	make CXXFLAGS="$(CXXFLAGS) -DLOGGING=1" obj/test/exhaustive{,1,2,3}_test | 
| +	$(MAKE) clean | 
| +	$(MAKE) CXXFLAGS="$(CXXFLAGS) -DLOGGING=1" \ | 
| +		$(filter obj/test/exhaustive%_test,$(BIGTESTS)) | 
| echo '#' RE2 exhaustive tests built by make log >re2-exhaustive.txt | 
| echo '#' $$(date) >>re2-exhaustive.txt | 
| obj/test/exhaustive_test |grep -v '^PASS$$' >>re2-exhaustive.txt | 
| @@ -282,7 +301,10 @@ log: | 
| obj/test/exhaustive2_test |grep -v '^PASS$$' >>re2-exhaustive.txt | 
| obj/test/exhaustive3_test |grep -v '^PASS$$' >>re2-exhaustive.txt | 
|  | 
| -	make CXXFLAGS="$(CXXFLAGS) -DLOGGING=1" obj/test/search_test | 
| +	$(MAKE) CXXFLAGS="$(CXXFLAGS) -DLOGGING=1" obj/test/search_test | 
| echo '#' RE2 basic search tests built by make $@ >re2-search.txt | 
| echo '#' $$(date) >>re2-search.txt | 
| obj/test/search_test |grep -v '^PASS$$' >>re2-search.txt | 
| + | 
| +x: x.cc obj/libre2.a | 
| +	g++ -I. -o x x.cc obj/libre2.a | 
|  |