diff options
Diffstat (limited to 'ext/pdo_sqlite/sqlite/main.mk')
| -rw-r--r-- | ext/pdo_sqlite/sqlite/main.mk | 533 | 
1 files changed, 533 insertions, 0 deletions
diff --git a/ext/pdo_sqlite/sqlite/main.mk b/ext/pdo_sqlite/sqlite/main.mk new file mode 100644 index 0000000000..e79e0926ba --- /dev/null +++ b/ext/pdo_sqlite/sqlite/main.mk @@ -0,0 +1,533 @@ +############################################################################### +# The following macros should be defined before this script is +# invoked: +# +# TOP              The toplevel directory of the source tree.  This is the +#                  directory that contains this "Makefile.in" and the +#                  "configure.in" script. +# +# BCC              C Compiler and options for use in building executables that +#                  will run on the platform that is doing the build. +# +# USLEEP           If the target operating system supports the "usleep()" system +#                  call, then define the HAVE_USLEEP macro for all C modules. +# +# THREADSAFE       If you want the SQLite library to be safe for use within a  +#                  multi-threaded program, then define the following macro +#                  appropriately: +# +# THREADLIB        Specify any extra linker options needed to make the library +#                  thread safe +# +# OPTS             Extra compiler command-line options. +# +# EXE              The suffix to add to executable files.  ".exe" for windows +#                  and "" for Unix. +# +# TCC              C Compiler and options for use in building executables that  +#                  will run on the target platform.  This is usually the same +#                  as BCC, unless you are cross-compiling. +# +# AR               Tools used to build a static library. +# RANLIB +# +# TCL_FLAGS        Extra compiler options needed for programs that use the +#                  TCL library. +# +# LIBTCL           Linker options needed to link against the TCL library. +# +# READLINE_FLAGS   Compiler options needed for programs that use the +#                  readline() library. +# +# LIBREADLINE      Linker options needed by programs using readline() must +#                  link against. +# +# ENCODING         "UTF8" or "ISO8859" +# +# Once the macros above are defined, the rest of this make script will +# build the SQLite library and testing tools. +################################################################################ + +# This is how we compile +# +TCCX = $(TCC) $(OPTS) $(THREADSAFE) $(USLEEP) -I. -I$(TOP)/src + +# Object files for the SQLite library. +# +LIBOBJ+= attach.o auth.o btree.o build.o date.o delete.o \ +         expr.o func.o hash.o insert.o \ +         main.o opcodes.o os_mac.o os_unix.o os_win.o \ +         pager.o parse.o pragma.o printf.o random.o \ +         select.o table.o tclsqlite.o tokenize.o trigger.o \ +         update.o util.o vacuum.o \ +         vdbe.o vdbeapi.o vdbeaux.o vdbemem.o \ +         where.o utf.o legacy.o + +# All of the source code files. +# +SRC = \ +  $(TOP)/src/attach.c \ +  $(TOP)/src/auth.c \ +  $(TOP)/src/btree.c \ +  $(TOP)/src/btree.h \ +  $(TOP)/src/build.c \ +  $(TOP)/src/date.c \ +  $(TOP)/src/delete.c \ +  $(TOP)/src/expr.c \ +  $(TOP)/src/func.c \ +  $(TOP)/src/hash.c \ +  $(TOP)/src/hash.h \ +  $(TOP)/src/insert.c \ +  $(TOP)/src/legacy.c \ +  $(TOP)/src/main.c \ +  $(TOP)/src/os_mac.c \ +  $(TOP)/src/os_unix.c \ +  $(TOP)/src/os_win.c \ +  $(TOP)/src/pager.c \ +  $(TOP)/src/pager.h \ +  $(TOP)/src/parse.y \ +  $(TOP)/src/pragma.c \ +  $(TOP)/src/printf.c \ +  $(TOP)/src/random.c \ +  $(TOP)/src/select.c \ +  $(TOP)/src/shell.c \ +  $(TOP)/src/sqlite.h.in \ +  $(TOP)/src/sqliteInt.h \ +  $(TOP)/src/table.c \ +  $(TOP)/src/tclsqlite.c \ +  $(TOP)/src/tokenize.c \ +  $(TOP)/src/trigger.c \ +  $(TOP)/src/utf.c \ +  $(TOP)/src/update.c \ +  $(TOP)/src/util.c \ +  $(TOP)/src/vacuum.c \ +  $(TOP)/src/vdbe.c \ +  $(TOP)/src/vdbe.h \ +  $(TOP)/src/vdbeapi.c \ +  $(TOP)/src/vdbeaux.c \ +  $(TOP)/src/vdbemem.c \ +  $(TOP)/src/vdbeInt.h \ +  $(TOP)/src/where.c + +# Source code to the test files. +# +TESTSRC = \ +  $(TOP)/src/btree.c \ +  $(TOP)/src/func.c \ +  $(TOP)/src/os_mac.c \ +  $(TOP)/src/os_unix.c \ +  $(TOP)/src/os_win.c \ +  $(TOP)/src/pager.c \ +  $(TOP)/src/pragma.c \ +  $(TOP)/src/printf.c \ +  $(TOP)/src/test1.c \ +  $(TOP)/src/test2.c \ +  $(TOP)/src/test3.c \ +  $(TOP)/src/test4.c \ +  $(TOP)/src/test5.c \ +  $(TOP)/src/utf.c \ +  $(TOP)/src/util.c \ +  $(TOP)/src/vdbe.c \ +  $(TOP)/src/md5.c + +# Header files used by all library source files. +# +HDR = \ +   sqlite3.h  \ +   $(TOP)/src/btree.h \ +   config.h \ +   $(TOP)/src/hash.h \ +   opcodes.h \ +   $(TOP)/src/os.h \ +   $(TOP)/src/os_common.h \ +   $(TOP)/src/os_mac.h \ +   $(TOP)/src/os_unix.h \ +   $(TOP)/src/os_win.h \ +   $(TOP)/src/sqliteInt.h  \ +   $(TOP)/src/vdbe.h \ +   parse.h + +# Header files used by the VDBE submodule +# +VDBEHDR = \ +   $(HDR) \ +   $(TOP)/src/vdbeInt.h + +# This is the default Makefile target.  The objects listed here +# are what get build when you type just "make" with no arguments. +# +all:	sqlite3.h config.h libsqlite3.a sqlite3$(EXE) + +# Generate the file "last_change" which contains the date of change +# of the most recently modified source code file +# +last_change:	$(SRC) +	cat $(SRC) | grep '$$Id: ' | sort +4 | tail -1 \ +          | awk '{print $$5,$$6}' >last_change + +libsqlite3.a:	$(LIBOBJ) +	$(AR) libsqlite3.a $(LIBOBJ) +	$(RANLIB) libsqlite3.a + +sqlite3$(EXE):	$(TOP)/src/shell.c libsqlite3.a sqlite3.h +	$(TCCX) $(READLINE_FLAGS) -o sqlite3$(EXE) $(TOP)/src/shell.c \ +		libsqlite3.a $(LIBREADLINE) $(THREADLIB) + +objects: $(LIBOBJ_ORIG) + +# This target creates a directory named "tsrc" and fills it with +# copies of all of the C source code and header files needed to +# build on the target system.  Some of the C source code and header +# files are automatically generated.  This target takes care of +# all that automatic generation. +# +target_source:	$(SRC) $(VDBEHDR) opcodes.c +	rm -rf tsrc +	mkdir tsrc +	cp $(SRC) $(VDBEHDR) tsrc +	rm tsrc/sqlite.h.in tsrc/parse.y +	cp parse.c opcodes.c tsrc +	cp $(TOP)/sqlite3.def tsrc + +# Rules to build the LEMON compiler generator +# +lemon:	$(TOP)/tool/lemon.c $(TOP)/tool/lempar.c +	$(BCC) -o lemon $(TOP)/tool/lemon.c +	cp $(TOP)/tool/lempar.c . + +# Rules to build individual files +# +attach.o:	$(TOP)/src/attach.c $(HDR) +	$(TCCX) -c $(TOP)/src/attach.c + +auth.o:	$(TOP)/src/auth.c $(HDR) +	$(TCCX) -c $(TOP)/src/auth.c + +btree.o:	$(TOP)/src/btree.c $(HDR) $(TOP)/src/pager.h +	$(TCCX) -c $(TOP)/src/btree.c + +build.o:	$(TOP)/src/build.c $(HDR) +	$(TCCX) -c $(TOP)/src/build.c + +# The config.h file will contain a single #define that tells us how +# many bytes are in a pointer.  This only works if a pointer is the +# same size on the host as it is on the target.  If you are cross-compiling +# to a target with a different pointer size, you'll need to manually +# configure the config.h file. +# +config.h:	 +	echo '#include <stdio.h>' >temp.c +	echo 'int main(){printf(' >>temp.c +	echo '"#define SQLITE_PTR_SZ %d",sizeof(char*));' >>temp.c +	echo 'exit(0);}' >>temp.c +	$(BCC) -o temp temp.c +	./temp >config.h +	echo >>config.h +	rm -f temp.c temp + +date.o:	$(TOP)/src/date.c $(HDR) +	$(TCCX) -c $(TOP)/src/date.c + +delete.o:	$(TOP)/src/delete.c $(HDR) +	$(TCCX) -c $(TOP)/src/delete.c + +expr.o:	$(TOP)/src/expr.c $(HDR) +	$(TCCX) -c $(TOP)/src/expr.c + +func.o:	$(TOP)/src/func.c $(HDR) +	$(TCCX) -c $(TOP)/src/func.c + +hash.o:	$(TOP)/src/hash.c $(HDR) +	$(TCCX) -c $(TOP)/src/hash.c + +insert.o:	$(TOP)/src/insert.c $(HDR) +	$(TCCX) -c $(TOP)/src/insert.c + +legacy.o:	$(TOP)/src/legacy.c $(HDR) +	$(TCCX) -c $(TOP)/src/legacy.c + +main.o:	$(TOP)/src/main.c $(HDR) +	$(TCCX) -c $(TOP)/src/main.c + +pager.o:	$(TOP)/src/pager.c $(HDR) $(TOP)/src/pager.h +	$(TCCX) -c $(TOP)/src/pager.c + +opcodes.o:	opcodes.c +	$(TCCX) -c opcodes.c + +opcodes.c:	opcodes.h $(TOP)/mkopcodec.awk +	sort -n +2 opcodes.h | awk -f $(TOP)/mkopcodec.awk >opcodes.c + +opcodes.h:	parse.h $(TOP)/src/vdbe.c $(TOP)/mkopcodeh.awk +	cat parse.h $(TOP)/src/vdbe.c | awk -f $(TOP)/mkopcodeh.awk >opcodes.h + +os_mac.o:	$(TOP)/src/os_mac.c $(HDR) +	$(TCCX) -c $(TOP)/src/os_mac.c + +os_unix.o:	$(TOP)/src/os_unix.c $(HDR) +	$(TCCX) -c $(TOP)/src/os_unix.c + +os_win.o:	$(TOP)/src/os_win.c $(HDR) +	$(TCCX) -c $(TOP)/src/os_win.c + +parse.o:	parse.c $(HDR) +	$(TCCX) -c parse.c + +parse.h:	parse.c + +parse.c:	$(TOP)/src/parse.y lemon +	cp $(TOP)/src/parse.y . +	./lemon parse.y + +pragma.o:	$(TOP)/src/pragma.c $(HDR) +	$(TCCX) $(TCL_FLAGS) -c $(TOP)/src/pragma.c + +printf.o:	$(TOP)/src/printf.c $(HDR) +	$(TCCX) $(TCL_FLAGS) -c $(TOP)/src/printf.c + +random.o:	$(TOP)/src/random.c $(HDR) +	$(TCCX) -c $(TOP)/src/random.c + +select.o:	$(TOP)/src/select.c $(HDR) +	$(TCCX) -c $(TOP)/src/select.c + +sqlite3.h:	$(TOP)/src/sqlite.h.in  +	sed -e s/--VERS--/`cat ${TOP}/VERSION`/ \ +            -e s/--ENCODING--/$(ENCODING)/ \ +                 $(TOP)/src/sqlite.h.in >sqlite3.h + +table.o:	$(TOP)/src/table.c $(HDR) +	$(TCCX) -c $(TOP)/src/table.c + +tclsqlite.o:	$(TOP)/src/tclsqlite.c $(HDR) +	$(TCCX) $(TCL_FLAGS) -c $(TOP)/src/tclsqlite.c + +tokenize.o:	$(TOP)/src/tokenize.c $(HDR) +	$(TCCX) -c $(TOP)/src/tokenize.c + +trigger.o:	$(TOP)/src/trigger.c $(HDR) +	$(TCCX) -c $(TOP)/src/trigger.c + +update.o:	$(TOP)/src/update.c $(HDR) +	$(TCCX) -c $(TOP)/src/update.c + +utf.o:	$(TOP)/src/utf.c $(HDR) +	$(TCCX) -c $(TOP)/src/utf.c + +util.o:	$(TOP)/src/util.c $(HDR) +	$(TCCX) -c $(TOP)/src/util.c + +vacuum.o:	$(TOP)/src/vacuum.c $(HDR) +	$(TCCX) -c $(TOP)/src/vacuum.c + +vdbe.o:	$(TOP)/src/vdbe.c $(VDBEHDR) +	$(TCCX) -c $(TOP)/src/vdbe.c + +vdbeapi.o:	$(TOP)/src/vdbeapi.c $(VDBEHDR) +	$(TCCX) -c $(TOP)/src/vdbeapi.c + +vdbeaux.o:	$(TOP)/src/vdbeaux.c $(VDBEHDR) +	$(TCCX) -c $(TOP)/src/vdbeaux.c + +vdbemem.o:	$(TOP)/src/vdbemem.c $(VDBEHDR) +	$(TCCX) -c $(TOP)/src/vdbemem.c + +where.o:	$(TOP)/src/where.c $(HDR) +	$(TCCX) -c $(TOP)/src/where.c + +# Rules for building test programs and for running tests +# +tclsqlite3:	$(TOP)/src/tclsqlite.c libsqlite3.a +	$(TCCX) $(TCL_FLAGS) -DTCLSH=1 -o tclsqlite3 \ +		$(TOP)/src/tclsqlite.c libsqlite3.a $(LIBTCL) $(THREADLIB) + +testfixture$(EXE):	$(TOP)/src/tclsqlite.c libsqlite3.a $(TESTSRC) +	$(TCCX) $(TCL_FLAGS) -DTCLSH=1 -DSQLITE_TEST=1 -o testfixture$(EXE) \ +		$(TESTSRC) $(TOP)/src/tclsqlite.c \ +		libsqlite3.a $(LIBTCL) $(THREADLIB) + +crashtest:	$(TOP)/src/tclsqlite.c libsqlite3.a $(TESTSRC) $(TOP)/src/os_test.c +	$(TCCX) $(TCL_FLAGS) -DOS_TEST=1 -DTCLSH=1 -DSQLITE_TEST=1 \ +		-o crashtest \ +		$(TESTSRC) $(TOP)/src/os_test.c $(TOP)/src/tclsqlite.c \ +		libsqlite3.a $(LIBTCL) $(THREADLIB) + +fulltest:	testfixture$(EXE) sqlite3$(EXE) crashtest +	./testfixture$(EXE) $(TOP)/test/all.test + +test:	testfixture$(EXE) sqlite3$(EXE) +	./testfixture$(EXE) $(TOP)/test/quick.test + +sqlite3_analyzer$(EXE):	$(TOP)/src/tclsqlite.c libsqlite3.a $(TESTSRC) \ +			$(TOP)/tool/spaceanal.tcl +	sed \ +	  -e '/^#/d' \ +	  -e 's,\\,\\\\,g' \ +	  -e 's,",\\",g' \ +	  -e 's,^,",' \ +	  -e 's,$$,\\n",' \ +	  $(TOP)/tool/spaceanal.tcl >spaceanal_tcl.h +	$(TCCX) $(TCL_FLAGS) -DTCLSH=2 -DSQLITE_TEST=1 -static -o \ + 		sqlite3_analyzer$(EXE) $(TESTSRC) $(TOP)/src/tclsqlite.c \ +		libsqlite3.a $(LIBTCL) $(THREADLIB) + +# Rules used to build documentation +# +arch.html:	$(TOP)/www/arch.tcl +	tclsh $(TOP)/www/arch.tcl >arch.html + +arch.png:	$(TOP)/www/arch.png +	cp $(TOP)/www/arch.png . + +c_interface.html:	$(TOP)/www/c_interface.tcl +	tclsh $(TOP)/www/c_interface.tcl >c_interface.html + +capi3.html:	$(TOP)/www/capi3.tcl +	tclsh $(TOP)/www/capi3.tcl >capi3.html + +capi3ref.html:	$(TOP)/www/capi3ref.tcl +	tclsh $(TOP)/www/capi3ref.tcl >capi3ref.html + +changes.html:	$(TOP)/www/changes.tcl +	tclsh $(TOP)/www/changes.tcl >changes.html + +copyright.html:	$(TOP)/www/copyright.tcl +	tclsh $(TOP)/www/copyright.tcl >copyright.html + +copyright-release.html:	$(TOP)/www/copyright-release.html +	cp $(TOP)/www/copyright-release.html . + +copyright-release.pdf:	$(TOP)/www/copyright-release.pdf +	cp $(TOP)/www/copyright-release.pdf . + +common.tcl:	$(TOP)/www/common.tcl +	cp $(TOP)/www/common.tcl . + +conflict.html:	$(TOP)/www/conflict.tcl +	tclsh $(TOP)/www/conflict.tcl >conflict.html + +datatypes.html:	$(TOP)/www/datatypes.tcl +	tclsh $(TOP)/www/datatypes.tcl >datatypes.html + +datatype3.html:	$(TOP)/www/datatype3.tcl +	tclsh $(TOP)/www/datatype3.tcl >datatype3.html + +docs.html:	$(TOP)/www/docs.tcl +	tclsh $(TOP)/www/docs.tcl >docs.html + +download.html:	$(TOP)/www/download.tcl +	mkdir -p doc +	tclsh $(TOP)/www/download.tcl >download.html + +faq.html:	$(TOP)/www/faq.tcl +	tclsh $(TOP)/www/faq.tcl >faq.html + +fileformat.html:	$(TOP)/www/fileformat.tcl +	tclsh $(TOP)/www/fileformat.tcl >fileformat.html + +formatchng.html:	$(TOP)/www/formatchng.tcl +	tclsh $(TOP)/www/formatchng.tcl >formatchng.html + +index.html:	$(TOP)/www/index.tcl last_change +	tclsh $(TOP)/www/index.tcl >index.html + +lang.html:	$(TOP)/www/lang.tcl +	tclsh $(TOP)/www/lang.tcl >lang.html + +lockingv3.html:	$(TOP)/www/lockingv3.tcl +	tclsh $(TOP)/www/lockingv3.tcl >lockingv3.html + +oldnews.html:	$(TOP)/www/oldnews.tcl +	tclsh $(TOP)/www/oldnews.tcl >oldnews.html + +omitted.html:	$(TOP)/www/omitted.tcl +	tclsh $(TOP)/www/omitted.tcl >omitted.html + +opcode.html:	$(TOP)/www/opcode.tcl $(TOP)/src/vdbe.c +	tclsh $(TOP)/www/opcode.tcl $(TOP)/src/vdbe.c >opcode.html + +mingw.html:	$(TOP)/www/mingw.tcl +	tclsh $(TOP)/www/mingw.tcl >mingw.html + +nulls.html:	$(TOP)/www/nulls.tcl +	tclsh $(TOP)/www/nulls.tcl >nulls.html + +quickstart.html:	$(TOP)/www/quickstart.tcl +	tclsh $(TOP)/www/quickstart.tcl >quickstart.html + +speed.html:	$(TOP)/www/speed.tcl +	tclsh $(TOP)/www/speed.tcl >speed.html + +sqlite.gif:	$(TOP)/art/SQLite.gif +	cp $(TOP)/art/SQLite.gif sqlite.gif + +sqlite.html:	$(TOP)/www/sqlite.tcl +	tclsh $(TOP)/www/sqlite.tcl >sqlite.html + +support.html:	$(TOP)/www/support.tcl +	tclsh $(TOP)/www/support.tcl >support.html + +tclsqlite.html:	$(TOP)/www/tclsqlite.tcl +	tclsh $(TOP)/www/tclsqlite.tcl >tclsqlite.html + +vdbe.html:	$(TOP)/www/vdbe.tcl +	tclsh $(TOP)/www/vdbe.tcl >vdbe.html + +version3.html:	$(TOP)/www/version3.tcl +	tclsh $(TOP)/www/version3.tcl >version3.html + + +# Files to be published on the website. +# +DOC = \ +  arch.html \ +  arch.png \ +  c_interface.html \ +  capi3.html \ +  capi3ref.html \ +  changes.html \ +  copyright.html \ +  copyright-release.html \ +  copyright-release.pdf \ +  conflict.html \ +  datatypes.html \ +  datatype3.html \ +  docs.html \ +  download.html \ +  faq.html \ +  fileformat.html \ +  formatchng.html \ +  index.html \ +  lang.html \ +  lockingv3.html \ +  mingw.html \ +  nulls.html \ +  oldnews.html \ +  omitted.html \ +  opcode.html \ +  quickstart.html \ +  speed.html \ +  sqlite.gif \ +  sqlite.html \ +  support.html \ +  tclsqlite.html \ +  vdbe.html \ +  version3.html + +doc:	common.tcl $(DOC) +	mkdir -p doc +	mv $(DOC) doc + +# Standard install and cleanup targets +# +install:	sqlite3 libsqlite3.a sqlite3.h +	mv sqlite3 /usr/bin +	mv libsqlite3.a /usr/lib +	mv sqlite3.h /usr/include + +clean:	 +	rm -f *.o sqlite3 libsqlite3.a sqlite3.h opcodes.* +	rm -f lemon lempar.c parse.* sqlite*.tar.gz +	rm -f $(PUBLISH) +	rm -f *.da *.bb *.bbg gmon.out +	rm -rf tsrc  | 
