X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=debian%2Frules;h=f6cdeef8e8d8b03ff87c9457a84d54770036c2e1;hb=d58e70bf6153ab3c1a59332f622a8b21d112faa6;hp=5289f03114715183ab541c3f65ae1acc6e59253e;hpb=dab52ae25c9f88ef9b25351d58bf24948fadaa48;p=clsql.git diff --git a/debian/rules b/debian/rules index 5289f03..f6cdeef 100755 --- a/debian/rules +++ b/debian/rules @@ -6,39 +6,60 @@ export DH_VERBOSE=1 # This is the debhelper compatibility version to use. -export DH_COMPAT=3 +export DH_COMPAT=4 + +plain-pkg := clsql pkg := cl-sql pkg-base := cl-sql-base pkg-mysql := cl-sql-mysql pkg-pg := cl-sql-postgresql pkg-pg-socket := cl-sql-postgresql-socket -all-pkgs := $(pkg) $(pkg-base) $(pkg-mysql) $(pkg-pg) $(pkg-pg-socket) +pkg-aodbc := cl-sql-aodbc +all-pkgs := $(pkg) $(pkg-base) $(pkg-mysql) $(pkg-pg) $(pkg-pg-socket) $(pkg-aodbc) prefix := debian/$(pkg) prefix-base := debian/$(pkg-base) prefix-mysql := debian/$(pkg-mysql) prefix-pg := debian/$(pkg-pg) prefix-pg-socket := debian/$(pkg-pg-socket) +prefix-aodbc := debian/$(pkg-aodbc) + +UPSTREAM_VER := $(shell sed -n -e "s/${pkg} (\(.*\)-[0-9.]).*/\1/p" < debian/changelog |head -1) -## -## lisp sources per pkg -## -srcs := sql/pool.cl sql/sql.cl sql/transactions.cl sql/utils.cl sql/functional.cl sql/usql.cl -srcs-base := sql/package.cl sql/db-interface.cl sql/classes.cl sql/conditions.cl $(wilcard cmu-compat/*.cl) +## Lisp sources +srcs := $(wildcard sql/*.cl) +srcs-base := $(wildcard base/*.cl) +srcs-base-uffi := $(wildcard interfaces/clsql-uffi/*.cl) +srcs-base-uffi-so:= $(wildcard interfaces/clsql-uffi/*.so) srcs-mysql := $(wildcard interfaces/mysql/*.cl) +srcs-mysql-so := $(wildcard interfaces/mysql/*.so) srcs-pg := $(wildcard interfaces/postgresql/*.cl) srcs-pg-socket := $(wildcard interfaces/postgresql-socket/*.cl) +srcs-aodbc := $(wildcard interfaces/aodbc/*.cl) INSTALL := install INSTALLFLAGS := -g root -o root -m 0644 +INSTALLEXECFLAGS := -g root -o root -m 0755 INSTALLDIRFLAGS := -d -g root -o root -m 0755 clc-base := usr/share/common-lisp clc-source := $(clc-base)/source -clc-repos := $(clc-base)/repositories clc-systems := $(clc-base)/systems -doc-dir := $(prefix)/usr/share/doc/cl-sql +doc-dir := $(prefix-base)/usr/share/doc/cl-sql + +clc-clsql := $(clc-source)/$(plain-pkg)-$(UPSTREAM_VER) + +lispdir := $(prefix)/$(clc-clsql) +lispdir-sql := $(prefix)/$(clc-clsql)/sql +lispdir-base := $(prefix-base)/$(clc-clsql)/base +lispdir-base-uffi := $(prefix-base)/$(clc-clsql)/interfaces/clsql-uffi +sodir-base-uffi := $(prefix-base)/usr/lib/cl-sql +lispdir-mysql := $(prefix-mysql)/$(clc-clsql)/interfaces/mysql +sodir-mysql := $(prefix-mysql)/usr/lib/cl-sql +lispdir-pg := $(prefix-pg)/$(clc-clsql)/interfaces/postgresql +lispdir-pg-socket := $(prefix-pg-socket)/$(clc-clsql)/interfaces/postgresql-socket +lispdir-aodbc := $(prefix-aodbc)/$(clc-clsql)/interfaces/aodbc configure: configure-stamp @@ -52,7 +73,8 @@ build: build-stamp build-stamp: configure-stamp dh_testdir - # Add here commands to compile the package. + # Compile helper libraries + $(MAKE) touch build-stamp clean: @@ -60,31 +82,47 @@ clean: dh_testroot rm -f build-stamp configure-stamp # Add here commands to clean up after the build process. + $(MAKE) clean dh_clean install: build dh_testdir dh_testroot dh_clean -k - dh_installdirs + dh_installdirs --all $(clc-systems) $(clc-source) - $(INSTALL) $(INSTALLFLAGS) $(srcs-base) $(prefix-base)/$(clc-repos)/clsql - $(INSTALL) $(INSTALLFLAGS) $(srcs) $(prefix)/$(clc-repos)/clsql - $(INSTALL) $(INSTALLFLAGS) $(srcs-mysql) $(prefix-mysql)/$(clc-repos)/clsql/interfaces/mysql - $(INSTALL) $(INSTALLFLAGS) $(srcs-pg) $(prefix-pg)/$(clc-repos)/clsql/interfaces/postgresql - $(INSTALL) $(INSTALLFLAGS) $(srcs-pg-socket) $(prefix-pg-socket)/$(clc-repos)/clsql/interfaces/postgresql-socket + $(INSTALL) $(INSTALLDIRFLAGS) $(lispdir) $(lispdir-base) \ + $(lispdir-base-uffi) $(lispdir-pg) $(lispdir-pg-socket) \ + $(lispdir-mysql) $(lispdir-sql) $(lispdir-aodbc) \ + $(sodir-base-uffi) $(sodir-mysql) - dh_link ../repositories/clsql $(prefix-base)/$(clc-source)/clsql + # Main package + $(INSTALL) $(INSTALLDIRFLAGS) $(lispdir) $(lispdir-int) + $(INSTALL) $(INSTALLFLAGS) $(srcs) $(lispdir-sql) + + # Base + $(INSTALL) $(INSTALLFLAGS) $(srcs-base) $(lispdir-base) + $(INSTALL) $(INSTALLFLAGS) $(srcs-base-uffi) $(lispdir-base-uffi) + $(INSTALL) $(INSTALLEXECFLAGS) $(srcs-base-uffi-so) $(sodir-base-uffi) + + $(INSTALL) $(INSTALLFLAGS) $(srcs-mysql) $(lispdir-mysql) + $(INSTALL) $(INSTALLEXECFLAGS) $(srcs-mysql-so) $(sodir-mysql) + $(INSTALL) $(INSTALLFLAGS) $(srcs-pg) $(lispdir-pg) + $(INSTALL) $(INSTALLFLAGS) $(srcs-pg-socket) $(lispdir-pg-socket) + $(INSTALL) $(INSTALLFLAGS) $(srcs-aodbc) $(lispdir-aodbc) # CLC Systems - $(INSTALL) $(INSTALLFLAGS) clsql.system $(prefix)/$(clc-systems)/ - $(INSTALL) $(INSTALLFLAGS) clsql-base.system $(prefix-base)/$(clc-systems)/ - $(INSTALL) $(INSTALLFLAGS) clsql-mysql.system $(prefix-mysql)/$(clc-systems)/ - $(INSTALL) $(INSTALLFLAGS) clsql-postgresql.system $(prefix-pg)/$(clc-systems)/ - $(INSTALL) $(INSTALLFLAGS) clsql-postgresql-socket.system $(prefix-pg-socket)/$(clc-systems)/ + $(INSTALL) $(INSTALLFLAGS) clsql.system $(prefix)/$(clc-systems) + $(INSTALL) $(INSTALLFLAGS) clsql-base.system clsql-uffi.system $(prefix-base)/$(clc-systems) + $(INSTALL) $(INSTALLFLAGS) clsql-mysql.system $(prefix-mysql)/$(clc-systems) + $(INSTALL) $(INSTALLFLAGS) clsql-postgresql.system $(prefix-pg)/$(clc-systems) + $(INSTALL) $(INSTALLFLAGS) clsql-postgresql-socket.system $(prefix-pg-socket)/$(clc-systems) + $(INSTALL) $(INSTALLFLAGS) clsql-aodbc.system $(prefix-aodbc)/$(clc-systems) # Test suite - $(INSTALL) $(INSTALLFLAGS) test-suite/tester-clsql.cl test-suite/acl-compat-tester.cl $(prefix)/$(doc-dir)/test-suite + $(INSTALL) $(INSTALLDIRFLAGS) $(doc-dir)/html $(doc-dir)/test-suite + + $(INSTALL) $(INSTALLFLAGS) test-suite/tester-clsql.cl test-suite/acl-compat-tester.cl $(doc-dir)/test-suite # Documentation $(INSTALL) $(INSTALLFLAGS) doc/html/* $(doc-dir)/html @@ -94,6 +132,15 @@ install: build $(INSTALL) $(INSTALLFLAGS) doc/cl-sql.pdf.gz $(doc-dir) rm -f doc/cl-sql.pdf.gz +# From UncommonSQL Debian package: build prerm postinst from templates + set -e ;\ + for p in $(all-pkgs); do \ + echo "processing maintainer scripts for $$p" ;\ + l=`echo $$p | sed -e "s/^cl-/cl/;"` ;\ + sed -e "s/%%/$$l/;" debian/prerm.template > debian/$$p.prerm ;\ + sed -e "s/%%/$$l/;" debian/postinst.template > debian/$$p.postinst ;\ + done + # Build architecture-independent files here. binary-indep: build install @@ -107,25 +154,20 @@ binary-arch: build install # dh_installdebconf dh_installdocs # dh_installexamples -# dh_installmenu -# dh_installlogrotate -# dh_installemacsen -# dh_installpam -# dh_installmime -# dh_installinit -# dh_installcron -# dh_installman -# dh_installinfo -# dh_undocumented dh_installchangelogs ChangeLog - dh_link + dh_link -p $(pkg-base) $(clc-clsql) $(clc-source)/clsql + dh_link -p $(pkg-base) $(clc-clsql) $(clc-source)/clsql-base + dh_link -p $(pkg-mysql) $(clc-clsql) $(clc-source)/clsql-mysql + dh_link -p $(pkg-pg) $(clc-clsql) $(clc-source)/clsql-postgresql + dh_link -p $(pkg-pg-socket) $(clc-clsql) $(clc-source)/clsql-postgresql-socket + dh_link -p $(pkg-aodbc) $(clc-clsql) $(clc-source)/clsql-aodbc dh_strip dh_compress dh_fixperms # dh_makeshlibs dh_installdeb # dh_perl -# dh_shlibdeps + dh_shlibdeps dh_gencontrol dh_md5sums dh_builddeb