Added the Solid 3.5 sources to the blender source tree.
[blender.git] / extern / solid / include / GEN_MinMax.h
1 /*
2  * SOLID - Software Library for Interference Detection
3  * 
4  * Copyright (C) 2001-2003  Dtecta.  All rights reserved.
5  *
6  * This library may be distributed under the terms of the Q Public License
7  * (QPL) as defined by Trolltech AS of Norway and appearing in the file
8  * LICENSE.QPL included in the packaging of this file.
9  *
10  * This library may be distributed and/or modified under the terms of the
11  * GNU General Public License (GPL) version 2 as published by the Free Software
12  * Foundation and appearing in the file LICENSE.GPL included in the
13  * packaging of this file.
14  *
15  * This library is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
16  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
17  *
18  * Commercial use or any other use of this library not covered by either 
19  * the QPL or the GPL requires an additional license from Dtecta. 
20  * Please contact info@dtecta.com for enquiries about the terms of commercial
21  * use of this library.
22  */
23
24 #ifndef GEN_MINMAX_H
25 #define GEN_MINMAX_H
26
27 template <class T>
28 inline const T& GEN_min(const T& a, const T& b) 
29 {
30   return b < a ? b : a;
31 }
32
33 template <class T>
34 inline const T& GEN_max(const T& a, const T& b) 
35 {
36   return  a < b ? b : a;
37 }
38
39 template <class T>
40 inline const T& GEN_clamped(const T& a, const T& lb, const T& ub) 
41 {
42         return a < lb ? lb : (ub < a ? ub : a); 
43 }
44
45 template <class T>
46 inline void GEN_set_min(T& a, const T& b) 
47 {
48     if (b < a) 
49         {
50                 a = b;
51         }
52 }
53
54 template <class T>
55 inline void GEN_set_max(T& a, const T& b) 
56 {
57     if (a < b) 
58         {
59                 a = b;
60         }
61 }
62
63 template <class T>
64 inline void GEN_clamp(T& a, const T& lb, const T& ub) 
65 {
66         if (a < lb) 
67         {
68                 a = lb; 
69         }
70         else if (ub < a) 
71         {
72                 a = ub;
73         }
74 }
75
76 #endif