Commit 46e76373 authored by Peter Eisentraut's avatar Peter Eisentraut

Implement a few changes to how shared libraries and dynamically loadable

modules are built.  Foremost, it creates a solid distinction between these two
types of targets based on what had already been implemented and duplicated in
ad hoc ways before.  Specifically,

- Dynamically loadable modules no longer get a soname.  The numbers previously
set in the makefiles were dummy numbers anyway, and the presence of a soname
upset a few packaging tools, so it is nicer not to have one.

- The cumbersome detour taken on installation (build a libfoo.so.0.0.0 and
then override the rule to install foo.so instead) is removed.

- Lots of duplicated code simplified.
parent 8deafd6f
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
# Copyright (c) 1998, Regents of the University of California # Copyright (c) 1998, Regents of the University of California
# #
# IDENTIFICATION # IDENTIFICATION
# $PostgreSQL: pgsql/src/Makefile.shlib,v 1.113 2008/02/26 14:26:16 petere Exp $ # $PostgreSQL: pgsql/src/Makefile.shlib,v 1.114 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -19,13 +19,18 @@ ...@@ -19,13 +19,18 @@
# variables: # variables:
# #
# NAME Name of library to build (no suffix nor "lib" prefix) # NAME Name of library to build (no suffix nor "lib" prefix)
# SO_MAJOR_VERSION Major version number to use for shared library
# SO_MINOR_VERSION Minor version number to use for shared library
# OBJS List of object files to include in library # OBJS List of object files to include in library
# SHLIB_LINK If shared library relies on other libraries, # SHLIB_LINK If shared library relies on other libraries,
# additional stuff to put in its link command # additional stuff to put in its link command
# SHLIB_EXPORTS (optional) Name of file containing list of symbols to # SHLIB_EXPORTS (optional) Name of file containing list of symbols to
# export # export
#
# When building a shared library, the following version information
# must also be set. It should be omitted when building a dynamically
# loadable module.
#
# SO_MAJOR_VERSION Major version number to use for shared library
# SO_MINOR_VERSION Minor version number to use for shared library
# (If you want a patchlevel, include it in SO_MINOR_VERSION, e.g., "6.2".) # (If you want a patchlevel, include it in SO_MINOR_VERSION, e.g., "6.2".)
# #
# Optional flags when building DLL's (only applicable to win32 and cygwin # Optional flags when building DLL's (only applicable to win32 and cygwin
...@@ -42,6 +47,7 @@ ...@@ -42,6 +47,7 @@
# #
# all-lib build the static and shared (if applicable) libraries # all-lib build the static and shared (if applicable) libraries
# install-lib install the libraries into $(libdir) # install-lib install the libraries into $(libdir)
# installdirs-lib create installation directory $(libdir)
# uninstall-lib remove the libraries from $(libdir) # uninstall-lib remove the libraries from $(libdir)
# clean-lib delete the static and shared libraries from the build dir # clean-lib delete the static and shared libraries from the build dir
# maintainer-clean-lib delete .def files built for win32 # maintainer-clean-lib delete .def files built for win32
...@@ -72,18 +78,34 @@ LINK.static = $(AR) $(AROPT) ...@@ -72,18 +78,34 @@ LINK.static = $(AR) $(AROPT)
ifeq ($(enable_shared), yes)
# Insert -L from LDFLAGS after any -L already present in SHLIB_LINK # Insert -L from LDFLAGS after any -L already present in SHLIB_LINK
SHLIB_LINK := $(filter -L%, $(SHLIB_LINK)) $(filter -L%, $(LDFLAGS)) $(filter-out -L%, $(SHLIB_LINK)) SHLIB_LINK := $(filter -L%, $(SHLIB_LINK)) $(filter -L%, $(LDFLAGS)) $(filter-out -L%, $(SHLIB_LINK))
# Need a -L-free version of LDFLAGS to use in combination with SHLIB_LINK # Need a -L-free version of LDFLAGS to use in combination with SHLIB_LINK
LDFLAGS_NO_L = $(filter-out -L%, $(LDFLAGS)) LDFLAGS_NO_L = $(filter-out -L%, $(LDFLAGS))
# Default shlib naming convention used by the majority of platforms ifdef SO_MAJOR_VERSION
# Default library naming convention used by the majority of platforms
ifeq ($(enable_shared), yes)
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION) shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)
shlib_major = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION) shlib_major = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)
shlib_bare = lib$(NAME)$(DLSUFFIX) shlib_bare = lib$(NAME)$(DLSUFFIX)
endif
# Testing the soname variable is a reliable way to determine whether a
# linkable library is being built.
soname = $(shlib_major)
stlib = lib$(NAME).a
else
# Naming convention for dynamically loadable modules
ifeq ($(enable_shared), yes)
shlib = $(NAME)$(DLSUFFIX)
endif
endif
ifndef soname
# additional flags for backend modules
SHLIB_LINK := $(BE_DLLLIBS) $(SHLIB_LINK)
endif
# For each platform we support shared libraries on, set shlib to the # For each platform we support shared libraries on, set shlib to the
# name of the library (if default above is not right), set # name of the library (if default above is not right), set
...@@ -94,29 +116,29 @@ shlib_bare = lib$(NAME)$(DLSUFFIX) ...@@ -94,29 +116,29 @@ shlib_bare = lib$(NAME)$(DLSUFFIX)
override CFLAGS += $(CFLAGS_SL) override CFLAGS += $(CFLAGS_SL)
soname = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)
ifeq ($(PORTNAME), aix) ifeq ($(PORTNAME), aix)
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION) ifdef SO_MAJOR_VERSION
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)
endif
haslibarule = yes haslibarule = yes
exports_file = lib$(NAME).exp exports_file = lib$(NAME).exp
endif endif
ifeq ($(PORTNAME), darwin) ifeq ($(PORTNAME), darwin)
ifneq ($(SO_MAJOR_VERSION), 0) ifdef soname
version_link = -compatibility_version $(SO_MAJOR_VERSION) -current_version $(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)
endif
ifeq ($(DLTYPE), library)
# linkable library # linkable library
DLSUFFIX = .dylib DLSUFFIX = .dylib
ifneq ($(SO_MAJOR_VERSION), 0)
version_link = -compatibility_version $(SO_MAJOR_VERSION) -current_version $(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)
endif
LINK.shared = $(COMPILER) -dynamiclib -install_name $(libdir)/lib$(NAME).$(SO_MAJOR_VERSION)$(DLSUFFIX) $(version_link) $(exported_symbols_list) -multiply_defined suppress LINK.shared = $(COMPILER) -dynamiclib -install_name $(libdir)/lib$(NAME).$(SO_MAJOR_VERSION)$(DLSUFFIX) $(version_link) $(exported_symbols_list) -multiply_defined suppress
shlib = lib$(NAME).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)$(DLSUFFIX)
shlib_major = lib$(NAME).$(SO_MAJOR_VERSION)$(DLSUFFIX)
else else
# loadable module (default case) # loadable module
DLSUFFIX = .so DLSUFFIX = .so
LINK.shared = $(COMPILER) -bundle -multiply_defined suppress LINK.shared = $(COMPILER) -bundle -multiply_defined suppress
endif endif
shlib = lib$(NAME).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)$(DLSUFFIX)
shlib_major = lib$(NAME).$(SO_MAJOR_VERSION)$(DLSUFFIX)
BUILD.exports = $(AWK) '/^[^\#]/ {printf "_%s\n",$$1}' $< >$@ BUILD.exports = $(AWK) '/^[^\#]/ {printf "_%s\n",$$1}' $< >$@
exports_file = $(SHLIB_EXPORTS:%.txt=%.list) exports_file = $(SHLIB_EXPORTS:%.txt=%.list)
ifneq (,$(exports_file)) ifneq (,$(exports_file))
...@@ -126,7 +148,10 @@ endif ...@@ -126,7 +148,10 @@ endif
ifeq ($(PORTNAME), openbsd) ifeq ($(PORTNAME), openbsd)
ifdef ELF_SYSTEM ifdef ELF_SYSTEM
LINK.shared = $(COMPILER) -shared -Wl,-x,-soname,$(soname) LINK.shared = $(COMPILER) -shared
ifdef soname
LINK.shared += -Wl,-x,-soname,$(soname)
endif
SHLIB_LINK += -lc SHLIB_LINK += -lc
else else
LINK.shared = $(LD) -x -Bshareable -Bforcearchive LINK.shared = $(LD) -x -Bshareable -Bforcearchive
...@@ -135,7 +160,10 @@ endif ...@@ -135,7 +160,10 @@ endif
ifeq ($(PORTNAME), bsdi) ifeq ($(PORTNAME), bsdi)
ifeq ($(DLSUFFIX), .so) ifeq ($(DLSUFFIX), .so)
LINK.shared = $(COMPILER) -shared -Wl,-x,-soname,$(soname) LINK.shared = $(COMPILER) -shared
ifdef soname
LINK.shared += -Wl,-x,-soname,$(soname)
endif
SHLIB_LINK += -lc SHLIB_LINK += -lc
endif endif
ifeq ($(DLSUFFIX), .o) ifeq ($(DLSUFFIX), .o)
...@@ -145,33 +173,50 @@ endif ...@@ -145,33 +173,50 @@ endif
ifeq ($(PORTNAME), freebsd) ifeq ($(PORTNAME), freebsd)
ifdef ELF_SYSTEM ifdef ELF_SYSTEM
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION) ifdef SO_MAJOR_VERSION
LINK.shared = $(COMPILER) -shared -Wl,-x,-soname,$(soname) shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)
endif
LINK.shared = $(COMPILER) -shared
ifdef soname
LINK.shared += -Wl,-x,-soname,$(soname)
endif
else else
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION) ifdef SO_MAJOR_VERSION
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)
endif
LINK.shared = $(LD) -x -Bshareable -Bforcearchive LINK.shared = $(LD) -x -Bshareable -Bforcearchive
endif endif
endif endif
ifeq ($(PORTNAME), netbsd) ifeq ($(PORTNAME), netbsd)
ifdef ELF_SYSTEM ifdef ELF_SYSTEM
LINK.shared = $(COMPILER) -shared -Wl,-x,-soname,$(soname) LINK.shared = $(COMPILER) -shared
ifdef soname
LINK.shared += -Wl,-x,-soname,$(soname)
endif
else else
LINK.shared = $(LD) -x -Bshareable -Bforcearchive LINK.shared = $(LD) -x -Bshareable -Bforcearchive
endif endif
endif endif
ifeq ($(PORTNAME), hpux) ifeq ($(PORTNAME), hpux)
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION) ifdef SO_MAJOR_VERSION
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)
endif
ifeq ($(with_gnu_ld), yes) ifeq ($(with_gnu_ld), yes)
LINK.shared = $(CC) $(LDFLAGS_NO_L) -shared -Wl,-h -Wl,$(soname) LINK.shared = $(CC) $(LDFLAGS_NO_L) -shared
ifdef soname
LINK.shared += -Wl,-h -Wl,$(soname)
endif
else else
# can't use the CC-syntax rpath pattern here # can't use the CC-syntax rpath pattern here
rpath = rpath =
LINK.shared = $(LD) -b
ifdef soname
LINK.shared += +h $(soname)
endif
ifeq ($(enable_rpath), yes) ifeq ($(enable_rpath), yes)
LINK.shared = $(LD) +h $(soname) -b +b '$(rpathdir)' LINK.shared += +b '$(rpathdir)'
else
LINK.shared = $(LD) +h $(soname) -b
endif endif
# On HPUX platforms, gcc is usually configured to search for libraries # On HPUX platforms, gcc is usually configured to search for libraries
# in /usr/local/lib, but ld won't do so. Add an explicit -L switch so # in /usr/local/lib, but ld won't do so. Add an explicit -L switch so
...@@ -188,12 +233,20 @@ ifeq ($(PORTNAME), hpux) ...@@ -188,12 +233,20 @@ ifeq ($(PORTNAME), hpux)
endif endif
ifeq ($(PORTNAME), irix) ifeq ($(PORTNAME), irix)
shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION) ifdef SO_MAJOR_VERSION
LINK.shared = $(COMPILER) -shared -Wl,-set_version,sgi$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION) shlib = lib$(NAME)$(DLSUFFIX).$(SO_MAJOR_VERSION)
endif
LINK.shared = $(COMPILER) -shared
ifdef soname
LINK.shared += -Wl,-set_version,sgi$(SO_MAJOR_VERSION).$(SO_MINOR_VERSION)
endif
endif endif
ifeq ($(PORTNAME), linux) ifeq ($(PORTNAME), linux)
LINK.shared = $(COMPILER) -shared -Wl,-soname,$(soname) LINK.shared = $(COMPILER) -shared
ifdef soname
LINK.shared += -Wl,-soname,$(soname)
endif
BUILD.exports = ( echo '{ global:'; $(AWK) '/^[^\#]/ {printf "%s;\n",$$1}' $<; echo ' local: *; };' ) >$@ BUILD.exports = ( echo '{ global:'; $(AWK) '/^[^\#]/ {printf "%s;\n",$$1}' $<; echo ' local: *; };' ) >$@
exports_file = $(SHLIB_EXPORTS:%.txt=%.list) exports_file = $(SHLIB_EXPORTS:%.txt=%.list)
ifneq (,$(exports_file)) ifneq (,$(exports_file))
...@@ -208,10 +261,12 @@ ifeq ($(PORTNAME), solaris) ...@@ -208,10 +261,12 @@ ifeq ($(PORTNAME), solaris)
# CFLAGS added for X86_64 # CFLAGS added for X86_64
LINK.shared = $(CC) -G $(CFLAGS) LINK.shared = $(CC) -G $(CFLAGS)
endif endif
ifeq ($(with_gnu_ld), yes) ifdef soname
LINK.shared += -Wl,-soname,$(soname) ifeq ($(with_gnu_ld), yes)
else LINK.shared += -Wl,-soname,$(soname)
LINK.shared += -h $(soname) else
LINK.shared += -h $(soname)
endif
endif endif
endif endif
...@@ -229,7 +284,10 @@ ifeq ($(PORTNAME), sco) ...@@ -229,7 +284,10 @@ ifeq ($(PORTNAME), sco)
else else
LINK.shared = $(CC) -G LINK.shared = $(CC) -G
endif endif
LINK.shared += -Wl,-z,text -Wl,-h,$(soname) LINK.shared += -Wl,-z,text
ifdef soname
LINK.shared += -Wl,-h,$(soname)
endif
endif endif
ifeq ($(PORTNAME), svr4) ifeq ($(PORTNAME), svr4)
...@@ -246,7 +304,10 @@ ifeq ($(PORTNAME), unixware) ...@@ -246,7 +304,10 @@ ifeq ($(PORTNAME), unixware)
else else
LINK.shared = $(CC) -G LINK.shared = $(CC) -G
endif endif
LINK.shared += -Wl,-z,text -Wl,-h,$(soname) LINK.shared += -Wl,-z,text
ifdef soname
LINK.shared += -Wl,-h,$(soname)
endif
endif endif
ifeq ($(PORTNAME), cygwin) ifeq ($(PORTNAME), cygwin)
...@@ -263,8 +324,6 @@ ifeq ($(enable_rpath), yes) ...@@ -263,8 +324,6 @@ ifeq ($(enable_rpath), yes)
SHLIB_LINK += $(rpath) SHLIB_LINK += $(rpath)
endif endif
endif # enable_shared
## ##
...@@ -273,14 +332,18 @@ endif # enable_shared ...@@ -273,14 +332,18 @@ endif # enable_shared
.PHONY: all-lib all-static-lib all-shared-lib .PHONY: all-lib all-static-lib all-shared-lib
all-lib: all-static-lib all-shared-lib all-lib: all-shared-lib
ifdef soname
# no static library when building a dynamically loadable module
all-lib: all-static-lib
endif
all-static-lib: lib$(NAME).a all-static-lib: $(stlib)
all-shared-lib: $(shlib) all-shared-lib: $(shlib)
ifndef haslibarule ifndef haslibarule
lib$(NAME).a: $(OBJS) $(stlib): $(OBJS)
$(LINK.static) $@ $^ $(LINK.static) $@ $^
$(RANLIB) $@ $(RANLIB) $@
endif #haslibarule endif #haslibarule
...@@ -293,6 +356,7 @@ ifneq ($(PORTNAME), aix) ...@@ -293,6 +356,7 @@ ifneq ($(PORTNAME), aix)
# Normal case # Normal case
$(shlib): $(OBJS) $(shlib): $(OBJS)
$(LINK.shared) $(LDFLAGS_SL) $(OBJS) $(SHLIB_LINK) -o $@ $(LINK.shared) $(LDFLAGS_SL) $(OBJS) $(SHLIB_LINK) -o $@
ifdef shlib_major
# If we're using major and minor versions, then make a symlink to major-version-only. # If we're using major and minor versions, then make a symlink to major-version-only.
ifneq ($(shlib), $(shlib_major)) ifneq ($(shlib), $(shlib_major))
rm -f $(shlib_major) rm -f $(shlib_major)
...@@ -303,6 +367,7 @@ ifneq ($(shlib), $(shlib_bare)) ...@@ -303,6 +367,7 @@ ifneq ($(shlib), $(shlib_bare))
rm -f $(shlib_bare) rm -f $(shlib_bare)
$(LN_S) $(shlib) $(shlib_bare) $(LN_S) $(shlib) $(shlib_bare)
endif endif
endif # shlib_major
# Where possible, restrict the symbols exported by the library to just the # Where possible, restrict the symbols exported by the library to just the
# official list, so as to avoid unintentional ABI changes. On recent Darwin # official list, so as to avoid unintentional ABI changes. On recent Darwin
...@@ -320,13 +385,13 @@ endif ...@@ -320,13 +385,13 @@ endif
else # PORTNAME == aix else # PORTNAME == aix
# AIX case # AIX case
$(shlib) lib$(NAME).a: $(OBJS) $(shlib) $(stlib): $(OBJS)
$(LINK.static) lib$(NAME).a $^ $(LINK.static) $(stlib) $^
$(RANLIB) lib$(NAME).a $(RANLIB) $(stlib)
$(MKLDEXPORT) lib$(NAME).a >$(exports_file) $(MKLDEXPORT) $(stlib) >$(exports_file)
$(COMPILER) $(LDFLAGS_NO_L) $(LDFLAGS_SL) -o $(shlib) lib$(NAME).a -Wl,-bE:$(exports_file) $(SHLIB_LINK) $(COMPILER) $(LDFLAGS_NO_L) $(LDFLAGS_SL) -o $(shlib) $(stlib) -Wl,-bE:$(exports_file) $(SHLIB_LINK)
rm -f lib$(NAME).a rm -f $(stlib)
$(AR) $(AROPT) lib$(NAME).a $(shlib) $(AR) $(AROPT) $(stlib) $(shlib)
endif # PORTNAME == aix endif # PORTNAME == aix
...@@ -348,7 +413,7 @@ endif ...@@ -348,7 +413,7 @@ endif
$(shlib): $(OBJS) $(DLL_DEFFILE) $(shlib): $(OBJS) $(DLL_DEFFILE)
$(DLLWRAP) $(LDFLAGS_SL) -o $@ --dllname $(shlib) $(DLLWRAP_FLAGS) --def $(DLL_DEFFILE) $(OBJS) $(SHLIB_LINK) $(DLLWRAP) $(LDFLAGS_SL) -o $@ --dllname $(shlib) $(DLLWRAP_FLAGS) --def $(DLL_DEFFILE) $(OBJS) $(SHLIB_LINK)
lib$(NAME).a: $(shlib) $(DLL_DEFFILE) $(stlib): $(shlib) $(DLL_DEFFILE)
$(DLLTOOL) --dllname $(shlib) $(DLLTOOL_LIBFLAGS) --def $(DLL_DEFFILE) --output-lib $@ $(DLLTOOL) --dllname $(shlib) $(DLLTOOL_LIBFLAGS) --def $(DLL_DEFFILE) --output-lib $@
endif # PORTNAME == cygwin || PORTNAME == win32 endif # PORTNAME == cygwin || PORTNAME == win32
...@@ -394,18 +459,22 @@ endif # SHLIB_EXPORTS ...@@ -394,18 +459,22 @@ endif # SHLIB_EXPORTS
## INSTALL ## INSTALL
## ##
.PHONY: install-lib install-lib-static install-lib-shared .PHONY: install-lib install-lib-static install-lib-shared installdirs-lib
install-lib: install-lib-static install-lib-shared install-lib: install-lib-shared
ifdef soname
install-lib: install-lib-static
endif
install-lib-static: lib$(NAME).a install-lib-static: $(stlib) installdirs-lib
$(INSTALL_STLIB) $< '$(DESTDIR)$(libdir)/lib$(NAME).a' $(INSTALL_STLIB) $< '$(DESTDIR)$(libdir)/$(stlib)'
ifeq ($(PORTNAME), darwin) ifeq ($(PORTNAME), darwin)
cd '$(DESTDIR)$(libdir)' && \ cd '$(DESTDIR)$(libdir)' && \
ranlib lib$(NAME).a ranlib $(stlib)
endif endif
ifeq ($(enable_shared), yes) ifeq ($(enable_shared), yes)
install-lib-shared: $(shlib) install-lib-shared: $(shlib) installdirs-lib
ifdef soname
# we don't install $(shlib) on AIX # we don't install $(shlib) on AIX
ifneq ($(PORTNAME), aix) ifneq ($(PORTNAME), aix)
$(INSTALL_SHLIB) $< '$(DESTDIR)$(libdir)/$(shlib)' $(INSTALL_SHLIB) $< '$(DESTDIR)$(libdir)/$(shlib)'
...@@ -424,21 +493,43 @@ endif ...@@ -424,21 +493,43 @@ endif
endif # not win32 endif # not win32
endif # not cygwin endif # not cygwin
endif # not aix endif # not aix
else # no soname
$(INSTALL_SHLIB) $< '$(DESTDIR)$(pkglibdir)/$(shlib)'
endif
else # not enable_shared
ifndef soname
install-lib-shared:
@echo "*****"; \
echo "* Module $(NAME) was not installed due to lack of shared library support."; \
echo "*****"
endif
endif # enable_shared endif # enable_shared
installdirs-lib:
ifdef soname
$(mkinstalldirs) '$(DESTDIR)$(libdir)'
else
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
endif
## ##
## UNINSTALL ## UNINSTALL
## ##
.PHONY: uninstall-lib .PHONY: uninstall-lib
uninstall-lib: uninstall-lib:
rm -f '$(DESTDIR)$(libdir)/lib$(NAME).a' ifdef soname
rm -f '$(DESTDIR)$(libdir)/$(stlib)'
ifeq ($(enable_shared), yes) ifeq ($(enable_shared), yes)
rm -f '$(DESTDIR)$(libdir)/$(shlib_bare)' \ rm -f '$(DESTDIR)$(libdir)/$(shlib_bare)' \
'$(DESTDIR)$(libdir)/$(shlib_major)' \ '$(DESTDIR)$(libdir)/$(shlib_major)' \
'$(DESTDIR)$(libdir)/$(shlib)' '$(DESTDIR)$(libdir)/$(shlib)'
endif # enable_shared endif # enable_shared
else # no soname
rm -f '$(DESTDIR)$(pkglibdir)/$(shlib)'
endif # no soname
## ##
...@@ -447,10 +538,7 @@ endif # enable_shared ...@@ -447,10 +538,7 @@ endif # enable_shared
.PHONY: clean-lib .PHONY: clean-lib
clean-lib: clean-lib:
rm -f lib$(NAME).a rm -f $(shlib) $(shlib_bare) $(shlib_major) $(stlib) $(exports_file)
ifeq ($(enable_shared), yes)
rm -f $(shlib_bare) $(shlib_major) $(shlib) $(exports_file)
endif
ifneq (,$(SHLIB_EXPORTS)) ifneq (,$(SHLIB_EXPORTS))
maintainer-clean-lib: maintainer-clean-lib:
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
# #
# Makefile for src/backend/snowball # Makefile for src/backend/snowball
# #
# $PostgreSQL: pgsql/src/backend/snowball/Makefile,v 1.5 2008/03/18 16:24:50 petere Exp $ # $PostgreSQL: pgsql/src/backend/snowball/Makefile,v 1.6 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -77,11 +77,7 @@ else ...@@ -77,11 +77,7 @@ else
VPATH = $(srcdir)/libstemmer VPATH = $(srcdir)/libstemmer
endif endif
SHLIB_LINK := $(BE_DLLLIBS)
NAME := dict_snowball NAME := dict_snowball
SO_MAJOR_VERSION := 0
SO_MINOR_VERSION := 0
rpath = rpath =
all: all-shared-lib $(SQLSCRIPT) all: all-shared-lib $(SQLSCRIPT)
...@@ -116,10 +112,7 @@ else ...@@ -116,10 +112,7 @@ else
echo "-- No language-specific snowball dictionaries, for lack of shared library support" > $@ echo "-- No language-specific snowball dictionaries, for lack of shared library support" > $@
endif endif
install: all installdirs install: all installdirs install-lib
ifeq ($(enable_shared), yes)
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/$(NAME)$(DLSUFFIX)'
endif
$(INSTALL_DATA) $(SQLSCRIPT) '$(DESTDIR)$(datadir)' $(INSTALL_DATA) $(SQLSCRIPT) '$(DESTDIR)$(datadir)'
@set -e; \ @set -e; \
set $(LANGUAGES) ; \ set $(LANGUAGES) ; \
...@@ -131,11 +124,10 @@ endif ...@@ -131,11 +124,10 @@ endif
fi \ fi \
done done
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)' '$(DESTDIR)$(datadir)' '$(DESTDIR)$(datadir)/$(DICTDIR)' $(mkinstalldirs) '$(DESTDIR)$(datadir)' '$(DESTDIR)$(datadir)/$(DICTDIR)'
uninstall: uninstall: uninstall-lib
rm -f '$(DESTDIR)$(pkglibdir)/$(NAME)$(DLSUFFIX)'
rm -f '$(DESTDIR)$(datadir)/$(SQLSCRIPT)' rm -f '$(DESTDIR)$(datadir)/$(SQLSCRIPT)'
@set -e; \ @set -e; \
set $(LANGUAGES) ; \ set $(LANGUAGES) ; \
......
SRCS += $(NAME).c SRCS += $(NAME).c
OBJS += $(NAME).o OBJS += $(NAME).o
SHLIB_LINK := $(BE_DLLLIBS)
SO_MAJOR_VERSION := 0
SO_MINOR_VERSION := 0
rpath = rpath =
all: all-shared-lib all: all-shared-lib
include $(top_srcdir)/src/Makefile.shlib include $(top_srcdir)/src/Makefile.shlib
install: all installdirs install: all installdirs install-lib
ifeq ($(enable_shared), yes)
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/$(NAME)$(DLSUFFIX)'
endif
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
uninstall: uninstall: uninstall-lib
rm -f '$(DESTDIR)$(pkglibdir)/$(NAME)$(DLSUFFIX)'
clean distclean maintainer-clean: clean-lib clean distclean maintainer-clean: clean-lib
rm -f $(OBJS) rm -f $(OBJS)
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
# Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group # Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
# Portions Copyright (c) 1994, Regents of the University of California # Portions Copyright (c) 1994, Regents of the University of California
# #
# $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/Makefile,v 1.39 2008/02/26 06:41:23 petere Exp $ # $PostgreSQL: pgsql/src/interfaces/ecpg/compatlib/Makefile,v 1.40 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -16,7 +16,6 @@ include $(top_builddir)/src/Makefile.global ...@@ -16,7 +16,6 @@ include $(top_builddir)/src/Makefile.global
NAME= ecpg_compat NAME= ecpg_compat
SO_MAJOR_VERSION= 3 SO_MAJOR_VERSION= 3
SO_MINOR_VERSION= 1 SO_MINOR_VERSION= 1
DLTYPE= library
override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \ override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \
-I$(libpq_srcdir) -I$(top_srcdir)/src/include/utils $(CPPFLAGS) -I$(libpq_srcdir) -I$(top_srcdir)/src/include/utils $(CPPFLAGS)
...@@ -42,8 +41,7 @@ snprintf.c: % : $(top_srcdir)/src/port/% ...@@ -42,8 +41,7 @@ snprintf.c: % : $(top_srcdir)/src/port/%
install: all installdirs install-lib install: all installdirs install-lib
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(libdir)'
uninstall: uninstall-lib uninstall: uninstall-lib
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
# Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group # Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
# Portions Copyright (c) 1994, Regents of the University of California # Portions Copyright (c) 1994, Regents of the University of California
# #
# $PostgreSQL: pgsql/src/interfaces/ecpg/ecpglib/Makefile,v 1.58 2008/03/21 16:10:23 meskes Exp $ # $PostgreSQL: pgsql/src/interfaces/ecpg/ecpglib/Makefile,v 1.59 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -16,7 +16,6 @@ include $(top_builddir)/src/Makefile.global ...@@ -16,7 +16,6 @@ include $(top_builddir)/src/Makefile.global
NAME= ecpg NAME= ecpg
SO_MAJOR_VERSION= 6 SO_MAJOR_VERSION= 6
SO_MINOR_VERSION= 1 SO_MINOR_VERSION= 1
DLTYPE= library
override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \ override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \
-I$(libpq_srcdir) -I$(top_builddir)/src/port $(CPPFLAGS) -I$(libpq_srcdir) -I$(top_builddir)/src/port $(CPPFLAGS)
...@@ -63,8 +62,7 @@ $(top_builddir)/src/port/pg_config_paths.h: ...@@ -63,8 +62,7 @@ $(top_builddir)/src/port/pg_config_paths.h:
install: all installdirs install-lib install: all installdirs install-lib
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(libdir)'
uninstall: uninstall-lib uninstall: uninstall-lib
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
# Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group # Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
# Portions Copyright (c) 1994, Regents of the University of California # Portions Copyright (c) 1994, Regents of the University of California
# #
# $PostgreSQL: pgsql/src/interfaces/ecpg/pgtypeslib/Makefile,v 1.41 2008/02/26 06:41:24 petere Exp $ # $PostgreSQL: pgsql/src/interfaces/ecpg/pgtypeslib/Makefile,v 1.42 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -16,7 +16,6 @@ include $(top_builddir)/src/Makefile.global ...@@ -16,7 +16,6 @@ include $(top_builddir)/src/Makefile.global
NAME= pgtypes NAME= pgtypes
SO_MAJOR_VERSION= 3 SO_MAJOR_VERSION= 3
SO_MINOR_VERSION= 1 SO_MINOR_VERSION= 1
DLTYPE= library
override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \ override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \
-I$(top_srcdir)/src/include/utils -I$(libpq_srcdir) $(CPPFLAGS) -I$(top_srcdir)/src/include/utils -I$(libpq_srcdir) $(CPPFLAGS)
...@@ -48,8 +47,7 @@ pgstrcasecmp.c rint.c snprintf.c: % : $(top_srcdir)/src/port/% ...@@ -48,8 +47,7 @@ pgstrcasecmp.c rint.c snprintf.c: % : $(top_srcdir)/src/port/%
install: all installdirs install-lib install: all installdirs install-lib
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(libdir)'
uninstall: uninstall-lib uninstall: uninstall-lib
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
# Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group # Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
# Portions Copyright (c) 1994, Regents of the University of California # Portions Copyright (c) 1994, Regents of the University of California
# #
# $PostgreSQL: pgsql/src/interfaces/libpq/Makefile,v 1.164 2008/03/05 05:39:11 tgl Exp $ # $PostgreSQL: pgsql/src/interfaces/libpq/Makefile,v 1.165 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -18,7 +18,6 @@ include $(top_builddir)/src/Makefile.global ...@@ -18,7 +18,6 @@ include $(top_builddir)/src/Makefile.global
NAME= pq NAME= pq
SO_MAJOR_VERSION= 5 SO_MAJOR_VERSION= 5
SO_MINOR_VERSION= 2 SO_MINOR_VERSION= 2
DLTYPE= library
override CPPFLAGS := -DFRONTEND -I$(srcdir) $(CPPFLAGS) -I$(top_builddir)/src/port override CPPFLAGS := -DFRONTEND -I$(srcdir) $(CPPFLAGS) -I$(top_builddir)/src/port
ifneq ($(PORTNAME), win32) ifneq ($(PORTNAME), win32)
...@@ -111,8 +110,8 @@ install: all installdirs install-lib ...@@ -111,8 +110,8 @@ install: all installdirs install-lib
$(INSTALL_DATA) $(srcdir)/pqexpbuffer.h '$(DESTDIR)$(includedir_internal)' $(INSTALL_DATA) $(srcdir)/pqexpbuffer.h '$(DESTDIR)$(includedir_internal)'
$(INSTALL_DATA) $(srcdir)/pg_service.conf.sample '$(DESTDIR)$(datadir)/pg_service.conf.sample' $(INSTALL_DATA) $(srcdir)/pg_service.conf.sample '$(DESTDIR)$(datadir)/pg_service.conf.sample'
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(libdir)' '$(DESTDIR)$(includedir)' '$(DESTDIR)$(includedir_internal)' $(mkinstalldirs) '$(DESTDIR)$(includedir)' '$(DESTDIR)$(includedir_internal)'
uninstall: uninstall-lib uninstall: uninstall-lib
rm -f '$(DESTDIR)$(includedir)/libpq-fe.h' '$(DESTDIR)$(includedir_internal)/libpq-int.h' '$(DESTDIR)$(includedir_internal)/pqexpbuffer.h' '$(DESTDIR)$(datadir)/pg_service.conf.sample' rm -f '$(DESTDIR)$(includedir)/libpq-fe.h' '$(DESTDIR)$(includedir_internal)/libpq-int.h' '$(DESTDIR)$(includedir_internal)/pqexpbuffer.h' '$(DESTDIR)$(datadir)/pg_service.conf.sample'
......
# PGXS: PostgreSQL extensions makefile # PGXS: PostgreSQL extensions makefile
# $PostgreSQL: pgsql/src/makefiles/pgxs.mk,v 1.11 2007/10/16 15:59:59 tgl Exp $ # $PostgreSQL: pgsql/src/makefiles/pgxs.mk,v 1.12 2008/04/07 14:15:58 petere Exp $
# This file contains generic rules to build many kinds of simple # This file contains generic rules to build many kinds of simple
# extension modules. You only need to set a few variables and include # extension modules. You only need to set a few variables and include
...@@ -80,10 +80,6 @@ all: $(PROGRAM) $(DATA_built) $(SCRIPTS_built) $(addsuffix $(DLSUFFIX), $(MODULE ...@@ -80,10 +80,6 @@ all: $(PROGRAM) $(DATA_built) $(SCRIPTS_built) $(addsuffix $(DLSUFFIX), $(MODULE
ifdef MODULE_big ifdef MODULE_big
# shared library parameters # shared library parameters
NAME = $(MODULE_big) NAME = $(MODULE_big)
SO_MAJOR_VERSION= 0
SO_MINOR_VERSION= 0
SHLIB_LINK += $(BE_DLLLIBS)
include $(top_srcdir)/src/Makefile.shlib include $(top_srcdir)/src/Makefile.shlib
...@@ -121,9 +117,6 @@ endif # DOCS ...@@ -121,9 +117,6 @@ endif # DOCS
ifdef PROGRAM ifdef PROGRAM
$(INSTALL_PROGRAM) $(PROGRAM)$(X) '$(DESTDIR)$(bindir)' $(INSTALL_PROGRAM) $(PROGRAM)$(X) '$(DESTDIR)$(bindir)'
endif # PROGRAM endif # PROGRAM
ifdef MODULE_big
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/$(MODULE_big)$(DLSUFFIX)'
endif # MODULE_big
ifdef SCRIPTS ifdef SCRIPTS
@for file in $(addprefix $(srcdir)/, $(SCRIPTS)); do \ @for file in $(addprefix $(srcdir)/, $(SCRIPTS)); do \
echo "$(INSTALL_SCRIPT) $$file '$(DESTDIR)$(bindir)'"; \ echo "$(INSTALL_SCRIPT) $$file '$(DESTDIR)$(bindir)'"; \
...@@ -137,6 +130,10 @@ ifdef SCRIPTS_built ...@@ -137,6 +130,10 @@ ifdef SCRIPTS_built
done done
endif # SCRIPTS_built endif # SCRIPTS_built
ifdef MODULE_big
install: install-lib
endif # MODULE_big
installdirs: installdirs:
ifneq (,$(DATA)$(DATA_built)) ifneq (,$(DATA)$(DATA_built))
...@@ -145,7 +142,7 @@ endif ...@@ -145,7 +142,7 @@ endif
ifneq (,$(DATA_TSEARCH)) ifneq (,$(DATA_TSEARCH))
$(mkinstalldirs) '$(DESTDIR)$(datadir)/tsearch_data' $(mkinstalldirs) '$(DESTDIR)$(datadir)/tsearch_data'
endif endif
ifneq (,$(MODULES)$(MODULE_big)) ifneq (,$(MODULES))
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)' $(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
endif endif
ifdef DOCS ifdef DOCS
...@@ -157,6 +154,10 @@ ifneq (,$(PROGRAM)$(SCRIPTS)$(SCRIPTS_built)) ...@@ -157,6 +154,10 @@ ifneq (,$(PROGRAM)$(SCRIPTS)$(SCRIPTS_built))
$(mkinstalldirs) '$(DESTDIR)$(bindir)' $(mkinstalldirs) '$(DESTDIR)$(bindir)'
endif endif
ifdef MODULE_big
installdirs: installdirs-lib
endif # MODULE_big
uninstall: uninstall:
ifneq (,$(DATA)$(DATA_built)) ifneq (,$(DATA)$(DATA_built))
...@@ -174,9 +175,6 @@ endif ...@@ -174,9 +175,6 @@ endif
ifdef PROGRAM ifdef PROGRAM
rm -f '$(DESTDIR)$(bindir)/$(PROGRAM)$(X)' rm -f '$(DESTDIR)$(bindir)/$(PROGRAM)$(X)'
endif endif
ifdef MODULE_big
rm -f '$(DESTDIR)$(pkglibdir)/$(MODULE_big)$(DLSUFFIX)'
endif
ifdef SCRIPTS ifdef SCRIPTS
rm -f $(addprefix '$(DESTDIR)$(bindir)'/, $(SCRIPTS)) rm -f $(addprefix '$(DESTDIR)$(bindir)'/, $(SCRIPTS))
endif endif
...@@ -184,6 +182,10 @@ ifdef SCRIPTS_built ...@@ -184,6 +182,10 @@ ifdef SCRIPTS_built
rm -f $(addprefix '$(DESTDIR)$(bindir)'/, $(SCRIPTS_built)) rm -f $(addprefix '$(DESTDIR)$(bindir)'/, $(SCRIPTS_built))
endif endif
ifdef MODULE_big
uninstall: uninstall-lib
endif # MODULE_big
clean: clean:
ifdef MODULES ifdef MODULES
......
# Makefile for PL/Perl # Makefile for PL/Perl
# $PostgreSQL: pgsql/src/pl/plperl/GNUmakefile,v 1.33 2007/12/01 15:30:09 adunstan Exp $ # $PostgreSQL: pgsql/src/pl/plperl/GNUmakefile,v 1.34 2008/04/07 14:15:58 petere Exp $
subdir = src/pl/plperl subdir = src/pl/plperl
top_builddir = ../../.. top_builddir = ../../..
...@@ -32,12 +32,10 @@ rpathdir = $(perl_archlibexp)/CORE ...@@ -32,12 +32,10 @@ rpathdir = $(perl_archlibexp)/CORE
NAME = plperl NAME = plperl
SO_MAJOR_VERSION = 0
SO_MINOR_VERSION = 0
OBJS = plperl.o spi_internal.o SPI.o OBJS = plperl.o spi_internal.o SPI.o
SHLIB_LINK = $(perl_embed_ldflags) $(BE_DLLLIBS) SHLIB_LINK = $(perl_embed_ldflags)
REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-language=plperl REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-language=plperl
REGRESS = plperl plperl_trigger plperl_shared plperl_elog REGRESS = plperl plperl_trigger plperl_shared plperl_elog
...@@ -73,20 +71,11 @@ $(test_files_build): $(abs_builddir)/%: $(srcdir)/% ...@@ -73,20 +71,11 @@ $(test_files_build): $(abs_builddir)/%: $(srcdir)/%
endif endif
install: all installdirs install: all installdirs install-lib
ifeq ($(enable_shared), yes)
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/plperl$(DLSUFFIX)'
else
@echo "*****"; \
echo "* PL/Perl was not installed due to lack of shared library support."; \
echo "*****"
endif
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
uninstall: uninstall: uninstall-lib
rm -f '$(DESTDIR)$(pkglibdir)/plperl$(DLSUFFIX)'
installcheck: submake installcheck: submake
$(top_builddir)/src/test/regress/pg_regress --psqldir=$(PSQLDIR) $(REGRESS_OPTS) $(REGRESS) $(top_builddir)/src/test/regress/pg_regress --psqldir=$(PSQLDIR) $(REGRESS_OPTS) $(REGRESS)
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
# #
# Makefile for the plpgsql shared object # Makefile for the plpgsql shared object
# #
# $PostgreSQL: pgsql/src/pl/plpgsql/src/Makefile,v 1.31 2007/07/15 22:18:24 tgl Exp $ # $PostgreSQL: pgsql/src/pl/plpgsql/src/Makefile,v 1.32 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -12,11 +12,9 @@ include $(top_builddir)/src/Makefile.global ...@@ -12,11 +12,9 @@ include $(top_builddir)/src/Makefile.global
# Shared library parameters # Shared library parameters
NAME= plpgsql NAME= plpgsql
SO_MAJOR_VERSION= 1
SO_MINOR_VERSION= 0
override CPPFLAGS := -I$(srcdir) $(CPPFLAGS) override CPPFLAGS := -I$(srcdir) $(CPPFLAGS)
SHLIB_LINK = $(filter -lintl, $(LIBS)) $(BE_DLLLIBS) SHLIB_LINK = $(filter -lintl, $(LIBS))
rpath = rpath =
OBJS = pl_gram.o pl_handler.o pl_comp.o pl_exec.o pl_funcs.o OBJS = pl_gram.o pl_handler.o pl_comp.o pl_exec.o pl_funcs.o
...@@ -27,26 +25,12 @@ all: all-lib ...@@ -27,26 +25,12 @@ all: all-lib
include $(top_srcdir)/src/Makefile.shlib include $(top_srcdir)/src/Makefile.shlib
# In order to use Makefile.shlib, we allow it to build a static install: installdirs all install-lib
# library libplpgsql.a, which we just ignore, as well as a shared
# library that it will insist on naming $(shlib). We don't want to
# call it that when installed, however, so we ignore the install-shlib
# rule and do this instead:
install: installdirs all installdirs: installdirs-lib
ifeq ($(enable_shared), yes)
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/plpgsql$(DLSUFFIX)'
else
@echo "*****"; \
echo "* PL/pgSQL was not installed due to lack of shared library support."; \
echo "*****"
endif
installdirs: uninstall: uninstall-lib
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
uninstall:
rm -f '$(DESTDIR)$(pkglibdir)/plpgsql$(DLSUFFIX)'
# Force these dependencies to be known even without dependency info built: # Force these dependencies to be known even without dependency info built:
pl_gram.o pl_handler.o pl_comp.o pl_exec.o pl_funcs.o: plpgsql.h $(srcdir)/pl.tab.h pl_gram.o pl_handler.o pl_comp.o pl_exec.o pl_funcs.o: plpgsql.h $(srcdir)/pl.tab.h
......
# $PostgreSQL: pgsql/src/pl/plpython/Makefile,v 1.28 2007/02/10 04:26:24 tgl Exp $ # $PostgreSQL: pgsql/src/pl/plpython/Makefile,v 1.29 2008/04/07 14:15:58 petere Exp $
subdir = src/pl/plpython subdir = src/pl/plpython
top_builddir = ../../.. top_builddir = ../../..
...@@ -37,8 +37,6 @@ override CPPFLAGS := -I$(srcdir) $(python_includespec) $(CPPFLAGS) ...@@ -37,8 +37,6 @@ override CPPFLAGS := -I$(srcdir) $(python_includespec) $(CPPFLAGS)
rpathdir = $(python_libdir) rpathdir = $(python_libdir)
NAME = plpython NAME = plpython
SO_MAJOR_VERSION = 0
SO_MINOR_VERSION = 0
OBJS = plpython.o OBJS = plpython.o
...@@ -56,7 +54,7 @@ python${pytverstr}.def: $(WD)/system32/python${pytverstr}.dll ...@@ -56,7 +54,7 @@ python${pytverstr}.def: $(WD)/system32/python${pytverstr}.dll
endif endif
SHLIB_LINK = $(BE_DLLLIBS) $(python_libspec) $(python_additional_libs) SHLIB_LINK = $(python_libspec) $(python_additional_libs)
REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-language=plpythonu REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-language=plpythonu
REGRESS = plpython_schema plpython_populate plpython_function plpython_test plpython_error plpython_drop REGRESS = plpython_schema plpython_populate plpython_function plpython_test plpython_error plpython_drop
...@@ -89,20 +87,11 @@ $(test_files_build): $(abs_builddir)/%: $(srcdir)/% ...@@ -89,20 +87,11 @@ $(test_files_build): $(abs_builddir)/%: $(srcdir)/%
endif endif
install: all installdirs install: all installdirs install-lib
ifeq ($(enable_shared), yes)
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/plpython$(DLSUFFIX)'
else
@echo "*****"; \
echo "* PL/Python was not installed due to lack of shared library support."; \
echo "*****"
endif
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
uninstall: uninstall: uninstall-lib
rm -f '$(DESTDIR)$(pkglibdir)/plpython$(DLSUFFIX)'
installcheck: submake installcheck: submake
$(top_builddir)/src/test/regress/pg_regress --psqldir=$(PSQLDIR) $(REGRESS_OPTS) $(REGRESS) $(top_builddir)/src/test/regress/pg_regress --psqldir=$(PSQLDIR) $(REGRESS_OPTS) $(REGRESS)
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
# #
# Makefile for the pltcl shared object # Makefile for the pltcl shared object
# #
# $PostgreSQL: pgsql/src/pl/tcl/Makefile,v 1.50 2006/07/21 00:24:04 tgl Exp $ # $PostgreSQL: pgsql/src/pl/tcl/Makefile,v 1.51 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -29,15 +29,12 @@ endif ...@@ -29,15 +29,12 @@ endif
endif endif
SHLIB_LINK = $(TCL_LIB_SPEC)
ifneq ($(PORTNAME), win32) ifneq ($(PORTNAME), win32)
SHLIB_LINK = $(BE_DLLLIBS) $(TCL_LIB_SPEC) $(TCL_LIBS) -lc SHLIB_LINK += $(TCL_LIBS) -lc
else
SHLIB_LINK = $(TCL_LIB_SPEC) $(BE_DLLLIBS)
endif endif
NAME = pltcl NAME = pltcl
SO_MAJOR_VERSION = 2
SO_MINOR_VERSION = 0
OBJS = pltcl.o OBJS = pltcl.o
REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-language=pltcl REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-language=pltcl
...@@ -73,22 +70,13 @@ $(test_files_build): $(abs_builddir)/%: $(srcdir)/% ...@@ -73,22 +70,13 @@ $(test_files_build): $(abs_builddir)/%: $(srcdir)/%
endif endif
install: all installdirs install: all installdirs install-lib
ifeq ($(enable_shared), yes)
$(INSTALL_SHLIB) $(shlib) '$(DESTDIR)$(pkglibdir)/$(NAME)$(DLSUFFIX)'
else
@echo "*****"; \
echo "* PL/Tcl was not installed due to lack of shared library support."; \
echo "*****"
endif
$(MAKE) -C modules $@ $(MAKE) -C modules $@
installdirs: installdirs: installdirs-lib
$(mkinstalldirs) '$(DESTDIR)$(pkglibdir)'
$(MAKE) -C modules $@ $(MAKE) -C modules $@
uninstall: uninstall: uninstall-lib
rm -f '$(DESTDIR)$(pkglibdir)/$(NAME)$(DLSUFFIX)'
$(MAKE) -C modules $@ $(MAKE) -C modules $@
installcheck: submake installcheck: submake
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
# Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group # Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
# Portions Copyright (c) 1994, Regents of the University of California # Portions Copyright (c) 1994, Regents of the University of California
# #
# $PostgreSQL: pgsql/src/test/regress/GNUmakefile,v 1.72 2008/03/18 16:24:50 petere Exp $ # $PostgreSQL: pgsql/src/test/regress/GNUmakefile,v 1.73 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -77,18 +77,11 @@ uninstall: ...@@ -77,18 +77,11 @@ uninstall:
# Build dynamically-loaded object file for CREATE FUNCTION ... LANGUAGE C. # Build dynamically-loaded object file for CREATE FUNCTION ... LANGUAGE C.
NAME = regress NAME = regress
SO_MAJOR_VERSION= 0
SO_MINOR_VERSION= 0
OBJS = regress.o OBJS = regress.o
SHLIB_LINK = $(BE_DLLLIBS)
include $(top_srcdir)/src/Makefile.shlib include $(top_srcdir)/src/Makefile.shlib
all: $(NAME)$(DLSUFFIX) all: all-lib
$(NAME)$(DLSUFFIX): $(shlib)
rm -f $(NAME)$(DLSUFFIX)
$(LN_S) $(shlib) $(NAME)$(DLSUFFIX)
# Test input and expected files. These are created by pg_regress itself, so we # Test input and expected files. These are created by pg_regress itself, so we
# don't have a rule to create them. We do need rules to clean them however. # don't have a rule to create them. We do need rules to clean them however.
...@@ -169,7 +162,7 @@ bigcheck: all ...@@ -169,7 +162,7 @@ bigcheck: all
clean distclean maintainer-clean: clean-lib clean distclean maintainer-clean: clean-lib
# things built by `all' target # things built by `all' target
rm -f $(NAME)$(DLSUFFIX) $(OBJS) rm -f $(OBJS)
$(MAKE) -C $(contribdir)/spi clean $(MAKE) -C $(contribdir)/spi clean
rm -f $(output_files) $(input_files) pg_regress_main.o pg_regress.o pg_regress$(X) rm -f $(output_files) $(input_files) pg_regress_main.o pg_regress.o pg_regress$(X)
# things created by various check targets # things created by various check targets
......
...@@ -9,15 +9,13 @@ ...@@ -9,15 +9,13 @@
# to build using the surrounding source tree. # to build using the surrounding source tree.
# #
# IDENTIFICATION # IDENTIFICATION
# $PostgreSQL: pgsql/src/tutorial/Makefile,v 1.20 2007/06/26 22:05:04 tgl Exp $ # $PostgreSQL: pgsql/src/tutorial/Makefile,v 1.21 2008/04/07 14:15:58 petere Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
MODULES = complex funcs MODULES = complex funcs
DATA_built = advanced.sql basics.sql complex.sql funcs.sql syscat.sql DATA_built = advanced.sql basics.sql complex.sql funcs.sql syscat.sql
SHLIB_LINK = $(BE_DLLLIBS)
ifdef NO_PGXS ifdef NO_PGXS
subdir = src/tutorial subdir = src/tutorial
top_builddir = ../.. top_builddir = ../..
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment