X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=debian%2Frules;h=e934d0a43290750cf7395b8a8f0ecdf11cb4bed3;hb=21cd6d665b303f493eab5bb9d71e198d704e914d;hp=fb99ebec54252504b6ec2fe8d839e337ea9387ae;hpb=5639395236a942d7ed2cc847152f2b428a70623e;p=clsql.git diff --git a/debian/rules b/debian/rules index fb99ebe..e934d0a 100755 --- a/debian/rules +++ b/debian/rules @@ -6,14 +6,16 @@ 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 -pkg-mysql := cl-sql-aodbc +pkg-aodbc := cl-sql-aodbc all-pkgs := $(pkg) $(pkg-base) $(pkg-mysql) $(pkg-pg) $(pkg-pg-socket) $(pkg-aodbc) prefix := debian/$(pkg) @@ -23,25 +25,41 @@ 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 -srcs := sql/pool.cl sql/sql.cl sql/transactions.cl sql/utils.cl sql/functional.cl sql/usql.cl -srcs-cmucl-compat := $(wildcard cmucl-compat/*.cl) -srcs-base := sql/package.cl sql/db-interface.cl sql/classes.cl sql/conditions.cl -srcs-base-uffi := $(wildcard interfaces/clsql-uffi/*.cl) $(wildcard interfaces/clsql-uffi/*.so) -srcs-mysql := $(wildcard interfaces/mysql/*.cl) $(wildcards interfaces/mysl/*.so) +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/clsql +lispdir-mysql := $(prefix-mysql)/$(clc-clsql)/interfaces/mysql +sodir-mysql := $(prefix-mysql)/usr/lib/clsql +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 @@ -71,42 +89,61 @@ install: build dh_testdir dh_testroot dh_clean -k - dh_installdirs + dh_installdirs --all $(clc-systems) $(clc-source) + + $(INSTALL) $(INSTALLDIRFLAGS) $(lispdir) $(lispdir-base) \ + $(lispdir-base-uffi) $(lispdir-pg) $(lispdir-pg-socket) \ + $(lispdir-mysql) $(lispdir-sql) $(lispdir-aodbc) \ + $(sodir-base-uffi) $(sodir-mysql) # Main package - $(INSTALL) $(INSTALLFLAGS) $(srcs) $(prefix)/$(clc-repos)/clsql - $(INSTALL) $(INSTALLFLAGS) $(srcs-cmucl-compat) $(prefix)/$(clc-repos)/clsql/cmucl-compat + $(INSTALL) $(INSTALLDIRFLAGS) $(lispdir) $(lispdir-int) + $(INSTALL) $(INSTALLFLAGS) $(srcs) $(lispdir-sql) # Base - $(INSTALL) $(INSTALLFLAGS) $(srcs-base) $(prefix-base)/$(clc-repos)/clsql - $(INSTALL) $(INSTALLFLAGS) $(srcs-base-uffi) $(prefix-base)/$(clc-repos)/clsql/interfaces/clsql-uffi - - $(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) $(INSTALLFLAGS) $(srcs-aodbc) $(prefix-aodbc)/$(clc-repos)/clsql/interfaces/aodbc + $(INSTALL) $(INSTALLFLAGS) $(srcs-base) $(lispdir-base) + $(INSTALL) $(INSTALLFLAGS) $(srcs-base-uffi) $(lispdir-base-uffi) + $(INSTALL) $(INSTALLEXECFLAGS) $(srcs-base-uffi-so) $(sodir-base-uffi) - dh_link ../repositories/clsql $(prefix-base)/$(clc-source)/clsql + $(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-aodbc.system $(prefix-aodbc)/$(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) $(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 + rm -rf doc/html + (cd doc; tar xzf html.tar.gz; cd ..) $(INSTALL) $(INSTALLFLAGS) doc/html/* $(doc-dir)/html + rm -rf doc/html cp doc/clsql.pdf doc/cl-sql.pdf rm -f doc/cl-sql.pdf.gz gzip doc/cl-sql.pdf $(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 @@ -120,25 +157,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