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 \
34 LIBBACSQL_OBJS = $(LIBBACSQL_SRCS:.c=.o)
35 LIBBACSQL_LOBJS = $(LIBBACSQL_SRCS:.c=.lo)
37 LIBBACSQL_LT_RELEASE = @LIBBACSQL_LT_RELEASE@
46 $(NO_ECHO)$(CXX) $(DEFS) $(DEBUG) -c $(WCFLAGS) $(CPPFLAGS) -I$(srcdir) -I$(basedir) $(SQL_INC) $(DINCLUDE) $(CFLAGS) $<
50 $(NO_ECHO)$(LIBTOOL_COMPILE) $(CXX) $(DEFS) $(DEBUG) -c $(WCFLAGS) $(CPPFLAGS) -I$(srcdir) -I$(basedir) $(SQL_INC) $(DINCLUDE) $(CFLAGS) $<
52 #-------------------------------------------------------------------------
53 all: Makefile libbacsql$(DEFAULT_ARCHIVE_TYPE)
54 @echo "==== Make of sqllib is good ===="
58 @echo "Generating myingres.c from myingres.sc"
59 $(NO_ECHO)$(II_SYSTEM)/ingres/bin/esqlcc -multi -extension=c myingres.sc
60 @echo "Generating myingres.h from myingres.sh"
61 $(NO_ECHO)$(II_SYSTEM)/ingres/bin/esqlcc -extension=h myingres.sh
63 libbacsql.a: $(LIBBACSQL_OBJS)
65 $(AR) rc $@ $(LIBBACSQL_OBJS)
68 libbacsql.la: Makefile $(LIBBACSQL_LOBJS)
70 $(LIBTOOL_LINK) $(CXX) $(DEFS) $(DEBUG) $(LDFLAGS) -o $@ $(LIBBACSQL_LOBJS) -export-dynamic -rpath $(libdir) -release $(LIBBACSQL_LT_RELEASE) $(DB_LIBS)
72 Makefile: $(srcdir)/Makefile.in $(topdir)/config.status
74 && CONFIG_FILES=$(thisdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status
77 @find . -name '*.lo' -print | xargs $(LIBTOOL_CLEAN) $(RMF)
79 @$(RMF) -r .libs _libs
82 @$(RMF) core a.out *.o *.bak *~ *.intpro *.extpro 1 2 3
87 $(RMF) create_bacula_database update_bacula_tables make_bacula_tables
88 $(RMF) grant_bacula_privileges drop_bacula_tables drop_bacula_database
90 $(RMF) create_mysql_database update_mysql_tables make_mysql_tables
91 $(RMF) grant_mysql_privileges drop_mysql_tables drop_mysql_database
93 $(RMF) create_postgresql_database update_postgresql_tables make_postgresql_tables
94 $(RMF) grant_postgresql_privileges drop_postgresql_tables drop_postgresql_database
96 $(RMF) create_ingres_database update_ingres_tables make_ingres_tables
97 $(RMF) grant_ingres_privileges drop_ingres_tables drop_ingres_database
99 $(RMF) create_sqlite_database update_sqlite_tables make_sqlite_tables
100 $(RMF) grant_sqlite_privileges drop_sqlite_tables drop_sqlite_database
102 $(RMF) create_sqlite3_database update_sqlite3_tables make_sqlite3_tables
103 $(RMF) grant_sqlite3_privileges drop_sqlite3_tables drop_sqlite3_database
105 $(RMF) mysql sqlite postgresql ingres
106 $(RMF) make_catalog_backup make_catalog_backup.pl delete_catalog_backup
109 if test $(srcdir) = .; then $(MAKE) realclean; fi
110 (cd $(srcdir); $(RMF) Makefile)
113 if test $(srcdir) = .; then $(MAKE) realclean; fi
114 (cd $(srcdir); $(RMF) Makefile)
117 $(MKDIR) $(DESTDIR)/$(includedir)/bacula/sql
118 for I in $(INCLUDE_FILES); do \
119 $(INSTALL_DATA) $$I $(DESTDIR)$(includedir)/bacula/sql/`basename $$I`; \
123 for I in $(INCLUDE_FILES); do \
124 $(RMF) $(DESTDIR)$(includedir)/bacula/sql/`basename $$I`; \
128 $(MKDIR) $(DESTDIR)$(libdir)
129 $(LIBTOOL_INSTALL_FINISH) $(INSTALL_LIB) libbacsql$(DEFAULT_ARCHIVE_TYPE) $(DESTDIR)$(libdir)
132 $(LIBTOOL_UNINSTALL) $(RMF) $(DESTDIR)$(libdir)/libbacsql.la
134 install: @LIBTOOL_INSTALL_TARGET@ @INCLUDE_INSTALL_TARGET@
135 $(INSTALL_SCRIPT) create_@DB_TYPE@_database $(DESTDIR)$(scriptdir)/create_@DB_TYPE@_database
136 $(INSTALL_SCRIPT) update_@DB_TYPE@_tables $(DESTDIR)$(scriptdir)/update_@DB_TYPE@_tables
137 $(INSTALL_SCRIPT) make_@DB_TYPE@_tables $(DESTDIR)$(scriptdir)/make_@DB_TYPE@_tables
138 $(INSTALL_SCRIPT) grant_@DB_TYPE@_privileges $(DESTDIR)$(scriptdir)/grant_@DB_TYPE@_privileges
139 $(INSTALL_SCRIPT) drop_@DB_TYPE@_tables $(DESTDIR)$(scriptdir)/drop_@DB_TYPE@_tables
140 $(INSTALL_SCRIPT) drop_@DB_TYPE@_database $(DESTDIR)$(scriptdir)/drop_@DB_TYPE@_database
142 $(INSTALL_SCRIPT) create_bacula_database $(DESTDIR)$(scriptdir)/create_bacula_database
143 $(INSTALL_SCRIPT) update_bacula_tables $(DESTDIR)$(scriptdir)/update_bacula_tables
144 $(INSTALL_SCRIPT) make_bacula_tables $(DESTDIR)$(scriptdir)/make_bacula_tables
145 $(INSTALL_SCRIPT) grant_bacula_privileges $(DESTDIR)$(scriptdir)/grant_bacula_privileges
146 $(INSTALL_SCRIPT) drop_bacula_tables $(DESTDIR)$(scriptdir)/drop_bacula_tables
147 $(INSTALL_SCRIPT) drop_bacula_database $(DESTDIR)$(scriptdir)/drop_bacula_database
149 @filename=make_catalog_backup.pl; \
150 if test -f $(DESTDIR)$(scriptdir)/$$filename; then \
151 destname=$$filename.new; \
152 echo " ==> Found existing $$filename, installing new file as $$destname"; \
154 destname=$$filename; \
156 echo "$(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname"; \
157 $(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname
158 @filename=make_catalog_backup; \
159 if test -f $(DESTDIR)$(scriptdir)/$$filename; then \
160 destname=$$filename.new; \
161 echo " ==> Found existing $$filename, installing new file as $$destname"; \
163 destname=$$filename; \
165 echo "$(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname"; \
166 $(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname
167 @filename=delete_catalog_backup; \
168 if test -f $(DESTDIR)$(scriptdir)/$$filename; then \
169 destname=$$filename.new; \
170 echo " ==> Found existing $$filename, installing new file as $$destname"; \
172 destname=$$filename; \
174 echo "$(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname"; \
175 $(INSTALL_SCRIPT) $$filename $(DESTDIR)$(scriptdir)/$$destname
177 uninstall: @LIBTOOL_UNINSTALL_TARGET@ @INCLUDE_UNINSTALL_TARGET@
178 (cd $(DESTDIR)$(scriptdir); $(RMF) create_@DB_TYPE@_database)
179 (cd $(DESTDIR)$(scriptdir); $(RMF) update_@DB_TYPE@_tables)
180 (cd $(DESTDIR)$(scriptdir); $(RMF) make_@DB_TYPE@_tables)
181 (cd $(DESTDIR)$(scriptdir); $(RMF) grant_@DB_TYPE@_privileges)
182 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_@DB_TYPE@_tables)
183 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_@DB_TYPE@_database)
185 (cd $(DESTDIR)$(scriptdir); $(RMF) create_bacula_database)
186 (cd $(DESTDIR)$(scriptdir); $(RMF) update_bacula_tables)
187 (cd $(DESTDIR)$(scriptdir); $(RMF) make_bacula_tables)
188 (cd $(DESTDIR)$(scriptdir); $(RMF) grant_bacula_privileges)
189 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_bacula_tables)
190 (cd $(DESTDIR)$(scriptdir); $(RMF) drop_bacula_database)
192 (cd $(DESTDIR)$(scriptdir); $(RMF) make_catalog_backup)
193 (cd $(DESTDIR)$(scriptdir); $(RMF) make_catalog_backup.pl)
194 (cd $(DESTDIR)$(scriptdir); $(RMF) delete_catalog_backup)
196 # Semi-automatic generation of dependencies:
197 # Use gcc -M because X11 `makedepend' doesn't work on all systems
198 # and it also includes system headers.
199 # `semi'-automatic since dependencies are generated at distribution time.
201 #depend: esql <- SRE: if generating from 'real' ingres source
203 @$(MV) Makefile Makefile.bak
204 @$(SED) "/^# DO NOT DELETE:/,$$ d" Makefile.bak > Makefile
205 @$(ECHO) "# DO NOT DELETE: nice dependency list follows" >> Makefile
206 @for src in $(LIBBACSQL_SRCS); do \
207 $(CXX) -S -M -MT `basename $$src .c`$(DEFAULT_OBJECT_TYPE) $(CPPFLAGS) $(XINC) -I$(srcdir) -I$(basedir) $(SQL_INC) $$src >> Makefile; \
209 @if test -f Makefile ; then \
210 $(RMF) Makefile.bak; \
212 $(MV) Makefile.bak Makefile; \
213 echo " ===== Something went wrong in make depend ====="; \
216 # -----------------------------------------------------------------------
217 # DO NOT DELETE: nice dependency list follows