]> git.saurik.com Git - wxWidgets.git/blobdiff - src/makelib.env.in
Replaced 'erase' with $(RM) so that the default file deletion program can be overriden
[wxWidgets.git] / src / makelib.env.in
index 7b6d8b18966f6938154497c7517ba91122b2c881..9ad3b1c6253afc73c29f5fafa357f2056439b871 100644 (file)
@@ -3,13 +3,23 @@
 #
 # Author:   Ron Lee <ron@debian.org>
 # Created:  19/3/2000
+# $Id$
 #
-# To use, set the following vars before including it.
+# To use, set the following vars before including it:
+#
+# top_srcdir
+# top_builddir
+# libsrc_dir
 #
 # TARGET_LIBNAME
 # LIBVERSION_CURRENT
 # LIBVERSION_REVISION
 # LIBVERSION_AGE
+# HEADER_PATH
+# HEADER_SUBDIR
+#
+# HEADERS
+# OBJECTS
 #
 # either a shared or static lib will be built according to the
 # option given to configure.
 
 prefix = @prefix@
 exec_prefix = @exec_prefix@
+includedir = @includedir@
 libdir = @libdir@
 
 INSTALL = @INSTALL@
 INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+
+TARGETLIB_STATIC = ${TARGET_LIBNAME}.a
+TARGETLIB_SHARED = ${TARGET_LIBNAME}.so.${LIBVERSION_CURRENT}.${LIBVERSION_REVISION}.${LIBVERSION_AGE}
+TARGETLIB_LINK1 = ${TARGET_LIBNAME}.so.${LIBVERSION_CURRENT}
+TARGETLIB_LINK2 = ${TARGET_LIBNAME}.so
 
-TARGETLIB_STATIC=$(TARGET_LIBNAME).a
-TARGETLIB_SHARED=$(TARGET_LIBNAME).so.$(LIBVERSION_CURRENT).$(LIBVERSION_REVISION).$(LIBVERSION_AGE)
-TARGETLIB_LINK1=$(TARGET_LIBNAME).so.$(LIBVERSION_CURRENT)
-TARGETLIB_LINK2=$(TARGET_LIBNAME).so
+TARGETLIB_SONAME = @WX_TARGET_LIBRARY_SONAME@
 
 # Clears all default suffixes
 .SUFFIXES:     .o .cpp .c .cxx
 
 .c.o :
-       $(CCC) -c $(CFLAGS) $(PICFLAGS) -o $@ $<
+       ${CCC} -c @DEP_INFO_FLAGS@ ${CFLAGS} ${PICFLAGS} -o $@ $<
 
 .cpp.o :
-       $(CC) -c $(CPPFLAGS) $(PICFLAGS) -o $@ $<
+       ${CC} -c @DEP_INFO_FLAGS@ ${CXXFLAGS} ${PICFLAGS} -o $@ $<
 
 .cxx.o :
-       $(CC) -c $(CPPFLAGS) $(PICFLAGS) -o $@ $<
+       ${CC} -c @DEP_INFO_FLAGS@ ${CXXFLAGS} ${PICFLAGS} -o $@ $<
 
-include $(top_builddir)/src/make.env
+# the comment at the end of the next line is needed because otherwise autoconf
+# would remove this line completely - it contains a built-in hack to remove
+# any VPATH assignment not containing ':'
+VPATH = @PATH_IFS@${top_srcdir}/${libsrc_dir} # ':' for autoconf
 
+include ${top_builddir}/src/make.env
 
-all:    libtype_@WX_TARGET_LIBRARY_TYPE@
+
+all: libtype_@WX_TARGET_LIBRARY_TYPE@
 
 libtype_so: CREATE_LINKS
 
-libtype_a: $(TARGETLIB_STATIC)
+libtype_a: ${TARGETLIB_STATIC}
 
 
-$(TARGETLIB_SHARED): $(OBJECTS)
-       $(SHARED_LD) $@ $(OBJECTS)
+${TARGETLIB_SHARED}: ${OBJECTS}
+       @${INSTALL} -d ${top_builddir}/lib
+       ${SHARED_LD} ${top_builddir}/lib/$@ ${TARGETLIB_SONAME} ${OBJECTS}
 
