Filling in branch from trunk
[blender.git] / source / blender / blenlib / MTC_vectorops.h
1 /*
2  * vectorops.h
3  *
4  * $Id$
5  *
6  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License
10  * as published by the Free Software Foundation; either version 2
11  * of the License, or (at your option) any later version. The Blender
12  * Foundation also sells licenses for use in proprietary software under
13  * the Blender License.  See http://www.blender.org/BL/ for information
14  * about this.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program; if not, write to the Free Software Foundation,
23  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
24  *
25  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
26  * All rights reserved.
27  *
28  * The Original Code is: all of this file.
29  *
30  * Contributor(s): none yet.
31  *
32  * ***** END GPL/BL DUAL LICENSE BLOCK *****
33  */
34
35 #ifndef VECTOROPS_H
36 #define VECTOROPS_H 
37
38 /* ------------------------------------------------------------------------- */
39
40 void  MTC_diff3Int(int v1[3], int v2[3], int v3[3]);
41 void  MTC_cross3Int(int v1[3], int v2[3], int v3[3]);
42 int   MTC_dot3Int(int v1[3], int v2[3]); 
43
44 void  MTC_diff3Float(float v1[3], float v2[3], float v3[3]);
45 void  MTC_cross3Float(float v1[3], float v2[3], float v3[3]);
46 float MTC_dot3Float(float v1[3], float v2[3]); 
47 void  MTC_cp3Float(float v1[3], float v2[3]);
48 /**
49  * Copy vector with a minus sign (so a = -b)
50  */
51 void  MTC_cp3FloatInv(float v1[3], float v2[3]);
52
53 void  MTC_swapInt(int *i1, int *i2);
54
55 void  MTC_diff3DFF(double v1[3], float v2[3], float v3[3]);
56 void  MTC_cross3Double(double v1[3], double v2[3], double v3[3]);
57 float MTC_normalize3DF(float n[3]);
58
59 /* ------------------------------------------------------------------------- */
60 #endif /* VECTOROPS_H */
61