diff options
author | Jacek Antonelli | 2008-12-01 17:39:58 -0600 |
---|---|---|
committer | Jacek Antonelli | 2008-12-01 17:40:06 -0600 |
commit | 7abecb48babe6a6f09bf6692ba55076546cfced9 (patch) | |
tree | 8d18a88513fb97adf32c10aae78f4be1984942db /linden/indra/llmath/llmodularmath.h | |
parent | Second Life viewer sources 1.21.6 (diff) | |
download | meta-impy-7abecb48babe6a6f09bf6692ba55076546cfced9.zip meta-impy-7abecb48babe6a6f09bf6692ba55076546cfced9.tar.gz meta-impy-7abecb48babe6a6f09bf6692ba55076546cfced9.tar.bz2 meta-impy-7abecb48babe6a6f09bf6692ba55076546cfced9.tar.xz |
Second Life viewer sources 1.22.0-RC
Diffstat (limited to 'linden/indra/llmath/llmodularmath.h')
-rw-r--r-- | linden/indra/llmath/llmodularmath.h | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/linden/indra/llmath/llmodularmath.h b/linden/indra/llmath/llmodularmath.h new file mode 100644 index 0000000..076f5da --- /dev/null +++ b/linden/indra/llmath/llmodularmath.h | |||
@@ -0,0 +1,57 @@ | |||
1 | /** | ||
2 | * @file llmodularmath.h | ||
3 | * @brief Useful modular math functions. | ||
4 | * | ||
5 | * $LicenseInfo:firstyear=2008&license=viewergpl$ | ||
6 | * | ||
7 | * Copyright (c) 2008, Linden Research, Inc. | ||
8 | * | ||
9 | * Second Life Viewer Source Code | ||
10 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
11 | * to you under the terms of the GNU General Public License, version 2.0 | ||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
16 | * | ||
17 | * There are special exceptions to the terms and conditions of the GPL as | ||
18 | * it is applied to this Source Code. View the full text of the exception | ||
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
21 | * | ||
22 | * By copying, modifying or distributing this software, you acknowledge | ||
23 | * that you have read and understood your obligations described above, | ||
24 | * and agree to abide by those obligations. | ||
25 | * | ||
26 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
27 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
28 | * COMPLETENESS OR PERFORMANCE. | ||
29 | * $/LicenseInfo$ | ||
30 | */ | ||
31 | |||
32 | #ifndef LLMODULARMATH_H | ||
33 | #define LLMODULARMATH_H | ||
34 | |||
35 | namespace LLModularMath | ||
36 | { | ||
37 | // Return difference between lhs and rhs | ||
38 | // treating the U32 operands and result | ||
39 | // as unsigned values of given width. | ||
40 | template<int width> | ||
41 | inline U32 subtract(U32 lhs, U32 rhs) | ||
42 | { | ||
43 | // Generate a bit mask which will truncate | ||
44 | // unsigned values to given width at compile time. | ||
45 | const U32 mask = (1 << width) - 1; | ||
46 | |||
47 | // Operands are unsigned, so modular | ||
48 | // arithmetic applies. If lhs < rhs, | ||
49 | // difference will wrap in to lower | ||
50 | // bits of result, which is then masked | ||
51 | // to give a value that can be represented | ||
52 | // by an unsigned value of width bits. | ||
53 | return mask & (lhs - rhs); | ||
54 | } | ||
55 | } | ||
56 | |||
57 | #endif | ||