Blame lib/minmax.h

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