11 # this dir relative to top dir
14 CPPFLAGS += -DBUILDING_CATS @DBI_DBD_DRIVERDIR@
17 MKDIR=$(topdir)/autoconf/mkinstalldirs
25 # include files installed when using libtool
27 INCLUDE_FILES = cats.h protos.h sql_cmds.h
29 LIBBACSQL_SRCS = mysql.c dbi.c \
30 sql.c sql_cmds.c sql_create.c sql_delete.c sql_find.c \
31 sql_get.c sql_list.c sql_update.c sqlite.c \
32 postgresql.c ingres.c myingres.c \
34 LIBBACSQL_OBJS = $(LIBBACSQL_SRCS:.c=.o)
35 LIBBACSQL_LOBJS = $(LIBBACSQL_SRCS:.c=.lo)
37 LIBBACSQL_LT_CURRENT = @LIBBACSQL_LT_CURRENT@
38 LIBBACSQL_LT_REVISION = @LIBBACSQL_LT_REVISION@
39 LIBBACSQL_LT_AGE = @LIBBACSQL_LT_AGE@
48 $(NO_ECHO)$(CXX) $(DEFS) $(DEBUG) -c $(WCFLAGS) $(CPPFLAGS) -I$(srcdir) -I$(basedir) $(SQL_INC) $(DINCLUDE) $(CFLAGS) $<
52 $(NO_ECHO)$(LIBTOOL_COMPILE) $(CXX) $(DEFS) $(DEBUG) -c $(WCFLAGS) $(CPPFLAGS) -I$(srcdir) -I$(basedir) $(SQL_INC) $(DINCLUDE) $(CFLAGS) $<
54 #-------------------------------------------------------------------------
55 all: Makefile libbacsql$(DEFAULT_ARCHIVE_TYPE)
56 @echo "==== Make of sqllib is good ===="
59 # SRE: embeddedSQL precompiler run
61 $(II_SYSTEM)/ingres/bin/esqlc -omyingres.c myingres.sc
62 $(II_SYSTEM)/ingres/bin/esqlc -omyingres.h myingres.sh
64 libbacsql.a: $(LIBBACSQL_OBJS)
66 $(AR) rc $@ $(LIBBACSQL_OBJS)
69 libbacsql.la: Makefile $(LIBBACSQL_LOBJS)
71 $(LIBTOOL_LINK) $(CXX) $(DEFS) $(DEBUG) $(LDFLAGS) -o $@ $(LIBBACSQL_LOBJS) -export-dynamic -rpath $(libdir) -release $(LIBBACSQL_LT_CURRENT).$(LIBBACSQL_LT_REVISION).$(LIBBACSQL_LT_AGE) $(DB_LIBS)
73 Makefile: $(srcdir)/Makefile.in $(topdir)/config.status
75 && CONFIG_FILES=$(thisdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status
78 @find . -name '*.lo' -print | xargs $(LIBTOOL_CLEAN) $(RMF)
80 @$(RMF) -r .libs _libs
83 @$(RMF) core a.out *.o *.bak *~ *.intpro *.extpro 1 2 3
88 $(RMF) create_bacula_database update_bacula_tables make_bacula_tables
89 $(RMF) grant_bacula_privileges drop_bacula_tables drop_bacula_database
91 $(RMF) create_bdb_database update_bdb_tables make_bdb_tables
92 $(RMF) grant_bdb_privileges drop_bdb_tables drop_bdb_database
94 $(RMF) create_mysql_database update_mysql_tables make_mysql_tables
95 $(RMF) grant_mysql_privileges drop_mysql_tables drop_mysql_database
97 $(RMF) create_postgresql_database update_postgresql_tables make_postgresql_tables
98 $(RMF) grant_postgresql_privileges drop_postgresql_tables drop_postgresql_database
100 $(RMF) create_ingres_database update_ingres_tables make_ingres_tables
101 $(RMF) grant_ingres_privileges drop_ingres_tables drop_ingres_database
103 $(RMF) create_sqlite_database update_sqlite_tables make_sqlite_tables
104 $(RMF) grant_sqlite_privileges drop_sqlite_tables drop_sqlite_database
106 $(RMF) create_sqlite3_database update_sqlite3_tables make_sqlite3_tables
107 $(RMF) grant_sqlite3_privileges drop_sqlite3_tables drop_sqlite3_database
109 $(RMF) mysql sqlite postgresql ingres
110 $(RMF) make_catalog_backup make_catalog_backup.pl delete_catalog_backup
113 if test $(srcdir) = .; then $(MAKE) realclean; fi
114 (cd $(srcdir); $(RMF) Makefile)
117 if test $(srcdir) = .; then $(MAKE) realclean; fi
118 (cd $(srcdir); $(RMF) Makefile)
121 $(MKDIR) $(DESTDIR)/$(includedir)/bacula/sql
122 for I in $(INCLUDE_FILES); do \
123 $(INSTALL_DATA) $$I $(DESTDIR)$(includedir)/bacula/sql/`basename $$I`; \
127 for I in $(INCLUDE_FILES); do \
128 $(RMF) $(DESTDIR)$(includedir)/bacula/sql/`basename $$I`; \
132 $(MKDIR) $(DESTDIR)$(libdir)
133 $(LIBTOOL_INSTALL_FINISH) $(INSTALL_PROGRAM) libbacsql$(DEFAULT_ARCHIVE_TYPE) $(DESTDIR)$(libdir)
136 $(LIBTOOL_UNINSTALL) $(RMF) $(DESTDIR)$(libdir)/libbacsql.la
138 install: @LIBTOOL_INSTALL_TARGET@ @INCLUDE_INSTALL_TARGET@
139 $(INSTALL_SCRIPT) create_@DB_TYPE@_database $(DESTDIR)$(scriptdir)/create_@DB_TYPE@_database
140 $(INSTALL_SCRIPT) update_@DB_TYPE@_tables $(DESTDIR)$(scriptdir)/update_@DB_TYPE@_tables
141 $(INSTALL_SCRIPT) make_@DB_TYPE@_tables $(DESTDIR)$(scriptdir)/make_@DB_TYPE@_tables
142 $(INSTALL_SCRIPT) grant_@DB_TYPE@_privileges $(DESTDIR)$(scriptdir)/grant_@DB_TYPE@_privileges
143 $(INSTALL_SCRIPT) drop_@DB_TYPE@_tables $(DESTDIR)$(scriptdir)/drop_@DB_TYPE@_tables
144 $(INSTALL_SCRIPT) drop_@DB_TYPE@_database $(DESTDIR)$(scriptdir)/drop_@DB_TYPE@_database
146 $(INSTALL_SCRIPT) create_bacula_database $(DESTDIR)$(scriptdir)/create_bacula_database
147 $(INSTALL_SCRIPT) update_bacula_tables $(DESTDIR)$(scriptdir)/update_bacula_tables
148 $(INSTALL_SCRIPT) make_bacula_tables $(DESTDIR)$(scriptdir)/make_bacula_tables
149 $(INSTALL_SCRIPT) grant_bacula_privileges $(DESTDIR)$(scriptdir)/grant_bacula_privileges
150 $(INSTALL_SCRIPT) drop_bacula_tables $(DESTDIR)$(scriptdir)/drop_bacula_tables
151 $(INSTALL_SCRIPT) drop_bacula_database $(DESTDIR)$(scriptdir)/drop_bacula_database
153 @filename=make_catalog_backup.pl; \
154 if test -f $(DESTDIR)$(scriptdir)/$$filename; then \
155 destname=$$filename.new; \
156 echo " ==> Found existing $$filename, installing new file as $$destname"; \
158 destname=$$filename; \
160 echo "$(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname"; \
161 $(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname
162 @filename=make_catalog_backup; \
163 if test -f $(DESTDIR)$(scriptdir)/$$filename; then \
164 destname=$$filename.new; \
165 echo " ==> Found existing $$filename, installing new file as $$destname"; \
167 destname=$$filename; \
169 echo "$(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname"; \
170 $(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname
171 @filename=delete_catalog_backup; \
172 if test -f $(DESTDIR)$(scriptdir)/$$filename; then \
173 destname=$$filename.new; \
174 echo " ==> Found existing $$filename, installing new file as $$destname"; \
176 destname=$$filename; \
178 echo "$(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname"; \
179 $(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname
181 uninstall: @LIBTOOL_UNINSTALL_TARGET@ @INCLUDE_UNINSTALL_TARGET@
182 (cd $(DESTDIR)$(scriptdir); $(RMF) create_@DB_TYPE@_database)
183 (cd $(DESTDIR)$(scriptdir); $(RMF) update_@DB_TYPE@_tables)
184 (cd $(DESTDIR)$(scriptdir); $(RMF) make_@DB_TYPE@_tables)
185 (cd $(DESTDIR)$(scriptdir); $(RMF) grant_@DB_TYPE@_privileges)
186 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_@DB_TYPE@_tables)
187 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_@DB_TYPE@_database)
189 (cd $(DESTDIR)$(scriptdir); $(RMF) create_bacula_database)
190 (cd $(DESTDIR)$(scriptdir); $(RMF) update_bacula_tables)
191 (cd $(DESTDIR)$(scriptdir); $(RMF) make_bacula_tables)
192 (cd $(DESTDIR)$(scriptdir); $(RMF) grant_bacula_privileges)
193 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_bacula_tables)
194 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_bacula_database)
196 (cd $(DESTDIR)$(scriptdir); $(RMF) make_catalog_backup)
197 (cd $(DESTDIR)$(scriptdir); $(RMF) make_catalog_backup.pl)
198 (cd $(DESTDIR)$(scriptdir); $(RMF) delete_catalog_backup)
200 # Semi-automatic generation of dependencies:
201 # Use gcc -M because X11 `makedepend' doesn't work on all systems
202 # and it also includes system headers.
203 # `semi'-automatic since dependencies are generated at distribution time.
205 #depend: esql <- SRE: if generating from 'real' ingres source
207 @$(MV) Makefile Makefile.bak
208 @$(SED) "/^# DO NOT DELETE:/,$$ d" Makefile.bak > Makefile
209 @$(ECHO) "# DO NOT DELETE: nice dependency list follows" >> Makefile
210 @for src in $(LIBBACSQL_SRCS); do \
211 $(CXX) -S -M -MT `basename $$src .c`$(DEFAULT_OBJECT_TYPE) $(CPPFLAGS) $(XINC) -I$(srcdir) -I$(basedir) $(SQL_INC) $$src >> Makefile; \
213 @if test -f Makefile ; then \
214 $(RMF) Makefile.bak; \
216 $(MV) Makefile.bak Makefile; \
217 echo " ===== Something went wrong in make depend ====="; \
220 # -----------------------------------------------------------------------
221 # DO NOT DELETE: nice dependency list follows