Removes support for pre-2015 Visual Studio (#496)

* Committing clang-format changes

* Removes work-around code for pre-2015 Visual Studio

HDF5 no longer provides an implementation for:

* <inttypes.h>
* snprintf and vsnprintf
* llround(f), lround(f), round(f)
* strtoll and strtoull
* va_copy
* struct timespec

Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com>
This commit is contained in:
Dana Robinson 2021-03-23 19:13:57 -07:00 committed by GitHub
parent 69f3cde936
commit 1f3f7fe3ae
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 21 additions and 180 deletions

View File

@ -49,6 +49,20 @@ New Features
Configuration: Configuration:
------------- -------------
- Removal of pre-VS2015 work-arounds
HDF5 now requires Visual Studio 2015 or greater, so old work-around
code and definitions have been removed, including:
* <inttypes.h>
* snprintf and vsnprintf
* llround, llroundf, lround, lroundf, round, roundf
* strtoll and strtoull
* va_copy
* struct timespec
(DER - 2021/03/22)
- On macOS, Universal Binaries can now be built, allowing native execution on - On macOS, Universal Binaries can now be built, allowing native execution on
both Intel and Apple Silicon (ARM) based Macs. both Intel and Apple Silicon (ARM) based Macs.

View File

@ -581,32 +581,6 @@ Wgetlogin(void)
return NULL; return NULL;
} }
int
c99_snprintf(char *str, size_t size, const char *format, ...)
{
int count;
va_list ap;
HDva_start(ap, format);
count = c99_vsnprintf(str, size, format, ap);
HDva_end(ap);
return count;
}
int
c99_vsnprintf(char *str, size_t size, const char *format, va_list ap)
{
int count = -1;
if (size != 0)
count = _vsnprintf_s(str, size, _TRUNCATE, format, ap);
if (count == -1)
count = _vscprintf(format, ap);
return count;
}
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* Function: Wflock * Function: Wflock
* *
@ -658,55 +632,6 @@ Wflock(int fd, int operation)
return 0; return 0;
} /* end Wflock() */ } /* end Wflock() */
/*-------------------------------------------------------------------------
* Function: Wllround, Wllroundf, Wlround, Wlroundf, Wround, Wroundf
*
* Purpose: Wrapper function for round functions for use with VS2012
* and earlier.
*
* Return: The rounded value that was passed in.
*
* Programmer: Dana Robinson
* December 2016
*
*-------------------------------------------------------------------------
*/
long long
Wllround(double arg)
{
return (long long)(arg < 0.0 ? HDceil(arg - 0.5) : HDfloor(arg + 0.5));
}
long long
Wllroundf(float arg)
{
return (long long)(arg < 0.0F ? HDceil(arg - 0.5F) : HDfloor(arg + 0.5F));
}
long
Wlround(double arg)
{
return (long)(arg < 0.0 ? HDceil(arg - 0.5) : HDfloor(arg + 0.5));
}
long
Wlroundf(float arg)
{
return (long)(arg < 0.0F ? HDceil(arg - 0.5F) : HDfloor(arg + 0.5F));
}
double
Wround(double arg)
{
return arg < 0.0 ? HDceil(arg - 0.5) : HDfloor(arg + 0.5);
}
float
Wroundf(float arg)
{
return (float)(arg < 0.0F ? HDceil(arg - 0.5F) : HDfloor(arg + 0.5F));
}
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* Function: H5_get_utf16_str * Function: H5_get_utf16_str
* *

View File

