From 2eb9ccd68d68b0cbbdb68ba628a501c2ef62a84a Mon Sep 17 00:00:00 2001 From: Dana Robinson <43805+derobins@users.noreply.github.com> Date: Sun, 20 Oct 2024 12:47:52 -0700 Subject: [PATCH] Remove some Solaris Studio work-arounds (#4979) Solaris Studio hasn't been updated in almost a decade and the last version (12.4, circa 2015) doesn't seem to fully support C11. This PR removes some work-arounds for things like __attribute__() support. --- bin/genparser | 2 -- config/cmake/ConfigureChecks.cmake | 5 ----- hl/src/H5LTanalyze.c | 2 -- hl/src/H5LTparse.c | 2 -- release_docs/RELEASE.txt | 6 ++++++ src/H5private.h | 5 +---- tools/test/perform/chunk.c | 3 +-- tools/test/perform/overhead.c | 3 +-- 8 files changed, 9 insertions(+), 19 deletions(-) diff --git a/bin/genparser b/bin/genparser index cb200619fa5..be2b9e24bd4 100755 --- a/bin/genparser +++ b/bin/genparser @@ -250,8 +250,6 @@ do echo '#if ((__GNUC__ * 100) + __GNUC_MINOR__) >= 600 ' >> tmp.out echo '#pragma GCC diagnostic ignored "-Wnull-dereference" ' >> tmp.out echo '#endif ' >> tmp.out - echo '#elif defined __SUNPRO_CC ' >> tmp.out - echo '#pragma disable_warn ' >> tmp.out echo '#elif defined _MSC_VER ' >> tmp.out echo '#pragma warning(push, 1) ' >> tmp.out echo '#endif ' >> tmp.out diff --git a/config/cmake/ConfigureChecks.cmake b/config/cmake/ConfigureChecks.cmake index 5f8f7514b0a..df6c760f0cc 100644 --- a/config/cmake/ConfigureChecks.cmake +++ b/config/cmake/ConfigureChecks.cmake @@ -29,11 +29,6 @@ if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin") set (${HDF_PREFIX}_HAVE_DARWIN 1) endif () -# Check for Solaris -if (${CMAKE_SYSTEM_NAME} MATCHES "SunOS") - set (${HDF_PREFIX}_HAVE_SOLARIS 1) -endif () - #----------------------------------------------------------------------------- # This MACRO checks IF the symbol exists in the library and IF it # does, it appends library to the list. diff --git a/hl/src/H5LTanalyze.c b/hl/src/H5LTanalyze.c index 67fa8457382..1b7355b130f 100644 --- a/hl/src/H5LTanalyze.c +++ b/hl/src/H5LTanalyze.c @@ -24,8 +24,6 @@ #if ((__GNUC__ * 100) + __GNUC_MINOR__) >= 600 #pragma GCC diagnostic ignored "-Wnull-dereference" #endif -#elif defined __SUNPRO_CC -#pragma disable_warn #elif defined _MSC_VER #pragma warning(push, 1) #endif diff --git a/hl/src/H5LTparse.c b/hl/src/H5LTparse.c index bb7137630a5..46c3ae79b72 100644 --- a/hl/src/H5LTparse.c +++ b/hl/src/H5LTparse.c @@ -24,8 +24,6 @@ #if ((__GNUC__ * 100) + __GNUC_MINOR__) >= 600 #pragma GCC diagnostic ignored "-Wnull-dereference" #endif -#elif defined __SUNPRO_CC -#pragma disable_warn #elif defined _MSC_VER #pragma warning(push, 1) #endif diff --git a/release_docs/RELEASE.txt b/release_docs/RELEASE.txt index ee12538b818..9125b8b4455 100644 --- a/release_docs/RELEASE.txt +++ b/release_docs/RELEASE.txt @@ -62,6 +62,12 @@ New Features The following API routines support concurrent multithreaded operation: + - Dropped some old Solaris Studio work-arounds + + Solaris Studio no longer seems to be maintained and the last version + (12.4, circa 2015) doesn't seem to fully support C11. We've removed + some hacks that work around things like __attribute__() support. + - Dropped support for the traditional MSVC preprocessor Visual Studio has recently started using a standards-compliant diff --git a/src/H5private.h b/src/H5private.h index 03b10c2e426..cc9f2323de1 100644 --- a/src/H5private.h +++ b/src/H5private.h @@ -187,9 +187,6 @@ * Does the compiler support the __attribute__(()) syntax? It's no * big deal if we don't. * - * Note that Solaris Studio supports attribute, but does not support the - * attributes we use. - * * When using H5_ATTR_FALLTHROUGH, you should also include a comment that * says FALLTHROUGH to reduce warnings on compilers that don't use * attributes but do respect fall-through comments. @@ -199,7 +196,7 @@ * file). Be sure to update that file if the #ifdefs change here. */ /* clang-format off */ -#if defined(H5_HAVE_ATTRIBUTE) && !defined(__SUNPRO_C) +#if defined(H5_HAVE_ATTRIBUTE) # define H5_ATTR_FORMAT(X, Y, Z) __attribute__((format(X, Y, Z))) # define H5_ATTR_UNUSED __attribute__((unused)) diff --git a/tools/test/perform/chunk.c b/tools/test/perform/chunk.c index 66450b875bb..4db2086fa7a 100644 --- a/tools/test/perform/chunk.c +++ b/tools/test/perform/chunk.c @@ -24,8 +24,7 @@ #include #include -/* Solaris Studio defines attribute, but for the attributes we need */ -#if !defined(H5_HAVE_ATTRIBUTE) || defined __cplusplus || defined(__SUNPRO_C) +#if !defined(H5_HAVE_ATTRIBUTE) || defined __cplusplus #undef __attribute__ #define __attribute__(X) /*void*/ #define H5_ATTR_UNUSED /*void*/ diff --git a/tools/test/perform/overhead.c b/tools/test/perform/overhead.c index e301bbfb737..4dd8da9293e 100644 --- a/tools/test/perform/overhead.c +++ b/tools/test/perform/overhead.c @@ -30,8 +30,7 @@ #include #endif -/* Solaris Studio defines attribute, but for the attributes we need */ -#if !defined(H5_HAVE_ATTRIBUTE) || defined __cplusplus || defined(__SUNPRO_C) +#if !defined(H5_HAVE_ATTRIBUTE) || defined __cplusplus #undef __attribute__ #define __attribute__(X) /*void*/ #define H5_ATTR_UNUSED /*void*/