r2200: Auto commit for Debian build
[clsql.git] / debian / rules
index f34fbe594bc5a43b8dd83b23ae23073e48baef52..e934d0a43290750cf7395b8a8f0ecdf11cb4bed3 100755 (executable)
@@ -6,7 +6,9 @@
 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
@@ -23,6 +25,8 @@ 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           := $(wildcard sql/*.cl)
 srcs-base      := $(wildcard base/*.cl)
@@ -42,7 +46,20 @@ INSTALLDIRFLAGS      := -d -g root -o root -m 0755
 clc-base       := usr/share/common-lisp
 clc-source     := $(clc-base)/source
 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
@@ -72,35 +89,46 @@ 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-source)/clsql/sql
+       $(INSTALL) $(INSTALLDIRFLAGS) $(lispdir) $(lispdir-int)
+       $(INSTALL) $(INSTALLFLAGS) $(srcs) $(lispdir-sql)
 
        # Base
-       $(INSTALL) $(INSTALLFLAGS) $(srcs-base) $(prefix-base)/$(clc-source)/clsql/base
-       $(INSTALL) $(INSTALLFLAGS) $(srcs-base-uffi) $(prefix-base)/$(clc-source)/clsql/interfaces/clsql-uffi
-       $(INSTALL) $(INSTALLEXECFLAGS) $(srcs-base-uffi-so) $(prefix-base)/$(clc-source)/clsql/interfaces/clsql-uffi
+       $(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) $(prefix-mysql)/$(clc-source)/clsql/interfaces/mysql
-       $(INSTALL) $(INSTALLEXECFLAGS) $(srcs-mysql-so) $(prefix-mysql)/$(clc-source)/clsql/interfaces/mysql
-       $(INSTALL) $(INSTALLFLAGS) $(srcs-pg) $(prefix-pg)/$(clc-source)/clsql/interfaces/postgresql
-       $(INSTALL) $(INSTALLFLAGS) $(srcs-pg-socket) $(prefix-pg-socket)/$(clc-source)/clsql/interfaces/postgresql-socket
-       $(INSTALL) $(INSTALLFLAGS) $(srcs-aodbc) $(prefix-aodbc)/$(clc-source)/clsql/interfaces/aodbc
+       $(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 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)/
+       $(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
@@ -130,6 +158,12 @@ binary-arch: build install
        dh_installdocs
 #      dh_installexamples 
        dh_installchangelogs ChangeLog
+       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