@ -11,66 +11,18 @@
* help@hdfgroup.org. * * help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/* Programmer: Scott Wegner /* Purpose: This file is used to map HDF macros to Windows functions. This
* June 3, 2008
*
* Purpose: This file is used to map HDF macros to Windows functions. This
* should get included H5private mappings, so as to override them. * should get included H5private mappings, so as to override them.
* Any macro not mapped here, however, will receive a similar mapping * Any macro not mapped here, however, will receive a similar mapping
* inside H5private.h * inside H5private.h
* *
*/ */
#ifndef H5_HAVE_INTTYPES_H
/* The following definitions should be suitable for 64-bit Windows, which is
* LLP64, and for 32-bit Windows, which is ILP32. Those are the only
* platforms where <inttypes.h> is likely to be missing. VS2015 and later
* *may* provide these definitions.
*/
#ifdef _WIN64
#define PRIdPTR "lld"
#define PRIoPTR "llo"
#define PRIuPTR "llu"
#define PRIxPTR "llx"
#define PRIXPTR "llX"
#else /* _WIN64 */
#define PRIdPTR "ld"
#define PRIoPTR "lo"
#define PRIuPTR "lu"
#define PRIxPTR "lx"
#define PRIXPTR "lX"
#endif /* _WIN64 */
#define PRId8 "d" /* _MSC_VER = 192x VS2019
#define PRIo8 "o" * _MSC_VER = 191x VS2017
#define PRIu8 "u" * _MSC_VER = 1900 VS2015
#define PRIx8 "x" * _MSC_VER = 1800 VS2013
#define PRIX8 "X" * _MSC_VER = 1700 VS2012
#define PRId16 "d"
#define PRIo16 "o"
#define PRIu16 "u"
#define PRIx16 "x"
#define PRIX16 "X"
#define PRId32 "d"
#define PRIo32 "o"
#define PRIu32 "u"
#define PRIx32 "x"
#define PRIX32 "X"
#define PRId64 "lld"
#define PRIo64 "llo"
#define PRIu64 "llu"
#define PRIx64 "llx"
#define PRIX64 "llX"
#define PRIdMAX "lld"
#define PRIoMAX "llo"
#define PRIuMAX "llu"
#define PRIxMAX "llx"
#define PRIXMAX "llX"
#endif
/*
* _MSC_VER = 1900 VS2015
* _MSC_VER = 1800 VS2013
* _MSC_VER = 1700 VS2012
*/ */
#ifdef H5_HAVE_WIN32_API #ifdef H5_HAVE_WIN32_API
@ -119,22 +71,8 @@ typedef __int64 h5_stat_size_t;
#ifdef H5_HAVE_VISUAL_STUDIO #ifdef H5_HAVE_VISUAL_STUDIO
#if (_MSC_VER < 1800)
#ifndef H5_HAVE_STRTOLL
#define HDstrtoll(S, R, N) _strtoi64(S, R, N)
#endif /* H5_HAVE_STRTOLL */
#ifndef H5_HAVE_STRTOULL
#define HDstrtoull(S, R, N) _strtoui64(S, R, N)
#endif /* H5_HAVE_STRTOULL */
/* va_copy() does not exist on pre-2013 Visual Studio. Since va_lists are
* just pointers into the stack in those CRTs, the usual work-around
* is to just define the operation as a pointer copy.
*/
#define HDva_copy(D, S) ((D) = (S))
#endif /* MSC_VER < 1800 */
/* /*
* The (void*) cast just avoids a compiler warning in H5_HAVE_VISUAL_STUDIO * The (void*) cast just avoids a compiler warning in MSVC
*/ */
#define HDmemset(X, C, Z) memset((void *)(X), C, Z) #define HDmemset(X, C, Z) memset((void *)(X), C, Z)
@ -143,26 +81,6 @@ struct timezone {
int tz_dsttime; int tz_dsttime;
}; };
/* time.h before VS2015 does not include timespec */
#if (_MSC_VER < 1900)
struct timespec {
time_t tv_sec; /* Seconds - >= 0 */
long tv_nsec; /* Nanoseconds - [0, 999999999] */
};
#endif /* MSC_VER < 1900 */
#if (_MSC_VER <= 1700)
/* The isnan function needs underscore in VS2012 and earlier */
#define HDisnan(X) _isnan(X)
/* The round functions do not exist in VS2012 and earlier */
#define HDllround(V) Wllround(V)
#define HDllroundf(V) Wllroundf(V)
#define HDlround(V) Wlround(V)
#define HDlroundf(V) Wlroundf(V)
#define HDround(V) Wround(V)
#define HDroundf(V) Wroundf(V)
#endif /* MSC_VER < 1700 */
#endif /* H5_HAVE_VISUAL_STUDIO */ #endif /* H5_HAVE_VISUAL_STUDIO */
#ifdef __cplusplus #ifdef __cplusplus
@ -172,25 +90,11 @@ H5_DLL int Wgettimeofday(struct timeval *tv, struct timezone *tz);
H5_DLL int Wsetenv(const char *name, const char *value, int overwrite); H5_DLL int Wsetenv(const char *name, const char *value, int overwrite);
H5_DLL int Wflock(int fd, int operation); H5_DLL int Wflock(int fd, int operation);
H5_DLL char * Wgetlogin(void); H5_DLL char * Wgetlogin(void);
H5_DLL int c99_snprintf(char *str, size_t size, const char *format, ...);
H5_DLL int c99_vsnprintf(char *str, size_t size, const char *format, va_list ap);
H5_DLL herr_t H5_expand_windows_env_vars(char **env_var); H5_DLL herr_t H5_expand_windows_env_vars(char **env_var);
H5_DLL wchar_t *H5_get_utf16_str(const char *s); H5_DLL wchar_t *H5_get_utf16_str(const char *s);
H5_DLL int Wopen_utf8(const char *path, int oflag, ...); H5_DLL int Wopen_utf8(const char *path, int oflag, ...);
H5_DLL int Wremove_utf8(const char *path); H5_DLL int Wremove_utf8(const char *path);
H5_DLL int H5_get_win32_times(H5_timevals_t *tvs); H5_DLL int H5_get_win32_times(H5_timevals_t *tvs);
/* Round functions only needed for VS2012 and earlier.
* They are always built to ensure they don't go stale and
* can be deleted (along with their #defines, above) when we
* drop VS2012 support.
*/
H5_DLL long long Wllround(double arg);
H5_DLL long long Wllroundf(float arg);
H5_DLL long Wlround(double arg);
H5_DLL long Wlroundf(float arg);
H5_DLL double Wround(double arg);
H5_DLL float Wroundf(float arg);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif /* __cplusplus */ #endif /* __cplusplus */
@ -199,8 +103,6 @@ H5_DLL float Wroundf(float arg);
#define HDsetenv(N, V, O) Wsetenv(N, V, O) #define HDsetenv(N, V, O) Wsetenv(N, V, O)
#define HDflock(F, L) Wflock(F, L) #define HDflock(F, L) Wflock(F, L)
#define HDgetlogin() Wgetlogin() #define HDgetlogin() Wgetlogin()
#define HDsnprintf c99_snprintf /*varargs*/
#define HDvsnprintf c99_vsnprintf /*varargs*/
/* Non-POSIX functions */ /* Non-POSIX functions */