From: Iain Buclaw Date: Tue, 19 Feb 2019 12:38:48 +0000 (+0000) Subject: Fix libphobos.shared/load.d compile failure on Solaris X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=be200c5c41cd17948aca4932fe96aeae268c99fc;p=gcc.git Fix libphobos.shared/load.d compile failure on Solaris 2019-02-19 Iain Buclaw * testsuite/libphobos.shared/load.d: Import core.sys.posix.dlfcn. [DragonFlyBSD, FreeBSD, linux, NetBSD, OSX, Solaris]: Import only RTLD_NOLOAD from core.sys.*.dlfcn. Assert RTLD_NOLOAD is available. From-SVN: r269014 --- diff --git a/libphobos/ChangeLog b/libphobos/ChangeLog index 5279c891e55..16514ff650f 100644 --- a/libphobos/ChangeLog +++ b/libphobos/ChangeLog @@ -1,3 +1,10 @@ +2019-02-19 Iain Buclaw + + * testsuite/libphobos.shared/load.d: Import core.sys.posix.dlfcn. + [DragonFlyBSD, FreeBSD, linux, NetBSD, OSX, Solaris]: Import only + RTLD_NOLOAD from core.sys.*.dlfcn. + Assert RTLD_NOLOAD is available. + 2019-02-19 Rainer Orth * m4/druntime/libraries.m4 (DRUNTIME_LIBRARIES_NET): New macro. diff --git a/libphobos/testsuite/libphobos.shared/load.d b/libphobos/testsuite/libphobos.shared/load.d index 8c13f51eac6..5a2dd01b778 100644 --- a/libphobos/testsuite/libphobos.shared/load.d +++ b/libphobos/testsuite/libphobos.shared/load.d @@ -3,10 +3,16 @@ import core.stdc.stdio; import core.stdc.string; import core.thread; -version (linux) import core.sys.linux.dlfcn; -else version (FreeBSD) import core.sys.freebsd.dlfcn; -else version (NetBSD) import core.sys.netbsd.dlfcn; -else static assert(0, "unimplemented"); +import core.sys.posix.dlfcn; + +version (DragonFlyBSD) import core.sys.dragonflybsd.dlfcn : RTLD_NOLOAD; +version (FreeBSD) import core.sys.freebsd.dlfcn : RTLD_NOLOAD; +version (linux) import core.sys.linux.dlfcn : RTLD_NOLOAD; +version (NetBSD) import core.sys.netbsd.dlfcn : RTLD_NOLOAD; +version (OSX) import core.sys.darwin.dlfcn : RTLD_NOLOAD; +version (Solaris) import core.sys.solaris.dlfcn : RTLD_NOLOAD; + +static assert(__traits(compiles, RTLD_NOLOAD), "unimplemented"); void loadSym(T)(void* handle, ref T val, const char* mangle) {