Blame lib/minmax.h

Packit 8f70b4
/* MIN, MAX macros.
Packit 8f70b4
   Copyright (C) 1995, 1998, 2001, 2003, 2005, 2009-2018 Free Software
Packit 8f70b4
   Foundation, Inc.
Packit 8f70b4
Packit 8f70b4
   This program is free software; you can redistribute it and/or modify
Packit 8f70b4
   it under the terms of the GNU General Public License as published by
Packit 8f70b4
   the Free Software Foundation; either version 3, or (at your option)
Packit 8f70b4
   any later version.
Packit 8f70b4
Packit 8f70b4
   This program is distributed in the hope that it will be useful,
Packit 8f70b4
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 8f70b4
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 8f70b4
   GNU General Public License for more details.
Packit 8f70b4
Packit 8f70b4
   You should have received a copy of the GNU General Public License
Packit 8f70b4
   along with this program; if not, see <https://www.gnu.org/licenses/>.  */
Packit 8f70b4
Packit 8f70b4
#ifndef _MINMAX_H
Packit 8f70b4
#define _MINMAX_H
Packit 8f70b4
Packit 8f70b4
/* Note: MIN, MAX are also defined in <sys/param.h> on some systems
Packit 8f70b4
   (glibc, IRIX, HP-UX, OSF/1).  Therefore you might get warnings about
Packit 8f70b4
   MIN, MAX macro redefinitions on some systems; the workaround is to
Packit 8f70b4
   #include this file as the last one among the #include list.  */
Packit 8f70b4
Packit 8f70b4
/* Before we define the following symbols we get the <limits.h> file
Packit 8f70b4
   since otherwise we get redefinitions on some systems if <limits.h> is
Packit 8f70b4
   included after this file.  Likewise for <sys/param.h>.
Packit 8f70b4
   If more than one of these system headers define MIN and MAX, pick just
Packit 8f70b4
   one of the headers (because the definitions most likely are the same).  */
Packit 8f70b4
#if HAVE_MINMAX_IN_LIMITS_H
Packit 8f70b4
# include <limits.h>
Packit 8f70b4
#elif HAVE_MINMAX_IN_SYS_PARAM_H
Packit 8f70b4
# include <sys/param.h>
Packit 8f70b4
#endif
Packit 8f70b4
Packit 8f70b4
/* Note: MIN and MAX should be used with two arguments of the
Packit 8f70b4
   same type.  They might not return the minimum and maximum of their two
Packit 8f70b4
   arguments, if the arguments have different types or have unusual
Packit 8f70b4
   floating-point values.  For example, on a typical host with 32-bit 'int',
Packit 8f70b4
   64-bit 'long long', and 64-bit IEEE 754 'double' types:
Packit 8f70b4
Packit 8f70b4
     MAX (-1, 2147483648) returns 4294967295.
Packit 8f70b4
     MAX (9007199254740992.0, 9007199254740993) returns 9007199254740992.0.
Packit 8f70b4
     MAX (NaN, 0.0) returns 0.0.
Packit 8f70b4
     MAX (+0.0, -0.0) returns -0.0.
Packit 8f70b4
Packit 8f70b4
   and in each case the answer is in some sense bogus.  */
Packit 8f70b4
Packit 8f70b4
/* MAX(a,b) returns the maximum of A and B.  */
Packit 8f70b4
#ifndef MAX
Packit 8f70b4
# define MAX(a,b) ((a) > (b) ? (a) : (b))
Packit 8f70b4
#endif
Packit 8f70b4
Packit 8f70b4
/* MIN(a,b) returns the minimum of A and B.  */
Packit 8f70b4
#ifndef MIN
Packit 8f70b4
# define MIN(a,b) ((a) < (b) ? (a) : (b))
Packit 8f70b4
#endif
Packit 8f70b4
Packit 8f70b4
#endif /* _MINMAX_H */