-CREATE_LINKS: $(TARGETLIB_SHARED)
-       @$(RM) $(TARGETLIB_LINK1) $(TARGETLIB_LINK2)
-       $(LN_S) $(TARGETLIB_SHARED) $(TARGETLIB_LINK1)
-       $(LN_S) $(TARGETLIB_SHARED) $(TARGETLIB_LINK2)
+CREATE_LINKS: ${TARGETLIB_SHARED}
+       cd ${top_builddir}/lib \
+               && ${RM} ${TARGETLIB_LINK1} ${TARGETLIB_LINK2} \
+               && ${LN_S} ${TARGETLIB_SHARED} ${TARGETLIB_LINK1} \
+               && ${LN_S} ${TARGETLIB_SHARED} ${TARGETLIB_LINK2}
 
-$(TARGETLIB_STATIC): $(OBJECTS)
-       ar $(AROPTIONS) $@ $(OBJECTS)
-       $(RANLIB) $@
+${TARGETLIB_STATIC}: ${OBJECTS}
+       @${INSTALL} -d ${top_builddir}/lib
+       ar ${AROPTIONS} ${top_builddir}/lib/$@ ${OBJECTS}
+       ${RANLIB} ${top_builddir}/lib/$@
 
-install: install_@WX_TARGET_LIBRARY_TYPE@
+install: install_@WX_TARGET_LIBRARY_TYPE@ install_headers
 
 install_so:
-       $(INSTALL_PROGRAM) $(TARGETLIB_SHARED) $(libdir)/$(TARGETLIB_SHARED)
-       @$(RM) $(libdir)/$(TARGETLIB_LINK1) $(libdir)/$(TARGETLIB_LINK2)
-       cd $(libdir) \
-               && $(LN_S) $(TARGETLIB_SHARED) $(TARGETLIB_LINK1) \
-               && $(LN_S) $(TARGETLIB_SHARED) $(TARGETLIB_LINK2)
+       ${INSTALL_PROGRAM} ${top_builddir}/lib/${TARGETLIB_SHARED} ${libdir}/${TARGETLIB_SHARED}
+       @${RM} ${libdir}/${TARGETLIB_LINK1} ${libdir}/${TARGETLIB_LINK2}
+       cd ${libdir} \
+               && ${LN_S} ${TARGETLIB_SHARED} ${TARGETLIB_LINK1} \
+               && ${LN_S} ${TARGETLIB_SHARED} ${TARGETLIB_LINK2}
 
 install_a:
-       $(INSTALL_PROGRAM) $(TARGETLIB_STATIC) $(libdir)/$(TARGETLIB_STATIC)
+       ${INSTALL_PROGRAM} ${top_builddir}/lib/${TARGETLIB_STATIC} ${libdir}/${TARGETLIB_STATIC}
+
+install_headers:
+       ${INSTALL} -d ${includedir}/wx/${HEADER_SUBDIR}
+       @for h in ${HEADERS}; do \
+         ${INSTALL_DATA} ${HEADER_PATH}/${HEADER_SUBDIR}/$$h ${includedir}/wx/${HEADER_SUBDIR}/$$h; \
+         echo "installing ${includedir}/wx/${HEADER_SUBDIR}/$$h"; \
+       done
 
 uninstall:
-       $(RM) $(libdir)/$(TARGETLIB_STATIC)
-       $(RM) $(libdir)/$(TARGETLIB_SHARED)
-       $(RM) $(libdir)/$(TARGETLIB_LINK1)
-       $(RM) $(libdir)/$(TARGETLIB_LINK2)
+       ${RM} ${libdir}/${TARGETLIB_STATIC}
+       ${RM} ${libdir}/${TARGETLIB_SHARED}
+       ${RM} ${libdir}/${TARGETLIB_LINK1}
+       ${RM} ${libdir}/${TARGETLIB_LINK2}
+       @echo "removing headers"
+       @for h in ${HEADERS}; do \
+         ${RM} ${includedir}/wx/${HEADER_SUBDIR}/$$h; \
+       done
+       @if test -d ${includedir}/wx/${HEADER_SUBDIR}; then \
+         rmdir ${includedir}/wx/${HEADER_SUBDIR}; \
+       fi
+       @-rmdir ${includedir}/wx
 
 clean:
-       $(RM) $(OBJECTS) $(TARGETLIB_SHARED) $(TARGETLIB_LINK1) \
-             $(TARGETLIB_LINK2) $(TARGETLIB_STATIC) core
+       ${RM} ${OBJECTS} ${top_builddir}/lib/${TARGETLIB_SHARED} \
+             ${top_builddir}/lib/${TARGETLIB_LINK1} \
+             ${top_builddir}/lib/${TARGETLIB_LINK2} \
+             ${top_builddir}/lib/${TARGETLIB_STATIC} core
 
 .PHONY: all shared static clean install install_static install_shared uninstall