diff options
author | Jacek Antonelli | 2008-08-15 23:44:46 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:44:46 -0500 |
commit | 38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4 (patch) | |
tree | adca584755d22ca041a2dbfc35d4eca01f70b32c /linden/indra/newview/VertexCache.h | |
parent | README.txt (diff) | |
download | meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.zip meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.gz meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.bz2 meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.xz |
Second Life viewer sources 1.13.2.12
Diffstat (limited to 'linden/indra/newview/VertexCache.h')
-rw-r--r-- | linden/indra/newview/VertexCache.h | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/linden/indra/newview/VertexCache.h b/linden/indra/newview/VertexCache.h new file mode 100644 index 0000000..1c9783d --- /dev/null +++ b/linden/indra/newview/VertexCache.h | |||
@@ -0,0 +1,106 @@ | |||
1 | /** | ||
2 | * @file VertexCache.h | ||
3 | * @brief VertexCache class definition | ||
4 | * | ||
5 | * Copyright (c) 2002-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | |||
29 | #ifndef VERTEX_CACHE_H | ||
30 | |||
31 | #define VERTEX_CACHE_H | ||
32 | |||
33 | class VertexCache | ||
34 | { | ||
35 | |||
36 | public: | ||
37 | |||
38 | VertexCache(int size) | ||
39 | { | ||
40 | numEntries = size; | ||
41 | |||
42 | entries = new int[numEntries]; | ||
43 | |||
44 | for(int i = 0; i < numEntries; i++) | ||
45 | entries[i] = -1; | ||
46 | } | ||
47 | |||
48 | VertexCache() { VertexCache(16); } | ||
49 | ~VertexCache() { delete[] entries; entries = 0; } | ||
50 | |||
51 | bool InCache(int entry) | ||
52 | { | ||
53 | bool returnVal = false; | ||
54 | for(int i = 0; i < numEntries; i++) | ||
55 | { | ||
56 | if(entries[i] == entry) | ||
57 | { | ||
58 | returnVal = true; | ||
59 | break; | ||
60 | } | ||
61 | } | ||
62 | |||
63 | return returnVal; | ||
64 | } | ||
65 | |||
66 | int AddEntry(int entry) | ||
67 | { | ||
68 | int removed; | ||
69 | |||
70 | removed = entries[numEntries - 1]; | ||
71 | |||
72 | //push everything right one | ||
73 | for(int i = numEntries - 2; i >= 0; i--) | ||
74 | { | ||
75 | entries[i + 1] = entries[i]; | ||
76 | } | ||
77 | |||
78 | entries[0] = entry; | ||
79 | |||
80 | return removed; | ||
81 | } | ||
82 | |||
83 | void Clear() | ||
84 | { | ||
85 | memset(entries, -1, sizeof(int) * numEntries); | ||
86 | } | ||
87 | |||
88 | void Copy(VertexCache* inVcache) | ||
89 | { | ||
90 | for(int i = 0; i < numEntries; i++) | ||
91 | { | ||
92 | inVcache->Set(i, entries[i]); | ||
93 | } | ||
94 | } | ||
95 | |||
96 | int At(int index) { return entries[index]; } | ||
97 | void Set(int index, int value) { entries[index] = value; } | ||
98 | |||
99 | private: | ||
100 | |||
101 | int *entries; | ||
102 | int numEntries; | ||
103 | |||
104 | }; | ||
105 | |||
106 | #endif | ||