From b964c0958e9f4f1878537b867fb3aecc7c86e708 Mon Sep 17 00:00:00 2001 From: Chris Jones Date: Sun, 25 Apr 2021 15:46:22 +0100 Subject: [PATCH] Add additional dynamic library that includes the legacy symbols but in addition re-exports libSystem.B --- Makefile | 40 ++++++++++++++++++++++++++++++++++------ README.md | 8 +++++++- 2 files changed, 41 insertions(+), 7 deletions(-) diff --git a/Makefile b/Makefile index 2d8da8c..60bb358 100644 --- a/Makefile +++ b/Makefile @@ -22,20 +22,33 @@ LIBDIR = $(PREFIX)/lib AREXT = .a SOEXT = .dylib LIBNAME = MacportsLegacySupport +SYSLIBNAME = MacportsLegacySystem.B DLIBFILE = lib$(LIBNAME)$(SOEXT) SLIBFILE = lib$(LIBNAME)$(AREXT) +SYSLIBFILE = lib$(SYSLIBNAME)$(SOEXT) DLIBPATH = $(LIBDIR)/$(DLIBFILE) SLIBPATH = $(LIBDIR)/$(SLIBFILE) +SYSLIBPATH = $(LIBDIR)/$(SYSLIBFILE) BUILDDLIBDIR = lib BUILDSLIBDIR = lib BUILDDLIBPATH = $(BUILDDLIBDIR)/$(DLIBFILE) BUILDSLIBPATH = $(BUILDSLIBDIR)/$(SLIBFILE) +BUILDSYSLIBPATH = $(BUILDDLIBDIR)/$(SYSLIBFILE) +SOCURVERSION ?= 1.0 +SOCOMPATVERSION ?= 1.0 BUILDDLIBFLAGS = -dynamiclib -headerpad_max_install_names \ -install_name @executable_path/../$(BUILDDLIBPATH) \ - -current_version 1.0 -compatibility_version 1.0 + -current_version $(SOCURVERSION) \ + -compatibility_version $(SOCOMPATVERSION) +BUILDSYSLIBFLAGS = -dynamiclib -headerpad_max_install_names \ + -install_name @executable_path/../$(BUILDSYSLIBPATH) \ + -current_version $(SOCURVERSION) \ + -compatibility_version $(SOCOMPATVERSION) +SYSREEXPORTFLAG = -Wl,-reexport_library /usr/lib/libSystem.B.dylib BUILDSLIBFLAGS = -qs POSTINSTALL = install_name_tool -POSTINSTALLFLAGS = -id $(DLIBPATH) + +MAX_DARWIN_REEXPORT ?= 19 FORCE_ARCH ?= ARCHFLAGS ?= @@ -193,9 +206,10 @@ define splitandfilterandmergemultiarch fi endef -all: dlib slib +all: dlib slib syslib dlib: $(BUILDDLIBPATH) slib: $(BUILDSLIBPATH) +syslib: $(BUILDSYSLIBPATH) # Special rules for special implementations. # For instance, functions using struct stat need to be implemented multiple @@ -236,6 +250,13 @@ $(BUILDDLIBPATH): $(DLIBOBJS) $(MULTIDLIBOBJS) $(MKINSTALLDIRS) $(BUILDDLIBDIR) $(CC) $(BUILDDLIBFLAGS) $(LDFLAGS) $^ -o $@ +# Wrapped libSystem relies on reexport which does not work on Darwin20+ +$(BUILDSYSLIBPATH): $(DLIBOBJS) $(MULTIDLIBOBJS) +ifeq ($(shell test $(PLATFORM) -le $(MAX_DARWIN_REEXPORT); echo $$?),0) + $(MKINSTALLDIRS) $(BUILDDLIBDIR) + $(CC) $(BUILDSYSLIBFLAGS) $(LDFLAGS) $(SYSREEXPORTFLAG) $^ -o $@ +endif + $(BUILDSLIBPATH): $(SLIBOBJS) $(MULTISLIBOBJS) $(MKINSTALLDIRS) $(BUILDSLIBDIR) $(RM) $@ @@ -281,12 +302,19 @@ install-headers: $(INSTALL_DATA) $(SRCINCDIR)/"$$h" $(DESTDIR)$(PKGINCDIR)/"$$h"; \ done -install-lib: install-dlib install-slib +install-lib: install-dlib install-slib install-syslib install-dlib: $(BUILDDLIBPATH) $(MKINSTALLDIRS) $(DESTDIR)$(LIBDIR) $(INSTALL_PROGRAM) $(BUILDDLIBPATH) $(DESTDIR)$(LIBDIR) - $(POSTINSTALL) $(POSTINSTALLFLAGS) $(DESTDIR)$(DLIBPATH) + $(POSTINSTALL) -id $(DLIBPATH) $(DESTDIR)$(DLIBPATH) + +install-syslib: $(BUILDSYSLIBPATH) +ifeq ($(shell test $(PLATFORM) -le $(MAX_DARWIN_REEXPORT); echo $$?),0) + $(MKINSTALLDIRS) $(DESTDIR)$(LIBDIR) + $(INSTALL_PROGRAM) $(BUILDSYSLIBPATH) $(DESTDIR)$(LIBDIR) + $(POSTINSTALL) -id $(SYSLIBPATH) $(DESTDIR)$(SYSLIBPATH) +endif install-slib: $(BUILDSLIBPATH) $(MKINSTALLDIRS) $(DESTDIR)$(LIBDIR) @@ -296,7 +324,7 @@ test check: $(TESTRUNS) test_cmath clean: $(RM) $(foreach D,$(SRCDIR) $(TESTDIR),$D/*.o $D/*.o.* $D/*.d) - $(RM) $(BUILDDLIBPATH) $(BUILDSLIBPATH) $(TESTPRGS) test/test_cmath_* + $(RM) $(BUILDDLIBPATH) $(BUILDSLIBPATH) $(BUILDSYSLIBPATH) $(TESTPRGS) test/test_cmath_* @$(RMDIR) $(BUILDDLIBDIR) $(BUILDSLIBDIR) .PHONY: all dlib slib clean check test $(TESTRUNS) test_cmath diff --git a/README.md b/README.md index 2ff47b9..92d7b6c 100644 --- a/README.md +++ b/README.md @@ -1,9 +1,15 @@ # MacPorts Support for Legacy OSX Versions -Installs wrapper headers and a library of functions that add common +Installs wrapper headers and library functions that add common functions missing in various older OSX releases to bring them approximately up to current expected standards. +Three different libraries are provided + + - libMacportsLegacySupport.a - A static library with the missing functions for the given OS. + - libMacportsLegacySupport.dylib - A dynamic library with the missing functions for the given OS. + - libMacportsLegacySystem.B.dylib - Similar to libMacportsLegacySupport.dylib but in addition re-exports the symbols from libSystem.B.dylib. + To use this library within [MacPorts](https://github.com/macports) add the `legacysupport` PortGroup to the Portfile. This will add the required include paths and libraries to allow the library to do it's