diff options
Diffstat (limited to 'linden/indra/llmath')
37 files changed, 841 insertions, 4091 deletions
diff --git a/linden/indra/llmath/CMakeLists.txt b/linden/indra/llmath/CMakeLists.txt new file mode 100644 index 0000000..6a329fa --- /dev/null +++ b/linden/indra/llmath/CMakeLists.txt | |||
@@ -0,0 +1,81 @@ | |||
1 | # -*- cmake -*- | ||
2 | |||
3 | project(llmath) | ||
4 | |||
5 | include(00-Common) | ||
6 | include(LLCommon) | ||
7 | |||
8 | include_directories( | ||
9 | ${LLCOMMON_INCLUDE_DIRS} | ||
10 | ) | ||
11 | |||
12 | set(llmath_SOURCE_FILES | ||
13 | llbboxlocal.cpp | ||
14 | llcamera.cpp | ||
15 | llcoordframe.cpp | ||
16 | llline.cpp | ||
17 | llperlin.cpp | ||
18 | llquaternion.cpp | ||
19 | llrect.cpp | ||
20 | llsphere.cpp | ||
21 | llvolume.cpp | ||
22 | llvolumemgr.cpp | ||
23 | llsdutil_math.cpp | ||
24 | m3math.cpp | ||
25 | m4math.cpp | ||
26 | raytrace.cpp | ||
27 | v2math.cpp | ||
28 | v3color.cpp | ||
29 | v3dmath.cpp | ||
30 | v3math.cpp | ||
31 | v4color.cpp | ||
32 | v4coloru.cpp | ||
33 | v4math.cpp | ||
34 | xform.cpp | ||
35 | ) | ||
36 | |||
37 | set(llmath_HEADER_FILES | ||
38 | CMakeLists.txt | ||
39 | |||
40 | camera.h | ||
41 | coordframe.h | ||
42 | llbboxlocal.h | ||
43 | llcamera.h | ||
44 | llcoord.h | ||
45 | llcoordframe.h | ||
46 | llinterp.h | ||
47 | llline.h | ||
48 | llmath.h | ||
49 | lloctree.h | ||
50 | llperlin.h | ||
51 | llplane.h | ||
52 | llquantize.h | ||
53 | llquaternion.h | ||
54 | llrect.h | ||
55 | llsphere.h | ||
56 | lltreenode.h | ||
57 | llv4math.h | ||
58 | llv4matrix3.h | ||
59 | llv4matrix4.h | ||
60 | llv4vector3.h | ||
61 | llvolume.h | ||
62 | llvolumemgr.h | ||
63 | m3math.h | ||
64 | m4math.h | ||
65 | raytrace.h | ||
66 | v2math.h | ||
67 | v3color.h | ||
68 | v3dmath.h | ||
69 | v3math.h | ||
70 | v4color.h | ||
71 | v4coloru.h | ||
72 | v4math.h | ||
73 | xform.h | ||
74 | ) | ||
75 | |||
76 | set_source_files_properties(${llmath_HEADER_FILES} | ||
77 | PROPERTIES HEADER_FILE_ONLY TRUE) | ||
78 | |||
79 | list(APPEND llmath_SOURCE_FILES ${llmath_HEADER_FILES}) | ||
80 | |||
81 | add_library (llmath ${llmath_SOURCE_FILES}) | ||
diff --git a/linden/indra/llmath/files.lst b/linden/indra/llmath/files.lst deleted file mode 100644 index 1001a6d..0000000 --- a/linden/indra/llmath/files.lst +++ /dev/null | |||
@@ -1,25 +0,0 @@ | |||
1 | llmath/llbboxlocal.cpp | ||
2 | llmath/llcamera.cpp | ||
3 | llmath/llcoordframe.cpp | ||
4 | llmath/llcrc.cpp | ||
5 | llmath/llline.cpp | ||
6 | llmath/llmd5.cpp | ||
7 | llmath/llperlin.cpp | ||
8 | llmath/llquaternion.cpp | ||
9 | llmath/llrand.cpp | ||
10 | llmath/llrect.cpp | ||
11 | llmath/llsphere.cpp | ||
12 | llmath/lluuid.cpp | ||
13 | llmath/llvolume.cpp | ||
14 | llmath/llvolumemgr.cpp | ||
15 | llmath/m3math.cpp | ||
16 | llmath/m4math.cpp | ||
17 | llmath/raytrace.cpp | ||
18 | llmath/v2math.cpp | ||
19 | llmath/v3color.cpp | ||
20 | llmath/v3dmath.cpp | ||
21 | llmath/v3math.cpp | ||
22 | llmath/v4color.cpp | ||
23 | llmath/v4coloru.cpp | ||
24 | llmath/v4math.cpp | ||
25 | llmath/xform.cpp | ||
diff --git a/linden/indra/llmath/llcamera.h b/linden/indra/llmath/llcamera.h index 7066b9f..2884338 100644 --- a/linden/indra/llmath/llcamera.h +++ b/linden/indra/llmath/llcamera.h | |||
@@ -115,11 +115,12 @@ protected: | |||
115 | LLPlane mWorldPlanes[PLANE_NUM]; | 115 | LLPlane mWorldPlanes[PLANE_NUM]; |
116 | LLPlane mHorizPlanes[HORIZ_PLANE_NUM]; | 116 | LLPlane mHorizPlanes[HORIZ_PLANE_NUM]; |
117 | 117 | ||
118 | typedef struct | 118 | struct frustum_plane |
119 | { | 119 | { |
120 | frustum_plane() : mask(0) {} | ||
120 | LLPlane p; | 121 | LLPlane p; |
121 | U8 mask; | 122 | U8 mask; |
122 | } frustum_plane; | 123 | }; |
123 | frustum_plane mAgentPlanes[7]; //frustum planes in agent space a la gluUnproject (I'm a bastard, I know) - DaveP | 124 | frustum_plane mAgentPlanes[7]; //frustum planes in agent space a la gluUnproject (I'm a bastard, I know) - DaveP |
124 | 125 | ||
125 | U32 mPlaneCount; //defaults to 6, if setUserClipPlane is called, uses user supplied clip plane in | 126 | U32 mPlaneCount; //defaults to 6, if setUserClipPlane is called, uses user supplied clip plane in |
diff --git a/linden/indra/llmath/llcrc.cpp b/linden/indra/llmath/llcrc.cpp deleted file mode 100644 index 447521a..0000000 --- a/linden/indra/llmath/llcrc.cpp +++ /dev/null | |||
@@ -1,224 +0,0 @@ | |||
1 | /** | ||
2 | * @file llcrc.cpp | ||
3 | * @brief implementation of the crc class. | ||
4 | * | ||
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | ||
6 | * | ||
7 | * Copyright (c) 2002-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 | #include "linden_common.h" | ||
33 | |||
34 | #include "llcrc.h" | ||
35 | #include "llerror.h" | ||
36 | |||
37 | /* Copyright (C) 1986 Gary S. Brown. You may use this program, or | ||
38 | code or tables extracted from it, as desired without restriction.*/ | ||
39 | |||
40 | /* First, the polynomial itself and its table of feedback terms. The */ | ||
41 | /* polynomial is */ | ||
42 | /* X^32+X^26+X^23+X^22+X^16+X^12+X^11+X^10+X^8+X^7+X^5+X^4+X^2+X^1+X^0 */ | ||
43 | /* Note that we take it "backwards" and put the highest-order term in */ | ||
44 | /* the lowest-order bit. The X^32 term is "implied"; the LSB is the */ | ||
45 | /* X^31 term, etc. The X^0 term (usually shown as "+1") results in */ | ||
46 | /* the MSB being 1. */ | ||
47 | |||
48 | /* Note that the usual hardware shift register implementation, which */ | ||
49 | /* is what we're using (we're merely optimizing it by doing eight-bit */ | ||
50 | /* chunks at a time) shifts bits into the lowest-order term. In our */ | ||
51 | /* implementation, that means shifting towards the right. Why do we */ | ||
52 | /* do it this way? Because the calculated CRC must be transmitted in */ | ||
53 | /* order from highest-order term to lowest-order term. UARTs transmit */ | ||
54 | /* characters in order from LSB to MSB. By storing the CRC this way, */ | ||
55 | /* we hand it to the UART in the order low-byte to high-byte; the UART */ | ||
56 | /* sends each low-bit to hight-bit; and the result is transmission bit */ | ||
57 | /* by bit from highest- to lowest-order term without requiring any bit */ | ||
58 | /* shuffling on our part. Reception works similarly. */ | ||
59 | |||
60 | /* The feedback terms table consists of 256, 32-bit entries. Notes: */ | ||
61 | /* */ | ||
62 | /* 1. The table can be generated at runtime if desired; code to do so */ | ||
63 | /* is shown later. It might not be obvious, but the feedback */ | ||
64 | /* terms simply represent the results of eight shift/xor opera- */ | ||
65 | /* tions for all combinations of data and CRC register values. */ | ||
66 | /* */ | ||
67 | /* 2. The CRC accumulation logic is the same for all CRC polynomials, */ | ||
68 | /* be they sixteen or thirty-two bits wide. You simply choose the */ | ||
69 | /* appropriate table. Alternatively, because the table can be */ | ||
70 | /* generated at runtime, you can start by generating the table for */ | ||
71 | /* the polynomial in question and use exactly the same "updcrc", */ | ||
72 | /* if your application needn't simultaneously handle two CRC */ | ||
73 | /* polynomials. (Note, however, that XMODEM is strange.) */ | ||
74 | /* */ | ||
75 | /* 3. For 16-bit CRCs, the table entries need be only 16 bits wide; */ | ||
76 | /* of course, 32-bit entries work OK if the high 16 bits are zero. */ | ||
77 | /* */ | ||
78 | /* 4. The values must be right-shifted by eight bits by the "updcrc" */ | ||
79 | /* logic; the shift must be unsigned (bring in zeroes). On some */ | ||
80 | /* hardware you could probably optimize the shift in assembler by */ | ||
81 | /* using byte-swap instructions. */ | ||
82 | |||
83 | ///---------------------------------------------------------------------------- | ||
84 | /// Local function declarations, constants, enums, and typedefs | ||
85 | ///---------------------------------------------------------------------------- | ||
86 | |||
87 | #define UPDC32(octet,crc) (crc_32_tab[((crc) \ | ||
88 | ^ ((U8)octet)) & 0xff] ^ ((crc) >> 8)) | ||
89 | |||
90 | |||
91 | static U32 crc_32_tab[] = { /* CRC polynomial 0xedb88320 */ | ||
92 | 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, | ||
93 | 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, | ||
94 | 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2, | ||
95 | 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7, | ||
96 | 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, | ||
97 | 0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, | ||
98 | 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c, | ||
99 | 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59, | ||
100 | 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, | ||
101 | 0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, | ||
102 | 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106, | ||
103 | 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433, | ||
104 | 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, | ||
105 | 0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, | ||
106 | 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950, | ||
107 | 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65, | ||
108 | 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, | ||
109 | 0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, | ||
110 | 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa, | ||
111 | 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f, | ||
112 | 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, | ||
113 | 0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, | ||
114 | 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84, | ||
115 | 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1, | ||
116 | 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, | ||
117 | 0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, | ||
118 | 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e, | ||
119 | 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b, | ||
120 | 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, | ||
121 | 0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, | ||
122 | 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28, | ||
123 | 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d, | ||
124 | 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, | ||
125 | 0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, | ||
126 | 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242, | ||
127 | 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777, | ||
128 | 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, | ||
129 | 0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, | ||
130 | 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc, | ||
131 | 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9, | ||
132 | 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, | ||
133 | 0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, | ||
134 | 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d | ||
135 | }; | ||
136 | |||
137 | |||
138 | ///---------------------------------------------------------------------------- | ||
139 | /// Class llcrc | ||
140 | ///---------------------------------------------------------------------------- | ||
141 | |||
142 | // Default constructor | ||
143 | LLCRC::LLCRC() : mCurrent(0xffffffff) | ||
144 | { | ||
145 | } | ||
146 | |||
147 | |||
148 | U32 LLCRC::getCRC() const | ||
149 | { | ||
150 | return ~mCurrent; | ||
151 | } | ||
152 | |||
153 | void LLCRC::update(U8 next_byte) | ||
154 | { | ||
155 | mCurrent = UPDC32(next_byte, mCurrent); | ||
156 | } | ||
157 | |||
158 | void LLCRC::update(const U8* buffer, size_t buffer_size) | ||
159 | { | ||
160 | for (size_t i = 0; i < buffer_size; i++) | ||
161 | { | ||
162 | mCurrent = UPDC32(buffer[i], mCurrent); | ||
163 | } | ||
164 | } | ||
165 | |||
166 | void LLCRC::update(const char* filename) | ||
167 | { | ||
168 | if (!filename) | ||
169 | { | ||
170 | llerrs << "No filename specified" << llendl; | ||
171 | return; | ||
172 | } | ||
173 | |||
174 | LLFILE* fp = LLFile::fopen(filename, "rb"); /* Flawfinder: ignore */ | ||
175 | |||
176 | if (fp) | ||
177 | { | ||
178 | fseek(fp, 0, SEEK_END); | ||
179 | long size = ftell(fp); | ||
180 | |||
181 | fseek(fp, 0, SEEK_SET); | ||
182 | |||
183 | if (size > 0) | ||
184 | { | ||
185 | U8* data = new U8[size]; | ||
186 | size_t nread; | ||
187 | |||
188 | nread = fread(data, 1, size, fp); | ||
189 | fclose(fp); | ||
190 | |||
191 | if (nread < (size_t) size) | ||
192 | { | ||
193 | llwarns << "Short read on " << filename << llendl; | ||
194 | } | ||
195 | |||
196 | update(data, nread); | ||
197 | delete[] data; | ||
198 | } | ||
199 | } | ||
200 | } | ||
201 | |||
202 | |||
203 | #ifdef _DEBUG | ||
204 | BOOL LLCRC::testHarness() | ||
205 | { | ||
206 | const S32 TEST_BUFFER_SIZE = 16; | ||
207 | const char TEST_BUFFER[TEST_BUFFER_SIZE] = "hello &#$)$&Nd0"; /* Flawfinder: ignore */ | ||
208 | LLCRC c1, c2; | ||
209 | c1.update((U8*)TEST_BUFFER, TEST_BUFFER_SIZE - 1); | ||
210 | char* rh = (char*)TEST_BUFFER; | ||
211 | while(*rh != '\0') | ||
212 | { | ||
213 | c2.update(*rh); | ||
214 | ++rh; | ||
215 | } | ||
216 | return(c1.getCRC() == c2.getCRC()); | ||
217 | } | ||
218 | #endif | ||
219 | |||
220 | |||
221 | |||
222 | ///---------------------------------------------------------------------------- | ||
223 | /// Local function definitions | ||
224 | ///---------------------------------------------------------------------------- | ||
diff --git a/linden/indra/llmath/llcrc.h b/linden/indra/llmath/llcrc.h deleted file mode 100644 index 59f58ce..0000000 --- a/linden/indra/llmath/llcrc.h +++ /dev/null | |||
@@ -1,73 +0,0 @@ | |||
1 | /** | ||
2 | * @file llcrc.h | ||
3 | * @brief LLCRC class header file. | ||
4 | * | ||
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | ||
6 | * | ||
7 | * Copyright (c) 2002-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 LL_LLCRC_H | ||
33 | #define LL_LLCRC_H | ||
34 | |||
35 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
36 | // Class llcrc | ||
37 | // | ||
38 | // Simple 32 bit crc. To use, instantiate an LLCRC instance and feed | ||
39 | // it the bytes you want to check. It will update the internal crc as | ||
40 | // you go, and you can qery it at the end. As a horribly inefficient | ||
41 | // example (don't try this at work kids): | ||
42 | // | ||
43 | // LLCRC crc; | ||
44 | // LLFILE* fp = LLFile::fopen(filename,"rb"); | ||
45 | // while(!feof(fp)) { | ||
46 | // crc.update(fgetc(fp)); | ||
47 | // } | ||
48 | // fclose(fp); | ||
49 | // llinfos << "File crc: " << crc.getCRC() << llendl; | ||
50 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
51 | |||
52 | class LLCRC | ||
53 | { | ||
54 | protected: | ||
55 | U32 mCurrent; | ||
56 | |||
57 | public: | ||
58 | LLCRC(); | ||
59 | |||
60 | U32 getCRC() const; | ||
61 | void update(U8 next_byte); | ||
62 | void update(const U8* buffer, size_t buffer_size); | ||
63 | void update(const char *filename); | ||
64 | |||
65 | #ifdef _DEBUG | ||
66 | // This function runs tests to make sure the crc is | ||
67 | // working. Returns TRUE if it is. | ||
68 | static BOOL testHarness(); | ||
69 | #endif | ||
70 | }; | ||
71 | |||
72 | |||
73 | #endif // LL_LLCRC_H | ||
diff --git a/linden/indra/llmath/llline.cpp b/linden/indra/llmath/llline.cpp index 9c41efb..cfd3f56 100644 --- a/linden/indra/llmath/llline.cpp +++ b/linden/indra/llmath/llline.cpp | |||
@@ -20,6 +20,8 @@ | |||
20 | * $/LicenseInfo$ | 20 | * $/LicenseInfo$ |
21 | */ | 21 | */ |
22 | 22 | ||
23 | #include "linden_common.h" | ||
24 | |||
23 | #include "llline.h" | 25 | #include "llline.h" |
24 | #include "llrand.h" | 26 | #include "llrand.h" |
25 | 27 | ||
diff --git a/linden/indra/llmath/llmath.h b/linden/indra/llmath/llmath.h index 4a6358d..82ab197 100644 --- a/linden/indra/llmath/llmath.h +++ b/linden/indra/llmath/llmath.h | |||
@@ -33,9 +33,10 @@ | |||
33 | #define LLMATH_H | 33 | #define LLMATH_H |
34 | 34 | ||
35 | #include <cmath> | 35 | #include <cmath> |
36 | //#include <math.h> | 36 | #include <cstdlib> |
37 | //#include <stdlib.h> | ||
38 | #include "lldefs.h" | 37 | #include "lldefs.h" |
38 | #include "llstl.h" // *TODO: Remove when LLString is gone | ||
39 | #include "llstring.h" // *TODO: Remove when LLString is gone | ||
39 | 40 | ||
40 | // work around for Windows & older gcc non-standard function names. | 41 | // work around for Windows & older gcc non-standard function names. |
41 | #if LL_WINDOWS | 42 | #if LL_WINDOWS |
@@ -93,6 +94,9 @@ const F32 F_APPROXIMATELY_ZERO = 0.00001f; | |||
93 | const F32 F_LN2 = 0.69314718056f; | 94 | const F32 F_LN2 = 0.69314718056f; |
94 | const F32 OO_LN2 = 1.4426950408889634073599246810019f; | 95 | const F32 OO_LN2 = 1.4426950408889634073599246810019f; |
95 | 96 | ||
97 | const F32 F_ALMOST_ZERO = 0.0001f; | ||
98 | const F32 F_ALMOST_ONE = 1.0f - F_ALMOST_ZERO; | ||
99 | |||
96 | // BUG: Eliminate in favor of F_APPROXIMATELY_ZERO above? | 100 | // BUG: Eliminate in favor of F_APPROXIMATELY_ZERO above? |
97 | const F32 FP_MAG_THRESHOLD = 0.0000001f; | 101 | const F32 FP_MAG_THRESHOLD = 0.0000001f; |
98 | 102 | ||
@@ -102,13 +106,13 @@ inline BOOL is_approx_zero( F32 f ) { return (-F_APPROXIMATELY_ZERO < f) && (f < | |||
102 | inline BOOL is_approx_equal(F32 x, F32 y) | 106 | inline BOOL is_approx_equal(F32 x, F32 y) |
103 | { | 107 | { |
104 | const S32 COMPARE_MANTISSA_UP_TO_BIT = 0x02; | 108 | const S32 COMPARE_MANTISSA_UP_TO_BIT = 0x02; |
105 | return (abs((S32) ((U32&)x - (U32&)y) ) < COMPARE_MANTISSA_UP_TO_BIT); | 109 | return (std::abs((S32) ((U32&)x - (U32&)y) ) < COMPARE_MANTISSA_UP_TO_BIT); |
106 | } | 110 | } |
107 | 111 | ||
108 | inline BOOL is_approx_equal(F64 x, F64 y) | 112 | inline BOOL is_approx_equal(F64 x, F64 y) |
109 | { | 113 | { |
110 | const S64 COMPARE_MANTISSA_UP_TO_BIT = 0x02; | 114 | const S64 COMPARE_MANTISSA_UP_TO_BIT = 0x02; |
111 | return (abs((S32) ((U64&)x - (U64&)y) ) < COMPARE_MANTISSA_UP_TO_BIT); | 115 | return (std::abs((S32) ((U64&)x - (U64&)y) ) < COMPARE_MANTISSA_UP_TO_BIT); |
112 | } | 116 | } |
113 | 117 | ||
114 | inline BOOL is_approx_equal_fraction(F32 x, F32 y, U32 frac_bits) | 118 | inline BOOL is_approx_equal_fraction(F32 x, F32 y, U32 frac_bits) |
@@ -155,17 +159,17 @@ inline BOOL is_approx_equal_fraction(F64 x, F64 y, U32 frac_bits) | |||
155 | 159 | ||
156 | inline S32 llabs(const S32 a) | 160 | inline S32 llabs(const S32 a) |
157 | { | 161 | { |
158 | return S32(labs(a)); | 162 | return S32(std::labs(a)); |
159 | } | 163 | } |
160 | 164 | ||
161 | inline F32 llabs(const F32 a) | 165 | inline F32 llabs(const F32 a) |
162 | { | 166 | { |
163 | return F32(fabs(a)); | 167 | return F32(std::fabs(a)); |
164 | } | 168 | } |
165 | 169 | ||
166 | inline F64 llabs(const F64 a) | 170 | inline F64 llabs(const F64 a) |
167 | { | 171 | { |
168 | return F64(fabs(a)); | 172 | return F64(std::fabs(a)); |
169 | } | 173 | } |
170 | 174 | ||
171 | inline S32 lltrunc( F32 f ) | 175 | inline S32 lltrunc( F32 f ) |
@@ -473,8 +477,8 @@ inline F32 llsimple_angle(F32 angle) | |||
473 | return angle; | 477 | return angle; |
474 | } | 478 | } |
475 | 479 | ||
476 | //calculate the nearesr power of two number for val, bounded by max_power_two | 480 | //SDK - Renamed this to get_lower_power_two, since this is what this actually does. |
477 | inline U32 get_nearest_power_two(U32 val, U32 max_power_two) | 481 | inline U32 get_lower_power_two(U32 val, U32 max_power_two) |
478 | { | 482 | { |
479 | if(!max_power_two) | 483 | if(!max_power_two) |
480 | { | 484 | { |
@@ -489,4 +493,34 @@ inline U32 get_nearest_power_two(U32 val, U32 max_power_two) | |||
489 | 493 | ||
490 | return max_power_two ; | 494 | return max_power_two ; |
491 | } | 495 | } |
496 | |||
497 | // calculate next highest power of two, limited by max_power_two | ||
498 | // This is taken from a brilliant little code snipped on http://acius2.blogspot.com/2007/11/calculating-next-power-of-2.html | ||
499 | // Basically we convert the binary to a solid string of 1's with the same | ||
500 | // number of digits, then add one. We subtract 1 initially to handle | ||
501 | // the case where the number passed in is actually a power of two. | ||
502 | // WARNING: this only works with 32 bit ints. | ||
503 | inline U32 get_next_power_two(U32 val, U32 max_power_two) | ||
504 | { | ||
505 | if(!max_power_two) | ||
506 | { | ||
507 | max_power_two = 1 << 31 ; | ||
508 | } | ||
509 | |||
510 | if(val >= max_power_two) | ||
511 | { | ||
512 | return max_power_two; | ||
513 | } | ||
514 | |||
515 | val--; | ||
516 | val = (val >> 1) | val; | ||
517 | val = (val >> 2) | val; | ||
518 | val = (val >> 4) | val; | ||
519 | val = (val >> 8) | val; | ||
520 | val = (val >> 16) | val; | ||
521 | val++; | ||
522 | |||
523 | return val; | ||
524 | } | ||
525 | |||
492 | #endif | 526 | #endif |
diff --git a/linden/indra/llmath/llmath.vcproj b/linden/indra/llmath/llmath.vcproj deleted file mode 100644 index d05505e..0000000 --- a/linden/indra/llmath/llmath.vcproj +++ /dev/null | |||
@@ -1,348 +0,0 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="7.10" | ||
5 | Name="llmath" | ||
6 | ProjectGUID="{E87FD9BE-BE42-4EA3-BF4D-D992223046D9}" | ||
7 | Keyword="Win32Proj"> | ||
8 | <Platforms> | ||
9 | <Platform | ||
10 | Name="Win32"/> | ||
11 | </Platforms> | ||
12 | <Configurations> | ||
13 | <Configuration | ||
14 | Name="Debug|Win32" | ||
15 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
16 | IntermediateDirectory="$(ConfigurationName)" | ||
17 | ConfigurationType="4" | ||
18 | CharacterSet="1"> | ||
19 | <Tool | ||
20 | Name="VCCLCompilerTool" | ||
21 | Optimization="0" | ||
22 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" | ||
24 | MinimalRebuild="TRUE" | ||
25 | BasicRuntimeChecks="3" | ||
26 | RuntimeLibrary="1" | ||
27 | StructMemberAlignment="4" | ||
28 | ForceConformanceInForLoopScope="TRUE" | ||
29 | UsePrecompiledHeader="0" | ||
30 | WarningLevel="3" | ||
31 | WarnAsError="TRUE" | ||
32 | Detect64BitPortabilityProblems="FALSE" | ||
33 | DebugInformationFormat="4"/> | ||
34 | <Tool | ||
35 | Name="VCCustomBuildTool"/> | ||
36 | <Tool | ||
37 | Name="VCLibrarianTool" | ||
38 | OutputFile="$(OutDir)/llmath.lib"/> | ||
39 | <Tool | ||
40 | Name="VCMIDLTool"/> | ||
41 | <Tool | ||
42 | Name="VCPostBuildEventTool"/> | ||
43 | <Tool | ||
44 | Name="VCPreBuildEventTool"/> | ||
45 | <Tool | ||
46 | Name="VCPreLinkEventTool"/> | ||
47 | <Tool | ||
48 | Name="VCResourceCompilerTool"/> | ||
49 | <Tool | ||
50 | Name="VCWebServiceProxyGeneratorTool"/> | ||
51 | <Tool | ||
52 | Name="VCXMLDataGeneratorTool"/> | ||
53 | <Tool | ||
54 | Name="VCManagedWrapperGeneratorTool"/> | ||
55 | <Tool | ||
56 | Name="VCAuxiliaryManagedWrapperGeneratorTool"/> | ||
57 | </Configuration> | ||
58 | <Configuration | ||
59 | Name="Release|Win32" | ||
60 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
61 | IntermediateDirectory="$(ConfigurationName)" | ||
62 | ConfigurationType="4" | ||
63 | CharacterSet="1"> | ||
64 | <Tool | ||
65 | Name="VCCLCompilerTool" | ||
66 | AdditionalOptions="/Oy-" | ||
67 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
68 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | ||
69 | RuntimeLibrary="0" | ||
70 | StructMemberAlignment="0" | ||
71 | ForceConformanceInForLoopScope="TRUE" | ||
72 | UsePrecompiledHeader="0" | ||
73 | WarningLevel="3" | ||
74 | WarnAsError="TRUE" | ||
75 | Detect64BitPortabilityProblems="FALSE" | ||
76 | DebugInformationFormat="3"/> | ||
77 | <Tool | ||
78 | Name="VCCustomBuildTool"/> | ||
79 | <Tool | ||
80 | Name="VCLibrarianTool" | ||
81 | OutputFile="$(OutDir)/llmath.lib"/> | ||
82 | <Tool | ||
83 | Name="VCMIDLTool"/> | ||
84 | <Tool | ||
85 | Name="VCPostBuildEventTool"/> | ||
86 | <Tool | ||
87 | Name="VCPreBuildEventTool"/> | ||
88 | <Tool | ||
89 | Name="VCPreLinkEventTool"/> | ||
90 | <Tool | ||
91 | Name="VCResourceCompilerTool"/> | ||
92 | <Tool | ||
93 | Name="VCWebServiceProxyGeneratorTool"/> | ||
94 | <Tool | ||
95 | Name="VCXMLDataGeneratorTool"/> | ||
96 | <Tool | ||
97 | Name="VCManagedWrapperGeneratorTool"/> | ||
98 | <Tool | ||
99 | Name="VCAuxiliaryManagedWrapperGeneratorTool"/> | ||
100 | </Configuration> | ||
101 | <Configuration | ||
102 | Name="ReleaseNoOpt|Win32" | ||
103 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
104 | IntermediateDirectory="$(ConfigurationName)" | ||
105 | ConfigurationType="4" | ||
106 | CharacterSet="1"> | ||
107 | <Tool | ||
108 | Name="VCCLCompilerTool" | ||
109 | AdditionalOptions="/Oy-" | ||
110 | Optimization="0" | ||
111 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
112 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | ||
113 | RuntimeLibrary="0" | ||
114 | StructMemberAlignment="0" | ||
115 | ForceConformanceInForLoopScope="TRUE" | ||
116 | UsePrecompiledHeader="0" | ||
117 | BrowseInformation="0" | ||
118 | WarningLevel="3" | ||
119 | WarnAsError="TRUE" | ||
120 | Detect64BitPortabilityProblems="FALSE" | ||
121 | DebugInformationFormat="3"/> | ||
122 | <Tool | ||
123 | Name="VCCustomBuildTool"/> | ||
124 | <Tool | ||
125 | Name="VCLibrarianTool" | ||
126 | OutputFile="$(OutDir)/llmath.lib"/> | ||
127 | <Tool | ||
128 | Name="VCMIDLTool"/> | ||
129 | <Tool | ||
130 | Name="VCPostBuildEventTool"/> | ||
131 | <Tool | ||
132 | Name="VCPreBuildEventTool"/> | ||
133 | <Tool | ||
134 | Name="VCPreLinkEventTool"/> | ||
135 | <Tool | ||
136 | Name="VCResourceCompilerTool"/> | ||
137 | <Tool | ||
138 | Name="VCWebServiceProxyGeneratorTool"/> | ||
139 | <Tool | ||
140 | Name="VCXMLDataGeneratorTool"/> | ||
141 | <Tool | ||
142 | Name="VCManagedWrapperGeneratorTool"/> | ||
143 | <Tool | ||
144 | Name="VCAuxiliaryManagedWrapperGeneratorTool"/> | ||
145 | </Configuration> | ||
146 | </Configurations> | ||
147 | <References> | ||
148 | </References> | ||
149 | <Files> | ||
150 | <Filter | ||
151 | Name="Source Files" | ||
152 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
153 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}"> | ||
154 | <File | ||
155 | RelativePath=".\llbboxlocal.cpp"> | ||
156 | </File> | ||
157 | <File | ||
158 | RelativePath=".\llcamera.cpp"> | ||
159 | </File> | ||
160 | <File | ||
161 | RelativePath=".\llcoordframe.cpp"> | ||
162 | </File> | ||
163 | <File | ||
164 | RelativePath=".\llcrc.cpp"> | ||
165 | </File> | ||
166 | <File | ||
167 | RelativePath=".\llline.cpp"> | ||
168 | </File> | ||
169 | <File | ||
170 | RelativePath=".\llmd5.cpp"> | ||
171 | </File> | ||
172 | <File | ||
173 | RelativePath=".\llperlin.cpp"> | ||
174 | </File> | ||
175 | <File | ||
176 | RelativePath=".\llquaternion.cpp"> | ||
177 | </File> | ||
178 | <File | ||
179 | RelativePath=".\llrand.cpp"> | ||
180 | </File> | ||
181 | <File | ||
182 | RelativePath=".\llrect.cpp"> | ||
183 | </File> | ||
184 | <File | ||
185 | RelativePath=".\llsphere.cpp"> | ||
186 | </File> | ||
187 | <File | ||
188 | RelativePath=".\lluuid.cpp"> | ||
189 | </File> | ||
190 | <File | ||
191 | RelativePath=".\llvolume.cpp"> | ||
192 | </File> | ||
193 | <File | ||
194 | RelativePath=".\llvolumemgr.cpp"> | ||
195 | </File> | ||
196 | <File | ||
197 | RelativePath=".\m3math.cpp"> | ||
198 | </File> | ||
199 | <File | ||
200 | RelativePath=".\m4math.cpp"> | ||
201 | </File> | ||
202 | <File | ||
203 | RelativePath=".\raytrace.cpp"> | ||
204 | </File> | ||
205 | <File | ||
206 | RelativePath=".\v2math.cpp"> | ||
207 | </File> | ||
208 | <File | ||
209 | RelativePath=".\v3color.cpp"> | ||
210 | </File> | ||
211 | <File | ||
212 | RelativePath=".\v3dmath.cpp"> | ||
213 | </File> | ||
214 | <File | ||
215 | RelativePath=".\v3math.cpp"> | ||
216 | </File> | ||
217 | <File | ||
218 | RelativePath=".\v4color.cpp"> | ||
219 | </File> | ||
220 | <File | ||
221 | RelativePath=".\v4coloru.cpp"> | ||
222 | </File> | ||
223 | <File | ||
224 | RelativePath=".\v4math.cpp"> | ||
225 | </File> | ||
226 | <File | ||
227 | RelativePath=".\xform.cpp"> | ||
228 | </File> | ||
229 | </Filter> | ||
230 | <Filter | ||
231 | Name="Header Files" | ||
232 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
233 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}"> | ||
234 | <File | ||
235 | RelativePath=".\llbboxlocal.h"> | ||
236 | </File> | ||
237 | <File | ||
238 | RelativePath=".\llcamera.h"> | ||
239 | </File> | ||
240 | <File | ||
241 | RelativePath=".\llcoord.h"> | ||
242 | </File> | ||
243 | <File | ||
244 | RelativePath=".\llcoordframe.h"> | ||
245 | </File> | ||
246 | <File | ||
247 | RelativePath=".\llcrc.h"> | ||
248 | </File> | ||
249 | <File | ||
250 | RelativePath=".\llinterp.h"> | ||
251 | </File> | ||
252 | <File | ||
253 | RelativePath=".\llline.h"> | ||
254 | </File> | ||
255 | <File | ||
256 | RelativePath=".\llmath.h"> | ||
257 | </File> | ||
258 | <File | ||
259 | RelativePath=".\llmd5.h"> | ||
260 | </File> | ||
261 | <File | ||
262 | RelativePath=".\lloctree.h"> | ||
263 | </File> | ||
264 | <File | ||
265 | RelativePath=".\llperlin.h"> | ||
266 | </File> | ||
267 | <File | ||
268 | RelativePath=".\llquantize.h"> | ||
269 | </File> | ||
270 | <File | ||
271 | RelativePath=".\llquaternion.h"> | ||
272 | </File> | ||
273 | <File | ||
274 | RelativePath=".\llrand.h"> | ||
275 | </File> | ||
276 | <File | ||
277 | RelativePath=".\llrect.h"> | ||
278 | </File> | ||
279 | <File | ||
280 | RelativePath=".\llsphere.h"> | ||
281 | </File> | ||
282 | <File | ||
283 | RelativePath=".\lltreenode.h"> | ||
284 | </File> | ||
285 | <File | ||
286 | RelativePath=".\lluuid.h"> | ||
287 | </File> | ||
288 | <File | ||
289 | RelativePath=".\llv4math.h"> | ||
290 | </File> | ||
291 | <File | ||
292 | RelativePath=".\llv4matrix3.h"> | ||
293 | </File> | ||
294 | <File | ||
295 | RelativePath=".\llv4matrix4.h"> | ||
296 | </File> | ||
297 | <File | ||
298 | RelativePath=".\llv4vector3.h"> | ||
299 | </File> | ||
300 | <File | ||
301 | RelativePath=".\llvolume.h"> | ||
302 | </File> | ||
303 | <File | ||
304 | RelativePath=".\llvolumemgr.h"> | ||
305 | </File> | ||
306 | <File | ||
307 | RelativePath=".\m3math.h"> | ||
308 | </File> | ||
309 | <File | ||
310 | RelativePath=".\m4math.h"> | ||
311 | </File> | ||
312 | <File | ||
313 | RelativePath=".\raytrace.h"> | ||
314 | </File> | ||
315 | <File | ||
316 | RelativePath=".\v2math.h"> | ||
317 | </File> | ||
318 | <File | ||
319 | RelativePath=".\v3color.h"> | ||
320 | </File> | ||
321 | <File | ||
322 | RelativePath=".\v3dmath.h"> | ||
323 | </File> | ||
324 | <File | ||
325 | RelativePath=".\v3math.h"> | ||
326 | </File> | ||
327 | <File | ||
328 | RelativePath=".\v4color.h"> | ||
329 | </File> | ||
330 | <File | ||
331 | RelativePath=".\v4coloru.h"> | ||
332 | </File> | ||
333 | <File | ||
334 | RelativePath=".\v4math.h"> | ||
335 | </File> | ||
336 | <File | ||
337 | RelativePath=".\xform.h"> | ||
338 | </File> | ||
339 | </Filter> | ||
340 | <Filter | ||
341 | Name="Resource Files" | ||
342 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
343 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}"> | ||
344 | </Filter> | ||
345 | </Files> | ||
346 | <Globals> | ||
347 | </Globals> | ||
348 | </VisualStudioProject> | ||
diff --git a/linden/indra/llmath/llmath_vc8.vcproj b/linden/indra/llmath/llmath_vc8.vcproj deleted file mode 100644 index 3b4413a..0000000 --- a/linden/indra/llmath/llmath_vc8.vcproj +++ /dev/null | |||
@@ -1,488 +0,0 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="8.00" | ||
5 | Name="llmath" | ||
6 | ProjectGUID="{E87FD9BE-BE42-4EA3-BF4D-D992223046D9}" | ||
7 | RootNamespace="llmath" | ||
8 | Keyword="Win32Proj" | ||
9 | > | ||
10 | <Platforms> | ||
11 | <Platform | ||
12 | Name="Win32" | ||
13 | /> | ||
14 | </Platforms> | ||
15 | <ToolFiles> | ||
16 | </ToolFiles> | ||
17 | <Configurations> | ||
18 | <Configuration | ||
19 | Name="Debug|Win32" | ||
20 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
21 | IntermediateDirectory="$(ConfigurationName)" | ||
22 | ConfigurationType="4" | ||
23 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
24 | CharacterSet="1" | ||
25 | > | ||
26 | <Tool | ||
27 | Name="VCPreBuildEventTool" | ||
28 | /> | ||
29 | <Tool | ||
30 | Name="VCCustomBuildTool" | ||
31 | /> | ||
32 | <Tool | ||
33 | Name="VCXMLDataGeneratorTool" | ||
34 | /> | ||
35 | <Tool | ||
36 | Name="VCWebServiceProxyGeneratorTool" | ||
37 | /> | ||
38 | <Tool | ||
39 | Name="VCMIDLTool" | ||
40 | /> | ||
41 | <Tool | ||
42 | Name="VCCLCompilerTool" | ||
43 | Optimization="0" | ||
44 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
45 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" | ||
46 | MinimalRebuild="true" | ||
47 | BasicRuntimeChecks="3" | ||
48 | RuntimeLibrary="1" | ||
49 | StructMemberAlignment="4" | ||
50 | TreatWChar_tAsBuiltInType="false" | ||
51 | ForceConformanceInForLoopScope="true" | ||
52 | UsePrecompiledHeader="0" | ||
53 | WarningLevel="3" | ||
54 | WarnAsError="true" | ||
55 | Detect64BitPortabilityProblems="false" | ||
56 | DebugInformationFormat="4" | ||
57 | /> | ||
58 | <Tool | ||
59 | Name="VCManagedResourceCompilerTool" | ||
60 | /> | ||
61 | <Tool | ||
62 | Name="VCResourceCompilerTool" | ||
63 | /> | ||
64 | <Tool | ||
65 | Name="VCPreLinkEventTool" | ||
66 | /> | ||
67 | <Tool | ||
68 | Name="VCLibrarianTool" | ||
69 | OutputFile="$(OutDir)/llmath.lib" | ||
70 | /> | ||
71 | <Tool | ||
72 | Name="VCALinkTool" | ||
73 | /> | ||
74 | <Tool | ||
75 | Name="VCXDCMakeTool" | ||
76 | /> | ||
77 | <Tool | ||
78 | Name="VCBscMakeTool" | ||
79 | /> | ||
80 | <Tool | ||
81 | Name="VCFxCopTool" | ||
82 | /> | ||
83 | <Tool | ||
84 | Name="VCPostBuildEventTool" | ||
85 | /> | ||
86 | </Configuration> | ||
87 | <Configuration | ||
88 | Name="Release|Win32" | ||
89 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
90 | IntermediateDirectory="$(ConfigurationName)" | ||
91 | ConfigurationType="4" | ||
92 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
93 | CharacterSet="1" | ||
94 | > | ||
95 | <Tool | ||
96 | Name="VCPreBuildEventTool" | ||
97 | /> | ||
98 | <Tool | ||
99 | Name="VCCustomBuildTool" | ||
100 | /> | ||
101 | <Tool | ||
102 | Name="VCXMLDataGeneratorTool" | ||
103 | /> | ||
104 | <Tool | ||
105 | Name="VCWebServiceProxyGeneratorTool" | ||
106 | /> | ||
107 | <Tool | ||
108 | Name="VCMIDLTool" | ||
109 | /> | ||
110 | <Tool | ||
111 | Name="VCCLCompilerTool" | ||
112 | AdditionalOptions="/Oy-" | ||
113 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
114 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
115 | RuntimeLibrary="0" | ||
116 | StructMemberAlignment="0" | ||
117 | TreatWChar_tAsBuiltInType="false" | ||
118 | ForceConformanceInForLoopScope="true" | ||
119 | UsePrecompiledHeader="0" | ||
120 | WarningLevel="3" | ||
121 | WarnAsError="true" | ||
122 | Detect64BitPortabilityProblems="false" | ||
123 | DebugInformationFormat="3" | ||
124 | /> | ||
125 | <Tool | ||
126 | Name="VCManagedResourceCompilerTool" | ||
127 | /> | ||
128 | <Tool | ||
129 | Name="VCResourceCompilerTool" | ||
130 | /> | ||
131 | <Tool | ||
132 | Name="VCPreLinkEventTool" | ||
133 | /> | ||
134 | <Tool | ||
135 | Name="VCLibrarianTool" | ||
136 | OutputFile="$(OutDir)/llmath.lib" | ||
137 | /> | ||
138 | <Tool | ||
139 | Name="VCALinkTool" | ||
140 | /> | ||
141 | <Tool | ||
142 | Name="VCXDCMakeTool" | ||
143 | /> | ||
144 | <Tool | ||
145 | Name="VCBscMakeTool" | ||
146 | /> | ||
147 | <Tool | ||
148 | Name="VCFxCopTool" | ||
149 | /> | ||
150 | <Tool | ||
151 | Name="VCPostBuildEventTool" | ||
152 | /> | ||
153 | </Configuration> | ||
154 | <Configuration | ||
155 | Name="ReleaseNoOpt|Win32" | ||
156 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
157 | IntermediateDirectory="$(ConfigurationName)" | ||
158 | ConfigurationType="4" | ||
159 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
160 | CharacterSet="1" | ||
161 | > | ||
162 | <Tool | ||
163 | Name="VCPreBuildEventTool" | ||
164 | /> | ||
165 | <Tool | ||
166 | Name="VCCustomBuildTool" | ||
167 | /> | ||
168 | <Tool | ||
169 | Name="VCXMLDataGeneratorTool" | ||
170 | /> | ||
171 | <Tool | ||
172 | Name="VCWebServiceProxyGeneratorTool" | ||
173 | /> | ||
174 | <Tool | ||
175 | Name="VCMIDLTool" | ||
176 | /> | ||
177 | <Tool | ||
178 | Name="VCCLCompilerTool" | ||
179 | AdditionalOptions="/Oy-" | ||
180 | Optimization="0" | ||
181 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
182 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
183 | RuntimeLibrary="0" | ||
184 | StructMemberAlignment="0" | ||
185 | TreatWChar_tAsBuiltInType="false" | ||
186 | ForceConformanceInForLoopScope="true" | ||
187 | UsePrecompiledHeader="0" | ||
188 | BrowseInformation="0" | ||
189 | WarningLevel="3" | ||
190 | WarnAsError="true" | ||
191 | Detect64BitPortabilityProblems="false" | ||
192 | DebugInformationFormat="3" | ||
193 | /> | ||
194 | <Tool | ||
195 | Name="VCManagedResourceCompilerTool" | ||
196 | /> | ||
197 | <Tool | ||
198 | Name="VCResourceCompilerTool" | ||
199 | /> | ||
200 | <Tool | ||
201 | Name="VCPreLinkEventTool" | ||
202 | /> | ||
203 | <Tool | ||
204 | Name="VCLibrarianTool" | ||
205 | OutputFile="$(OutDir)/llmath.lib" | ||
206 | /> | ||
207 | <Tool | ||
208 | Name="VCALinkTool" | ||
209 | /> | ||
210 | <Tool | ||
211 | Name="VCXDCMakeTool" | ||
212 | /> | ||
213 | <Tool | ||
214 | Name="VCBscMakeTool" | ||
215 | /> | ||
216 | <Tool | ||
217 | Name="VCFxCopTool" | ||
218 | /> | ||
219 | <Tool | ||
220 | Name="VCPostBuildEventTool" | ||
221 | /> | ||
222 | </Configuration> | ||
223 | </Configurations> | ||
224 | <References> | ||
225 | </References> | ||
226 | <Files> | ||
227 | <Filter | ||
228 | Name="Source Files" | ||
229 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
230 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}" | ||
231 | > | ||
232 | <File | ||
233 | RelativePath=".\llbboxlocal.cpp" | ||
234 | > | ||
235 | </File> | ||
236 | <File | ||
237 | RelativePath=".\llcamera.cpp" | ||
238 | > | ||
239 | </File> | ||
240 | <File | ||
241 | RelativePath=".\llcoordframe.cpp" | ||
242 | > | ||
243 | </File> | ||
244 | <File | ||
245 | RelativePath=".\llcrc.cpp" | ||
246 | > | ||
247 | </File> | ||
248 | <File | ||
249 | RelativePath=".\llline.cpp" | ||
250 | > | ||
251 | </File> | ||
252 | <File | ||
253 | RelativePath=".\llmd5.cpp" | ||
254 | > | ||
255 | </File> | ||
256 | <File | ||
257 | RelativePath=".\llperlin.cpp" | ||
258 | > | ||
259 | </File> | ||
260 | <File | ||
261 | RelativePath=".\llquaternion.cpp" | ||
262 | > | ||
263 | </File> | ||
264 | <File | ||
265 | RelativePath=".\llrand.cpp" | ||
266 | > | ||
267 | </File> | ||
268 | <File | ||
269 | RelativePath=".\llrect.cpp" | ||
270 | > | ||
271 | </File> | ||
272 | <File | ||
273 | RelativePath=".\llsphere.cpp" | ||
274 | > | ||
275 | </File> | ||
276 | <File | ||
277 | RelativePath=".\lluuid.cpp" | ||
278 | > | ||
279 | </File> | ||
280 | <File | ||
281 | RelativePath=".\llvolume.cpp" | ||
282 | > | ||
283 | </File> | ||
284 | <File | ||
285 | RelativePath=".\llvolumemgr.cpp" | ||
286 | > | ||
287 | </File> | ||
288 | <File | ||
289 | RelativePath=".\m3math.cpp" | ||
290 | > | ||
291 | </File> | ||
292 | <File | ||
293 | RelativePath=".\m4math.cpp" | ||
294 | > | ||
295 | </File> | ||
296 | <File | ||
297 | RelativePath=".\raytrace.cpp" | ||
298 | > | ||
299 | </File> | ||
300 | <File | ||
301 | RelativePath=".\v2math.cpp" | ||
302 | > | ||
303 | </File> | ||
304 | <File | ||
305 | RelativePath=".\v3color.cpp" | ||
306 | > | ||
307 | </File> | ||
308 | <File | ||
309 | RelativePath=".\v3dmath.cpp" | ||
310 | > | ||
311 | </File> | ||
312 | <File | ||
313 | RelativePath=".\v3math.cpp" | ||
314 | > | ||
315 | </File> | ||
316 | <File | ||
317 | RelativePath=".\v4color.cpp" | ||
318 | > | ||
319 | </File> | ||
320 | <File | ||
321 | RelativePath=".\v4coloru.cpp" | ||
322 | > | ||
323 | </File> | ||
324 | <File | ||
325 | RelativePath=".\v4math.cpp" | ||
326 | > | ||
327 | </File> | ||
328 | <File | ||
329 | RelativePath=".\xform.cpp" | ||
330 | > | ||
331 | </File> | ||
332 | </Filter> | ||
333 | <Filter | ||
334 | Name="Header Files" | ||
335 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
336 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}" | ||
337 | > | ||
338 | <File | ||
339 | RelativePath=".\llbboxlocal.h" | ||
340 | > | ||
341 | </File> | ||
342 | <File | ||
343 | RelativePath=".\llcamera.h" | ||
344 | > | ||
345 | </File> | ||
346 | <File | ||
347 | RelativePath=".\llcoord.h" | ||
348 | > | ||
349 | </File> | ||
350 | <File | ||
351 | RelativePath=".\llcoordframe.h" | ||
352 | > | ||
353 | </File> | ||
354 | <File | ||
355 | RelativePath=".\llcrc.h" | ||
356 | > | ||
357 | </File> | ||
358 | <File | ||
359 | RelativePath=".\llinterp.h" | ||
360 | > | ||
361 | </File> | ||
362 | <File | ||
363 | RelativePath=".\llline.h" | ||
364 | > | ||
365 | </File> | ||
366 | <File | ||
367 | RelativePath=".\llmath.h" | ||
368 | > | ||
369 | </File> | ||
370 | <File | ||
371 | RelativePath=".\llmd5.h" | ||
372 | > | ||
373 | </File> | ||
374 | <File | ||
375 | RelativePath=".\lloctree.h" | ||
376 | > | ||
377 | </File> | ||
378 | <File | ||
379 | RelativePath=".\llperlin.h" | ||
380 | > | ||
381 | </File> | ||
382 | <File | ||
383 | RelativePath=".\llquantize.h" | ||
384 | > | ||
385 | </File> | ||
386 | <File | ||
387 | RelativePath=".\llquaternion.h" | ||
388 | > | ||
389 | </File> | ||
390 | <File | ||
391 | RelativePath=".\llrand.h" | ||
392 | > | ||
393 | </File> | ||
394 | <File | ||
395 | RelativePath=".\llrect.h" | ||
396 | > | ||
397 | </File> | ||
398 | <File | ||
399 | RelativePath=".\llsphere.h" | ||
400 | > | ||
401 | </File> | ||
402 | <File | ||
403 | RelativePath=".\lltreenode.h" | ||
404 | > | ||
405 | </File> | ||
406 | <File | ||
407 | RelativePath=".\lluuid.h" | ||
408 | > | ||
409 | </File> | ||
410 | <File | ||
411 | RelativePath=".\llv4math.h" | ||
412 | > | ||
413 | </File> | ||
414 | <File | ||
415 | RelativePath=".\llv4matrix3.h" | ||
416 | > | ||
417 | </File> | ||
418 | <File | ||
419 | RelativePath=".\llv4matrix4.h" | ||
420 | > | ||
421 | </File> | ||
422 | <File | ||
423 | RelativePath=".\llv4vector3.h" | ||
424 | > | ||
425 | </File> | ||
426 | <File | ||
427 | RelativePath=".\llvolume.h" | ||
428 | > | ||
429 | </File> | ||
430 | <File | ||
431 | RelativePath=".\llvolumemgr.h" | ||
432 | > | ||
433 | </File> | ||
434 | <File | ||
435 | RelativePath=".\m3math.h" | ||
436 | > | ||
437 | </File> | ||
438 | <File | ||
439 | RelativePath=".\m4math.h" | ||
440 | > | ||
441 | </File> | ||
442 | <File | ||
443 | RelativePath=".\raytrace.h" | ||
444 | > | ||
445 | </File> | ||
446 | <File | ||
447 | RelativePath=".\v2math.h" | ||
448 | > | ||
449 | </File> | ||
450 | <File | ||
451 | RelativePath=".\v3color.h" | ||
452 | > | ||
453 | </File> | ||
454 | <File | ||
455 | RelativePath=".\v3dmath.h" | ||
456 | > | ||
457 | </File> | ||
458 | <File | ||
459 | RelativePath=".\v3math.h" | ||
460 | > | ||
461 | </File> | ||
462 | <File | ||
463 | RelativePath=".\v4color.h" | ||
464 | > | ||
465 | </File> | ||
466 | <File | ||
467 | RelativePath=".\v4coloru.h" | ||
468 | > | ||
469 | </File> | ||
470 | <File | ||
471 | RelativePath=".\v4math.h" | ||
472 | > | ||
473 | </File> | ||
474 | <File | ||
475 | RelativePath=".\xform.h" | ||
476 | > | ||
477 | </File> | ||
478 | </Filter> | ||
479 | <Filter | ||
480 | Name="Resource Files" | ||
481 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
482 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||
483 | > | ||
484 | </Filter> | ||
485 | </Files> | ||
486 | <Globals> | ||
487 | </Globals> | ||
488 | </VisualStudioProject> | ||
diff --git a/linden/indra/llmath/llmath_vc9.vcproj b/linden/indra/llmath/llmath_vc9.vcproj deleted file mode 100644 index 03bc780..0000000 --- a/linden/indra/llmath/llmath_vc9.vcproj +++ /dev/null | |||
@@ -1,489 +0,0 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="9.00" | ||
5 | Name="llmath" | ||
6 | ProjectGUID="{E87FD9BE-BE42-4EA3-BF4D-D992223046D9}" | ||
7 | RootNamespace="llmath" | ||
8 | Keyword="Win32Proj" | ||
9 | TargetFrameworkVersion="131072" | ||
10 | > | ||
11 | <Platforms> | ||
12 | <Platform | ||
13 | Name="Win32" | ||
14 | /> | ||
15 | </Platforms> | ||
16 | <ToolFiles> | ||
17 | </ToolFiles> | ||
18 | <Configurations> | ||
19 | <Configuration | ||
20 | Name="Debug|Win32" | ||
21 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
22 | IntermediateDirectory="$(ConfigurationName)" | ||
23 | ConfigurationType="4" | ||
24 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
25 | CharacterSet="1" | ||
26 | > | ||
27 | <Tool | ||
28 | Name="VCPreBuildEventTool" | ||
29 | /> | ||
30 | <Tool | ||
31 | Name="VCCustomBuildTool" | ||
32 | /> | ||
33 | <Tool | ||
34 | Name="VCXMLDataGeneratorTool" | ||
35 | /> | ||
36 | <Tool | ||
37 | Name="VCWebServiceProxyGeneratorTool" | ||
38 | /> | ||
39 | <Tool | ||
40 | Name="VCMIDLTool" | ||
41 | /> | ||
42 | <Tool | ||
43 | Name="VCCLCompilerTool" | ||
44 | Optimization="0" | ||
45 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
46 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" | ||
47 | MinimalRebuild="true" | ||
48 | BasicRuntimeChecks="3" | ||
49 | RuntimeLibrary="1" | ||
50 | StructMemberAlignment="4" | ||
51 | TreatWChar_tAsBuiltInType="false" | ||
52 | ForceConformanceInForLoopScope="true" | ||
53 | UsePrecompiledHeader="0" | ||
54 | WarningLevel="3" | ||
55 | WarnAsError="true" | ||
56 | Detect64BitPortabilityProblems="false" | ||
57 | DebugInformationFormat="4" | ||
58 | /> | ||
59 | <Tool | ||
60 | Name="VCManagedResourceCompilerTool" | ||
61 | /> | ||
62 | <Tool | ||
63 | Name="VCResourceCompilerTool" | ||
64 | /> | ||
65 | <Tool | ||
66 | Name="VCPreLinkEventTool" | ||
67 | /> | ||
68 | <Tool | ||
69 | Name="VCLibrarianTool" | ||
70 | OutputFile="$(OutDir)/llmath.lib" | ||
71 | /> | ||
72 | <Tool | ||
73 | Name="VCALinkTool" | ||
74 | /> | ||
75 | <Tool | ||
76 | Name="VCXDCMakeTool" | ||
77 | /> | ||
78 | <Tool | ||
79 | Name="VCBscMakeTool" | ||
80 | /> | ||
81 | <Tool | ||
82 | Name="VCFxCopTool" | ||
83 | /> | ||
84 | <Tool | ||
85 | Name="VCPostBuildEventTool" | ||
86 | /> | ||
87 | </Configuration> | ||
88 | <Configuration | ||
89 | Name="Release|Win32" | ||
90 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
91 | IntermediateDirectory="$(ConfigurationName)" | ||
92 | ConfigurationType="4" | ||
93 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
94 | CharacterSet="1" | ||
95 | > | ||
96 | <Tool | ||
97 | Name="VCPreBuildEventTool" | ||
98 | /> | ||
99 | <Tool | ||
100 | Name="VCCustomBuildTool" | ||
101 | /> | ||
102 | <Tool | ||
103 | Name="VCXMLDataGeneratorTool" | ||
104 | /> | ||
105 | <Tool | ||
106 | Name="VCWebServiceProxyGeneratorTool" | ||
107 | /> | ||
108 | <Tool | ||
109 | Name="VCMIDLTool" | ||
110 | /> | ||
111 | <Tool | ||
112 | Name="VCCLCompilerTool" | ||
113 | AdditionalOptions="/Oy-" | ||
114 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
115 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
116 | RuntimeLibrary="0" | ||
117 | StructMemberAlignment="0" | ||
118 | TreatWChar_tAsBuiltInType="false" | ||
119 | ForceConformanceInForLoopScope="true" | ||
120 | UsePrecompiledHeader="0" | ||
121 | WarningLevel="3" | ||
122 | WarnAsError="true" | ||
123 | Detect64BitPortabilityProblems="false" | ||
124 | DebugInformationFormat="3" | ||
125 | /> | ||
126 | <Tool | ||
127 | Name="VCManagedResourceCompilerTool" | ||
128 | /> | ||
129 | <Tool | ||
130 | Name="VCResourceCompilerTool" | ||
131 | /> | ||
132 | <Tool | ||
133 | Name="VCPreLinkEventTool" | ||
134 | /> | ||
135 | <Tool | ||
136 | Name="VCLibrarianTool" | ||
137 | OutputFile="$(OutDir)/llmath.lib" | ||
138 | /> | ||
139 | <Tool | ||
140 | Name="VCALinkTool" | ||
141 | /> | ||
142 | <Tool | ||
143 | Name="VCXDCMakeTool" | ||
144 | /> | ||
145 | <Tool | ||
146 | Name="VCBscMakeTool" | ||
147 | /> | ||
148 | <Tool | ||
149 | Name="VCFxCopTool" | ||
150 | /> | ||
151 | <Tool | ||
152 | Name="VCPostBuildEventTool" | ||
153 | /> | ||
154 | </Configuration> | ||
155 | <Configuration | ||
156 | Name="ReleaseNoOpt|Win32" | ||
157 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
158 | IntermediateDirectory="$(ConfigurationName)" | ||
159 | ConfigurationType="4" | ||
160 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
161 | CharacterSet="1" | ||
162 | > | ||
163 | <Tool | ||
164 | Name="VCPreBuildEventTool" | ||
165 | /> | ||
166 | <Tool | ||
167 | Name="VCCustomBuildTool" | ||
168 | /> | ||
169 | <Tool | ||
170 | Name="VCXMLDataGeneratorTool" | ||
171 | /> | ||
172 | <Tool | ||
173 | Name="VCWebServiceProxyGeneratorTool" | ||
174 | /> | ||
175 | <Tool | ||
176 | Name="VCMIDLTool" | ||
177 | /> | ||
178 | <Tool | ||
179 | Name="VCCLCompilerTool" | ||
180 | AdditionalOptions="/Oy-" | ||
181 | Optimization="0" | ||
182 | AdditionalIncludeDirectories="..\llcommon;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
183 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
184 | RuntimeLibrary="0" | ||
185 | StructMemberAlignment="0" | ||
186 | TreatWChar_tAsBuiltInType="false" | ||
187 | ForceConformanceInForLoopScope="true" | ||
188 | UsePrecompiledHeader="0" | ||
189 | BrowseInformation="0" | ||
190 | WarningLevel="3" | ||
191 | WarnAsError="true" | ||
192 | Detect64BitPortabilityProblems="false" | ||
193 | DebugInformationFormat="3" | ||
194 | /> | ||
195 | <Tool | ||
196 | Name="VCManagedResourceCompilerTool" | ||
197 | /> | ||
198 | <Tool | ||
199 | Name="VCResourceCompilerTool" | ||
200 | /> | ||
201 | <Tool | ||
202 | Name="VCPreLinkEventTool" | ||
203 | /> | ||
204 | <Tool | ||
205 | Name="VCLibrarianTool" | ||
206 | OutputFile="$(OutDir)/llmath.lib" | ||
207 | /> | ||
208 | <Tool | ||
209 | Name="VCALinkTool" | ||
210 | /> | ||
211 | <Tool | ||
212 | Name="VCXDCMakeTool" | ||
213 | /> | ||
214 | <Tool | ||
215 | Name="VCBscMakeTool" | ||
216 | /> | ||
217 | <Tool | ||
218 | Name="VCFxCopTool" | ||
219 | /> | ||
220 | <Tool | ||
221 | Name="VCPostBuildEventTool" | ||
222 | /> | ||
223 | </Configuration> | ||
224 | </Configurations> | ||
225 | <References> | ||
226 | </References> | ||
227 | <Files> | ||
228 | <Filter | ||
229 | Name="Source Files" | ||
230 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
231 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}" | ||
232 | > | ||
233 | <File | ||
234 | RelativePath=".\llbboxlocal.cpp" | ||
235 | > | ||
236 | </File> | ||
237 | <File | ||
238 | RelativePath=".\llcamera.cpp" | ||
239 | > | ||
240 | </File> | ||
241 | <File | ||
242 | RelativePath=".\llcoordframe.cpp" | ||
243 | > | ||
244 | </File> | ||
245 | <File | ||
246 | RelativePath=".\llcrc.cpp" | ||
247 | > | ||
248 | </File> | ||
249 | <File | ||
250 | RelativePath=".\llline.cpp" | ||
251 | > | ||
252 | </File> | ||
253 | <File | ||
254 | RelativePath=".\llmd5.cpp" | ||
255 | > | ||
256 | </File> | ||
257 | <File | ||
258 | RelativePath=".\llperlin.cpp" | ||
259 | > | ||
260 | </File> | ||
261 | <File | ||
262 | RelativePath=".\llquaternion.cpp" | ||
263 | > | ||
264 | </File> | ||
265 | <File | ||
266 | RelativePath=".\llrand.cpp" | ||
267 | > | ||
268 | </File> | ||
269 | <File | ||
270 | RelativePath=".\llrect.cpp" | ||
271 | > | ||
272 | </File> | ||
273 | <File | ||
274 | RelativePath=".\llsphere.cpp" | ||
275 | > | ||
276 | </File> | ||
277 | <File | ||
278 | RelativePath=".\lluuid.cpp" | ||
279 | > | ||
280 | </File> | ||
281 | <File | ||
282 | RelativePath=".\llvolume.cpp" | ||
283 | > | ||
284 | </File> | ||
285 | <File | ||
286 | RelativePath=".\llvolumemgr.cpp" | ||
287 | > | ||
288 | </File> | ||
289 | <File | ||
290 | RelativePath=".\m3math.cpp" | ||
291 | > | ||
292 | </File> | ||
293 | <File | ||
294 | RelativePath=".\m4math.cpp" | ||
295 | > | ||
296 | </File> | ||
297 | <File | ||
298 | RelativePath=".\raytrace.cpp" | ||
299 | > | ||
300 | </File> | ||
301 | <File | ||
302 | RelativePath=".\v2math.cpp" | ||
303 | > | ||
304 | </File> | ||
305 | <File | ||
306 | RelativePath=".\v3color.cpp" | ||
307 | > | ||
308 | </File> | ||
309 | <File | ||
310 | RelativePath=".\v3dmath.cpp" | ||
311 | > | ||
312 | </File> | ||
313 | <File | ||
314 | RelativePath=".\v3math.cpp" | ||
315 | > | ||
316 | </File> | ||
317 | <File | ||
318 | RelativePath=".\v4color.cpp" | ||
319 | > | ||
320 | </File> | ||
321 | <File | ||
322 | RelativePath=".\v4coloru.cpp" | ||
323 | > | ||
324 | </File> | ||
325 | <File | ||
326 | RelativePath=".\v4math.cpp" | ||
327 | > | ||
328 | </File> | ||
329 | <File | ||
330 | RelativePath=".\xform.cpp" | ||
331 | > | ||
332 | </File> | ||
333 | </Filter> | ||
334 | <Filter | ||
335 | Name="Header Files" | ||
336 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
337 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}" | ||
338 | > | ||
339 | <File | ||
340 | RelativePath=".\llbboxlocal.h" | ||
341 | > | ||
342 | </File> | ||
343 | <File | ||
344 | RelativePath=".\llcamera.h" | ||
345 | > | ||
346 | </File> | ||
347 | <File | ||
348 | RelativePath=".\llcoord.h" | ||
349 | > | ||
350 | </File> | ||
351 | <File | ||
352 | RelativePath=".\llcoordframe.h" | ||
353 | > | ||
354 | </File> | ||
355 | <File | ||
356 | RelativePath=".\llcrc.h" | ||
357 | > | ||
358 | </File> | ||
359 | <File | ||
360 | RelativePath=".\llinterp.h" | ||
361 | > | ||
362 | </File> | ||
363 | <File | ||
364 | RelativePath=".\llline.h" | ||
365 | > | ||
366 | </File> | ||
367 | <File | ||
368 | RelativePath=".\llmath.h" | ||
369 | > | ||
370 | </File> | ||
371 | <File | ||
372 | RelativePath=".\llmd5.h" | ||
373 | > | ||
374 | </File> | ||
375 | <File | ||
376 | RelativePath=".\lloctree.h" | ||
377 | > | ||
378 | </File> | ||
379 | <File | ||
380 | RelativePath=".\llperlin.h" | ||
381 | > | ||
382 | </File> | ||
383 | <File | ||
384 | RelativePath=".\llquantize.h" | ||
385 | > | ||
386 | </File> | ||
387 | <File | ||
388 | RelativePath=".\llquaternion.h" | ||
389 | > | ||
390 | </File> | ||
391 | <File | ||
392 | RelativePath=".\llrand.h" | ||
393 | > | ||
394 | </File> | ||
395 | <File | ||
396 | RelativePath=".\llrect.h" | ||
397 | > | ||
398 | </File> | ||
399 | <File | ||
400 | RelativePath=".\llsphere.h" | ||
401 | > | ||
402 | </File> | ||
403 | <File | ||
404 | RelativePath=".\lltreenode.h" | ||
405 | > | ||
406 | </File> | ||
407 | <File | ||
408 | RelativePath=".\lluuid.h" | ||
409 | > | ||
410 | </File> | ||
411 | <File | ||
412 | RelativePath=".\llv4math.h" | ||
413 | > | ||
414 | </File> | ||
415 | <File | ||
416 | RelativePath=".\llv4matrix3.h" | ||
417 | > | ||
418 | </File> | ||
419 | <File | ||
420 | RelativePath=".\llv4matrix4.h" | ||
421 | > | ||
422 | </File> | ||
423 | <File | ||
424 | RelativePath=".\llv4vector3.h" | ||
425 | > | ||
426 | </File> | ||
427 | <File | ||
428 | RelativePath=".\llvolume.h" | ||
429 | > | ||
430 | </File> | ||
431 | <File | ||
432 | RelativePath=".\llvolumemgr.h" | ||
433 | > | ||
434 | </File> | ||
435 | <File | ||
436 | RelativePath=".\m3math.h" | ||
437 | > | ||
438 | </File> | ||
439 | <File | ||
440 | RelativePath=".\m4math.h" | ||
441 | > | ||
442 | </File> | ||
443 | <File | ||
444 | RelativePath=".\raytrace.h" | ||
445 | > | ||
446 | </File> | ||
447 | <File | ||
448 | RelativePath=".\v2math.h" | ||
449 | > | ||
450 | </File> | ||
451 | <File | ||
452 | RelativePath=".\v3color.h" | ||
453 | > | ||
454 | </File> | ||
455 | <File | ||
456 | RelativePath=".\v3dmath.h" | ||
457 | > | ||
458 | </File> | ||
459 | <File | ||
460 | RelativePath=".\v3math.h" | ||
461 | > | ||
462 | </File> | ||
463 | <File | ||
464 | RelativePath=".\v4color.h" | ||
465 | > | ||
466 | </File> | ||
467 | <File | ||
468 | RelativePath=".\v4coloru.h" | ||
469 | > | ||
470 | </File> | ||
471 | <File | ||
472 | RelativePath=".\v4math.h" | ||
473 | > | ||
474 | </File> | ||
475 | <File | ||
476 | RelativePath=".\xform.h" | ||
477 | > | ||
478 | </File> | ||
479 | </Filter> | ||
480 | <Filter | ||
481 | Name="Resource Files" | ||
482 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
483 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||
484 | > | ||
485 | </Filter> | ||
486 | </Files> | ||
487 | <Globals> | ||
488 | </Globals> | ||
489 | </VisualStudioProject> | ||
diff --git a/linden/indra/llmath/llmd5.cpp b/linden/indra/llmath/llmd5.cpp deleted file mode 100644 index ea69002..0000000 --- a/linden/indra/llmath/llmd5.cpp +++ /dev/null | |||
@@ -1,531 +0,0 @@ | |||
1 | /** | ||
2 | * @file llmd5.cpp | ||
3 | * | ||
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | ||
5 | * | ||
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | ||
7 | * | ||
8 | * Second Life Viewer Source Code | ||
9 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
10 | * to you under the terms of the GNU General Public License, version 2.0 | ||
11 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
12 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
13 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
14 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
15 | * | ||
16 | * There are special exceptions to the terms and conditions of the GPL as | ||
17 | * it is applied to this Source Code. View the full text of the exception | ||
18 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
19 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
20 | * | ||
21 | * By copying, modifying or distributing this software, you acknowledge | ||
22 | * that you have read and understood your obligations described above, | ||
23 | * and agree to abide by those obligations. | ||
24 | * | ||
25 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
26 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
27 | * COMPLETENESS OR PERFORMANCE. | ||
28 | * $/LicenseInfo$ | ||
29 | */ | ||
30 | |||
31 | // llMD5.CC - source code for the C++/object oriented translation and | ||
32 | // modification of MD5. | ||
33 | // | ||
34 | // Adapted to Linden Lab by Frank Filipanits, 6/25/2002 | ||
35 | // Fixed potential memory leak, James Cook, 6/27/2002 | ||
36 | |||
37 | // Translation and modification (c) 1995 by Mordechai T. Abzug | ||
38 | |||
39 | // This translation/ modification is provided "as is," without express or | ||
40 | // implied warranty of any kind. | ||
41 | |||
42 | // The translator/ modifier does not claim (1) that MD5 will do what you think | ||
43 | // it does; (2) that this translation/ modification is accurate; or (3) that | ||
44 | // this software is "merchantible." (Language for this disclaimer partially | ||
45 | // copied from the disclaimer below). | ||
46 | |||
47 | /* based on: | ||
48 | |||
49 | MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm | ||
50 | MDDRIVER.C - test driver for MD2, MD4 and MD5 | ||
51 | |||
52 | |||
53 | Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All | ||
54 | rights reserved. | ||
55 | |||
56 | License to copy and use this software is granted provided that it | ||
57 | is identified as the "RSA Data Security, Inc. MD5 Message-Digest | ||
58 | Algorithm" in all material mentioning or referencing this software | ||
59 | or this function. | ||
60 | |||
61 | License is also granted to make and use derivative works provided | ||
62 | that such works are identified as "derived from the RSA Data | ||
63 | Security, Inc. MD5 Message-Digest Algorithm" in all material | ||
64 | mentioning or referencing the derived work. | ||
65 | |||
66 | RSA Data Security, Inc. makes no representations concerning either | ||
67 | the merchantability of this software or the suitability of this | ||
68 | software for any particular purpose. It is provided "as is" | ||
69 | without express or implied warranty of any kind. | ||
70 | |||
71 | These notices must be retained in any copies of any part of this | ||
72 | documentation and/or software. | ||
73 | |||
74 | */ | ||
75 | |||
76 | |||
77 | |||
78 | |||
79 | |||
80 | #include "linden_common.h" | ||
81 | |||
82 | #include "llmd5.h" | ||
83 | |||
84 | #include <cassert> | ||
85 | |||
86 | // how many bytes to grab at a time when checking files | ||
87 | const int LLMD5::BLOCK_LEN = 4096; | ||
88 | |||
89 | |||
90 | // LLMD5 simple initialization method | ||
91 | |||
92 | LLMD5::LLMD5() | ||
93 | { | ||
94 | init(); | ||
95 | } | ||
96 | |||
97 | |||
98 | |||
99 | |||
100 | // MD5 block update operation. Continues an MD5 message-digest | ||
101 | // operation, processing another message block, and updating the | ||
102 | // context. | ||
103 | |||
104 | void LLMD5::update (const uint1 *input, const uint4 input_length) { | ||
105 | |||
106 | uint4 input_index, buffer_index; | ||
107 | uint4 buffer_space; // how much space is left in buffer | ||
108 | |||
109 | if (finalized){ // so we can't update! | ||
110 | std::cerr << "LLMD5::update: Can't update a finalized digest!" << std::endl; | ||
111 | return; | ||
112 | } | ||
113 | |||
114 | // Compute number of bytes mod 64 | ||
115 | buffer_index = (unsigned int)((count[0] >> 3) & 0x3F); | ||
116 | |||
117 | // Update number of bits | ||
118 | if ( (count[0] += ((uint4) input_length << 3))<((uint4) input_length << 3) ) | ||
119 | count[1]++; | ||
120 | |||
121 | count[1] += ((uint4)input_length >> 29); | ||
122 | |||
123 | |||
124 | buffer_space = 64 - buffer_index; // how much space is left in buffer | ||
125 | |||
126 | // Transform as many times as possible. | ||
127 | if (input_length >= buffer_space) { // ie. we have enough to fill the buffer | ||
128 | // fill the rest of the buffer and transform | ||
129 | memcpy( /* Flawfinder: ignore */ | ||
130 | buffer + buffer_index, | ||
131 | input, | ||
132 | buffer_space); | ||
133 | transform (buffer); | ||
134 | |||
135 | // now, transform each 64-byte piece of the input, bypassing the buffer | ||
136 | if (input == NULL || input_length == 0){ | ||
137 | std::cerr << "LLMD5::update: Invalid input!" << std::endl; | ||
138 | return; | ||
139 | } | ||
140 | |||
141 | for (input_index = buffer_space; input_index + 63 < input_length; | ||
142 | input_index += 64) | ||
143 | transform (input+input_index); | ||
144 | |||
145 | buffer_index = 0; // so we can buffer remaining | ||
146 | } | ||
147 | else | ||
148 | input_index=0; // so we can buffer the whole input | ||
149 | |||
150 | |||
151 | // and here we do the buffering: | ||
152 | memcpy(buffer+buffer_index, input+input_index, input_length-input_index); /* Flawfinder: ignore */ | ||
153 | } | ||
154 | |||
155 | |||
156 | |||
157 | // MD5 update for files. | ||
158 | // Like above, except that it works on files (and uses above as a primitive.) | ||
159 | |||
160 | void LLMD5::update(LLFILE* file){ | ||
161 | |||
162 | unsigned char buffer[BLOCK_LEN]; /* Flawfinder: ignore */ | ||
163 | int len; | ||
164 | |||
165 | while ( (len=(int)fread(buffer, 1, BLOCK_LEN, file)) ) | ||
166 | update(buffer, len); | ||
167 | |||
168 | fclose (file); | ||
169 | |||
170 | } | ||
171 | |||
172 | |||
173 | |||
174 | |||
175 | |||
176 | |||
177 | // MD5 update for istreams. | ||
178 | // Like update for files; see above. | ||
179 | |||
180 | void LLMD5::update(std::istream& stream){ | ||
181 | |||
182 | unsigned char buffer[BLOCK_LEN]; /* Flawfinder: ignore */ | ||
183 | int len; | ||
184 | |||
185 | while (stream.good()){ | ||
186 | stream.read( (char*)buffer, BLOCK_LEN); /* Flawfinder: ignore */ // note that return value of read is unusable. | ||
187 | len=stream.gcount(); | ||
188 | update(buffer, len); | ||
189 | } | ||
190 | |||
191 | } | ||
192 | |||
193 | |||
194 | |||
195 | |||
196 | |||
197 | // MD5 finalization. Ends an MD5 message-digest operation, writing the | ||
198 | // the message digest and zeroizing the context. | ||
199 | |||
200 | |||
201 | void LLMD5::finalize (){ | ||
202 | |||
203 | unsigned char bits[8]; /* Flawfinder: ignore */ | ||
204 | unsigned int index, padLen; | ||
205 | static uint1 PADDING[64]={ | ||
206 | 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||
207 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||
208 | 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 | ||
209 | }; | ||
210 | |||
211 | if (finalized){ | ||
212 | std::cerr << "LLMD5::finalize: Already finalized this digest!" << std::endl; | ||
213 | return; | ||
214 | } | ||
215 | |||
216 | // Save number of bits | ||
217 | encode (bits, count, 8); | ||
218 | |||
219 | // Pad out to 56 mod 64. | ||
220 | index = (uint4) ((count[0] >> 3) & 0x3f); | ||
221 | padLen = (index < 56) ? (56 - index) : (120 - index); | ||
222 | update (PADDING, padLen); | ||
223 | |||
224 | // Append length (before padding) | ||
225 | update (bits, 8); | ||
226 | |||
227 | // Store state in digest | ||
228 | encode (digest, state, 16); | ||
229 | |||
230 | // Zeroize sensitive information | ||
231 | memset (buffer, 0, sizeof(*buffer)); | ||
232 | |||
233 | finalized=1; | ||
234 | |||
235 | } | ||
236 | |||
237 | |||
238 | |||
239 | |||
240 | LLMD5::LLMD5(LLFILE *file){ | ||
241 | |||
242 | init(); // must be called be all constructors | ||
243 | update(file); | ||
244 | finalize (); | ||
245 | } | ||
246 | |||
247 | |||
248 | |||
249 | |||
250 | LLMD5::LLMD5(std::istream& stream){ | ||
251 | |||
252 | init(); // must called by all constructors | ||
253 | update (stream); | ||
254 | finalize(); | ||
255 | } | ||
256 | |||
257 | // Digest a string of the format ("%s:%i" % (s, number)) | ||
258 | LLMD5::LLMD5(const unsigned char *string, const unsigned int number) | ||
259 | { | ||
260 | const char *colon = ":"; | ||
261 | char tbuf[16]; /* Flawfinder: ignore */ | ||
262 | init(); | ||
263 | update(string, (U32)strlen((const char *) string)); /* Flawfinder: ignore */ | ||
264 | update((const unsigned char *) colon, (U32)strlen(colon)); /* Flawfinder: ignore */ | ||
265 | snprintf(tbuf, sizeof(tbuf), "%i", number); /* Flawfinder: ignore */ | ||
266 | update((const unsigned char *) tbuf, (U32)strlen(tbuf)); /* Flawfinder: ignore */ | ||
267 | finalize(); | ||
268 | } | ||
269 | |||
270 | // Digest a string | ||
271 | LLMD5::LLMD5(const unsigned char *s) | ||
272 | { | ||
273 | init(); | ||
274 | update(s, (U32)strlen((const char *) s)); /* Flawfinder: ignore */ | ||
275 | finalize(); | ||
276 | } | ||
277 | |||
278 | void LLMD5::raw_digest(unsigned char *s) | ||
279 | { | ||
280 | if (!finalized) | ||
281 | { | ||
282 | std::cerr << "LLMD5::raw_digest: Can't get digest if you haven't "<< | ||
283 | "finalized the digest!" << std::endl; | ||
284 | s[0] = '\0'; | ||
285 | return; | ||
286 | } | ||
287 | |||
288 | memcpy(s, digest, 16); /* Flawfinder: ignore */ | ||
289 | return; | ||
290 | } | ||
291 | |||
292 | |||
293 | |||
294 | void LLMD5::hex_digest(char *s) | ||
295 | { | ||
296 | int i; | ||
297 | |||
298 | if (!finalized) | ||
299 | { | ||
300 | std::cerr << "LLMD5::hex_digest: Can't get digest if you haven't "<< | ||
301 | "finalized the digest!" <<std::endl; | ||
302 | s[0] = '\0'; | ||
303 | return; | ||
304 | } | ||
305 | |||
306 | for (i=0; i<16; i++) | ||
307 | { | ||
308 | sprintf(s+i*2, "%02x", digest[i]); /* Flawfinder: ignore */ | ||
309 | } | ||
310 | |||
311 | s[32]='\0'; | ||
312 | |||
313 | return; | ||
314 | } | ||
315 | |||
316 | |||
317 | |||
318 | |||
319 | |||
320 | std::ostream& operator<<(std::ostream &stream, LLMD5 context) | ||
321 | { | ||
322 | char s[33]; /* Flawfinder: ignore */ | ||
323 | context.hex_digest(s); | ||
324 | stream << s; | ||
325 | return stream; | ||
326 | } | ||
327 | |||
328 | |||
329 | |||
330 | |||
331 | // PRIVATE METHODS: | ||
332 | |||
333 | |||
334 | |||
335 | void LLMD5::init(){ | ||
336 | finalized=0; // we just started! | ||
337 | |||
338 | // Nothing counted, so count=0 | ||
339 | count[0] = 0; | ||
340 | count[1] = 0; | ||
341 | |||
342 | // Load magic initialization constants. | ||
343 | state[0] = 0x67452301; | ||
344 | state[1] = 0xefcdab89; | ||
345 | state[2] = 0x98badcfe; | ||
346 | state[3] = 0x10325476; | ||
347 | } | ||
348 | |||
349 | |||
350 | |||
351 | // Constants for MD5Transform routine. | ||
352 | // Although we could use C++ style constants, defines are actually better, | ||
353 | // since they let us easily evade scope clashes. | ||
354 | |||
355 | #define S11 7 | ||
356 | #define S12 12 | ||
357 | #define S13 17 | ||
358 | #define S14 22 | ||
359 | #define S21 5 | ||
360 | #define S22 9 | ||
361 | #define S23 14 | ||
362 | #define S24 20 | ||
363 | #define S31 4 | ||
364 | #define S32 11 | ||
365 | #define S33 16 | ||
366 | #define S34 23 | ||
367 | #define S41 6 | ||
368 | #define S42 10 | ||
369 | #define S43 15 | ||
370 | #define S44 21 | ||
371 | |||
372 | // #defines are faster then inline, etc because the compiler is not required to inline. | ||
373 | // Timing tests prove that this works ~40% faster on win with msvc++2k3 over using static inline. | ||
374 | |||
375 | /* F, G, H and I are basic MD5 functions. | ||
376 | */ | ||
377 | #define F(x, y, z) (((x) & (y)) | ((~x) & (z))) | ||
378 | #define G(x, y, z) (((x) & (z)) | ((y) & (~z))) | ||
379 | #define H(x, y, z) ((x) ^ (y) ^ (z)) | ||
380 | #define I(x, y, z) ((y) ^ ((x) | (~z))) | ||
381 | |||
382 | /* ROTATE_LEFT rotates x left n bits. | ||
383 | */ | ||
384 | #define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n)))) | ||
385 | |||
386 | /* FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4. | ||
387 | Rotation is separate from addition to prevent recomputation. | ||
388 | */ | ||
389 | #define FF(a, b, c, d, x, s, ac) { \ | ||
390 | (a) += F ((b), (c), (d)) + (x) + (U32)(ac); \ | ||
391 | (a) = ROTATE_LEFT ((a), (s)); \ | ||
392 | (a) += (b); \ | ||
393 | } | ||
394 | #define GG(a, b, c, d, x, s, ac) { \ | ||
395 | (a) += G ((b), (c), (d)) + (x) + (U32)(ac); \ | ||
396 | (a) = ROTATE_LEFT ((a), (s)); \ | ||
397 | (a) += (b); \ | ||
398 | } | ||
399 | #define HH(a, b, c, d, x, s, ac) { \ | ||
400 | (a) += H ((b), (c), (d)) + (x) + (U32)(ac); \ | ||
401 | (a) = ROTATE_LEFT ((a), (s)); \ | ||
402 | (a) += (b); \ | ||
403 | } | ||
404 | #define II(a, b, c, d, x, s, ac) { \ | ||
405 | (a) += I ((b), (c), (d)) + (x) + (U32)(ac); \ | ||
406 | (a) = ROTATE_LEFT ((a), (s)); \ | ||
407 | (a) += (b); \ | ||
408 | } | ||
409 | |||
410 | |||
411 | |||
412 | // LLMD5 basic transformation. Transforms state based on block. | ||
413 | void LLMD5::transform (const U8 block[64]){ | ||
414 | |||
415 | uint4 a = state[0], b = state[1], c = state[2], d = state[3], x[16]; | ||
416 | |||
417 | decode (x, block, 64); | ||
418 | |||
419 | assert(!finalized); // not just a user error, since the method is private | ||
420 | |||
421 | /* Round 1 */ | ||
422 | FF (a, b, c, d, x[ 0], S11, 0xd76aa478); /* 1 */ | ||
423 | FF (d, a, b, c, x[ 1], S12, 0xe8c7b756); /* 2 */ | ||
424 | FF (c, d, a, b, x[ 2], S13, 0x242070db); /* 3 */ | ||
425 | FF (b, c, d, a, x[ 3], S14, 0xc1bdceee); /* 4 */ | ||
426 | FF (a, b, c, d, x[ 4], S11, 0xf57c0faf); /* 5 */ | ||
427 | FF (d, a, b, c, x[ 5], S12, 0x4787c62a); /* 6 */ | ||
428 | FF (c, d, a, b, x[ 6], S13, 0xa8304613); /* 7 */ | ||
429 | FF (b, c, d, a, x[ 7], S14, 0xfd469501); /* 8 */ | ||
430 | FF (a, b, c, d, x[ 8], S11, 0x698098d8); /* 9 */ | ||
431 | FF (d, a, b, c, x[ 9], S12, 0x8b44f7af); /* 10 */ | ||
432 | FF (c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */ | ||
433 | FF (b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */ | ||
434 | FF (a, b, c, d, x[12], S11, 0x6b901122); /* 13 */ | ||
435 | FF (d, a, b, c, x[13], S12, 0xfd987193); /* 14 */ | ||
436 | FF (c, d, a, b, x[14], S13, 0xa679438e); /* 15 */ | ||
437 | FF (b, c, d, a, x[15], S14, 0x49b40821); /* 16 */ | ||
438 | |||
439 | /* Round 2 */ | ||
440 | GG (a, b, c, d, x[ 1], S21, 0xf61e2562); /* 17 */ | ||
441 | GG (d, a, b, c, x[ 6], S22, 0xc040b340); /* 18 */ | ||
442 | GG (c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */ | ||
443 | GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa); /* 20 */ | ||
444 | GG (a, b, c, d, x[ 5], S21, 0xd62f105d); /* 21 */ | ||
445 | GG (d, a, b, c, x[10], S22, 0x2441453); /* 22 */ | ||
446 | GG (c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */ | ||
447 | GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8); /* 24 */ | ||
448 | GG (a, b, c, d, x[ 9], S21, 0x21e1cde6); /* 25 */ | ||
449 | GG (d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */ | ||
450 | GG (c, d, a, b, x[ 3], S23, 0xf4d50d87); /* 27 */ | ||
451 | GG (b, c, d, a, x[ 8], S24, 0x455a14ed); /* 28 */ | ||
452 | GG (a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */ | ||
453 | GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8); /* 30 */ | ||
454 | GG (c, d, a, b, x[ 7], S23, 0x676f02d9); /* 31 */ | ||
455 | GG (b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */ | ||
456 | |||
457 | /* Round 3 */ | ||
458 | HH (a, b, c, d, x[ 5], S31, 0xfffa3942); /* 33 */ | ||
459 | HH (d, a, b, c, x[ 8], S32, 0x8771f681); /* 34 */ | ||
460 | HH (c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */ | ||
461 | HH (b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */ | ||
462 | HH (a, b, c, d, x[ 1], S31, 0xa4beea44); /* 37 */ | ||
463 | HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9); /* 38 */ | ||
464 | HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60); /* 39 */ | ||
465 | HH (b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */ | ||
466 | HH (a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */ | ||
467 | HH (d, a, b, c, x[ 0], S32, 0xeaa127fa); /* 42 */ | ||
468 | HH (c, d, a, b, x[ 3], S33, 0xd4ef3085); /* 43 */ | ||
469 | HH (b, c, d, a, x[ 6], S34, 0x4881d05); /* 44 */ | ||
470 | HH (a, b, c, d, x[ 9], S31, 0xd9d4d039); /* 45 */ | ||
471 | HH (d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */ | ||
472 | HH (c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */ | ||
473 | HH (b, c, d, a, x[ 2], S34, 0xc4ac5665); /* 48 */ | ||
474 | |||
475 | /* Round 4 */ | ||
476 | II (a, b, c, d, x[ 0], S41, 0xf4292244); /* 49 */ | ||
477 | II (d, a, b, c, x[ 7], S42, 0x432aff97); /* 50 */ | ||
478 | II (c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */ | ||
479 | II (b, c, d, a, x[ 5], S44, 0xfc93a039); /* 52 */ | ||
480 | II (a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */ | ||
481 | II (d, a, b, c, x[ 3], S42, 0x8f0ccc92); /* 54 */ | ||
482 | II (c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */ | ||
483 | II (b, c, d, a, x[ 1], S44, 0x85845dd1); /* 56 */ | ||
484 | II (a, b, c, d, x[ 8], S41, 0x6fa87e4f); /* 57 */ | ||
485 | II (d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */ | ||
486 | II (c, d, a, b, x[ 6], S43, 0xa3014314); /* 59 */ | ||
487 | II (b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */ | ||
488 | II (a, b, c, d, x[ 4], S41, 0xf7537e82); /* 61 */ | ||
489 | II (d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */ | ||
490 | II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb); /* 63 */ | ||
491 | II (b, c, d, a, x[ 9], S44, 0xeb86d391); /* 64 */ | ||
492 | |||
493 | state[0] += a; | ||
494 | state[1] += b; | ||
495 | state[2] += c; | ||
496 | state[3] += d; | ||
497 | |||
498 | // Zeroize sensitive information. | ||
499 | memset ( (uint1 *) x, 0, sizeof(x)); | ||
500 | |||
501 | } | ||
502 | |||
503 | |||
504 | |||
505 | // Encodes input (UINT4) into output (unsigned char). Assumes len is | ||
506 | // a multiple of 4. | ||
507 | void LLMD5::encode (uint1 *output, const uint4 *input, const uint4 len) { | ||
508 | |||
509 | unsigned int i, j; | ||
510 | |||
511 | for (i = 0, j = 0; j < len; i++, j += 4) { | ||
512 | output[j] = (uint1) (input[i] & 0xff); | ||
513 | output[j+1] = (uint1) ((input[i] >> 8) & 0xff); | ||
514 | output[j+2] = (uint1) ((input[i] >> 16) & 0xff); | ||
515 | output[j+3] = (uint1) ((input[i] >> 24) & 0xff); | ||
516 | } | ||
517 | } | ||
518 | |||
519 | |||
520 | |||
521 | |||
522 | // Decodes input (unsigned char) into output (UINT4). Assumes len is | ||
523 | // a multiple of 4. | ||
524 | void LLMD5::decode (uint4 *output, const uint1 *input, const uint4 len){ | ||
525 | |||
526 | unsigned int i, j; | ||
527 | |||
528 | for (i = 0, j = 0; j < len; i++, j += 4) | ||
529 | output[i] = ((uint4)input[j]) | (((uint4)input[j+1]) << 8) | | ||
530 | (((uint4)input[j+2]) << 16) | (((uint4)input[j+3]) << 24); | ||
531 | } | ||
diff --git a/linden/indra/llmath/llmd5.h b/linden/indra/llmath/llmd5.h deleted file mode 100644 index 9ba0a9f..0000000 --- a/linden/indra/llmath/llmd5.h +++ /dev/null | |||
@@ -1,133 +0,0 @@ | |||
1 | /** | ||
2 | * @file llmd5.h | ||
3 | * | ||
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | ||
5 | * | ||
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | ||
7 | * | ||
8 | * Second Life Viewer Source Code | ||
9 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
10 | * to you under the terms of the GNU General Public License, version 2.0 | ||
11 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
12 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
13 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
14 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
15 | * | ||
16 | * There are special exceptions to the terms and conditions of the GPL as | ||
17 | * it is applied to this Source Code. View the full text of the exception | ||
18 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
19 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
20 | * | ||
21 | * By copying, modifying or distributing this software, you acknowledge | ||
22 | * that you have read and understood your obligations described above, | ||
23 | * and agree to abide by those obligations. | ||
24 | * | ||
25 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
26 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
27 | * COMPLETENESS OR PERFORMANCE. | ||
28 | * $/LicenseInfo$ | ||
29 | */ | ||
30 | |||
31 | #ifndef LL_LLMD5_H | ||
32 | #define LL_LLMD5_H | ||
33 | |||
34 | // LLMD5.CC - source code for the C++/object oriented translation and | ||
35 | // modification of MD5. | ||
36 | |||
37 | // Translation and modification (c) 1995 by Mordechai T. Abzug | ||
38 | |||
39 | // This translation/ modification is provided "as is," without express or | ||
40 | // implied warranty of any kind. | ||
41 | |||
42 | // The translator/ modifier does not claim (1) that MD5 will do what you think | ||
43 | // it does; (2) that this translation/ modification is accurate; or (3) that | ||
44 | // this software is "merchantible." (Language for this disclaimer partially | ||
45 | // copied from the disclaimer below). | ||
46 | |||
47 | /* based on: | ||
48 | |||
49 | MD5.H - header file for MD5C.C | ||
50 | MDDRIVER.C - test driver for MD2, MD4 and MD5 | ||
51 | |||
52 | Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All | ||
53 | rights reserved. | ||
54 | |||
55 | License to copy and use this software is granted provided that it | ||
56 | is identified as the "RSA Data Security, Inc. MD5 Message-Digest | ||
57 | Algorithm" in all material mentioning or referencing this software | ||
58 | or this function. | ||
59 | |||
60 | License is also granted to make and use derivative works provided | ||
61 | that such works are identified as "derived from the RSA Data | ||
62 | Security, Inc. MD5 Message-Digest Algorithm" in all material | ||
63 | mentioning or referencing the derived work. | ||
64 | |||
65 | RSA Data Security, Inc. makes no representations concerning either | ||
66 | the merchantability of this software or the suitability of this | ||
67 | software for any particular purpose. It is provided "as is" | ||
68 | without express or implied warranty of any kind. | ||
69 | |||
70 | These notices must be retained in any copies of any part of this | ||
71 | documentation and/or software. | ||
72 | |||
73 | */ | ||
74 | |||
75 | // use for the raw digest output | ||
76 | const int MD5RAW_BYTES = 16; | ||
77 | |||
78 | // use for outputting hex digests | ||
79 | const int MD5HEX_STR_SIZE = 33; // char hex[MD5HEX_STR_SIZE]; with null | ||
80 | const int MD5HEX_STR_BYTES = 32; // message system fixed size | ||
81 | |||
82 | class LLMD5 { | ||
83 | // first, some types: | ||
84 | typedef unsigned int uint4; // assumes integer is 4 words long | ||
85 | typedef unsigned short int uint2; // assumes short integer is 2 words long | ||
86 | typedef unsigned char uint1; // assumes char is 1 word long | ||
87 | |||
88 | // how many bytes to grab at a time when checking files | ||
89 | static const int BLOCK_LEN; | ||
90 | |||
91 | public: | ||
92 | // methods for controlled operation: | ||
93 | LLMD5 (); // simple initializer | ||
94 | void update (const uint1 *input, const uint4 input_length); | ||
95 | void update (std::istream& stream); | ||
96 | void update (LLFILE *file); | ||
97 | void finalize (); | ||
98 | |||
99 | // constructors for special circumstances. All these constructors finalize | ||
100 | // the MD5 context. | ||
101 | LLMD5 (const unsigned char *string); // digest string, finalize | ||
102 | LLMD5 (std::istream& stream); // digest stream, finalize | ||
103 | LLMD5 (LLFILE *file); // digest file, close, finalize | ||
104 | LLMD5 (const unsigned char *string, const unsigned int number); | ||
105 | |||
106 | // methods to acquire finalized result | ||
107 | void raw_digest(unsigned char *array); // provide 16-byte array for binary data | ||
108 | void hex_digest(char *string); // provide 33-byte array for ascii-hex string | ||
109 | friend std::ostream& operator<< (std::ostream&, LLMD5 context); | ||
110 | |||
111 | |||
112 | |||
113 | private: | ||
114 | |||
115 | |||
116 | // next, the private data: | ||
117 | uint4 state[4]; | ||
118 | uint4 count[2]; // number of *bits*, mod 2^64 | ||
119 | uint1 buffer[64]; // input buffer | ||
120 | uint1 digest[16]; | ||
121 | uint1 finalized; | ||
122 | |||
123 | // last, the private methods, mostly static: | ||
124 | void init (); // called by all constructors | ||
125 | void transform (const uint1 *buffer); // does the real update work. Note | ||
126 | // that length is implied to be 64. | ||
127 | |||
128 | static void encode (uint1 *dest, const uint4 *src, const uint4 length); | ||
129 | static void decode (uint4 *dest, const uint1 *src, const uint4 length); | ||
130 | |||
131 | }; | ||
132 | |||
133 | #endif // LL_LLMD5_H | ||
diff --git a/linden/indra/llmath/lloctree.h b/linden/indra/llmath/lloctree.h index e26bae5..57b359f 100644 --- a/linden/indra/llmath/lloctree.h +++ b/linden/indra/llmath/lloctree.h | |||
@@ -37,7 +37,7 @@ | |||
37 | #include <vector> | 37 | #include <vector> |
38 | #include <set> | 38 | #include <set> |
39 | 39 | ||
40 | #ifdef LL_RELEASE_FOR_DOWNLOAD | 40 | #if LL_RELEASE_WITH_DEBUG_INFO || LL_DEBUG |
41 | #define OCT_ERRS LL_WARNS("OctreeErrors") | 41 | #define OCT_ERRS LL_WARNS("OctreeErrors") |
42 | #else | 42 | #else |
43 | #define OCT_ERRS LL_ERRS("OctreeErrors") | 43 | #define OCT_ERRS LL_ERRS("OctreeErrors") |
diff --git a/linden/indra/llmath/llquaternion.cpp b/linden/indra/llmath/llquaternion.cpp index ab4855b..9eab8ed 100644 --- a/linden/indra/llmath/llquaternion.cpp +++ b/linden/indra/llmath/llquaternion.cpp | |||
@@ -791,7 +791,7 @@ LLQuaternion mayaQ(F32 xRot, F32 yRot, F32 zRot, LLQuaternion::Order order) | |||
791 | 791 | ||
792 | const char *OrderToString( const LLQuaternion::Order order ) | 792 | const char *OrderToString( const LLQuaternion::Order order ) |
793 | { | 793 | { |
794 | char *p = NULL; | 794 | const char *p = NULL; |
795 | switch( order ) | 795 | switch( order ) |
796 | { | 796 | { |
797 | default: | 797 | default: |
@@ -937,15 +937,15 @@ void LLQuaternion::unpackFromVector3( const LLVector3& vec ) | |||
937 | } | 937 | } |
938 | } | 938 | } |
939 | 939 | ||
940 | BOOL LLQuaternion::parseQuat(const char* buf, LLQuaternion* value) | 940 | BOOL LLQuaternion::parseQuat(const std::string& buf, LLQuaternion* value) |
941 | { | 941 | { |
942 | if( buf == NULL || buf[0] == '\0' || value == NULL) | 942 | if( buf.empty() || value == NULL) |
943 | { | 943 | { |
944 | return FALSE; | 944 | return FALSE; |
945 | } | 945 | } |
946 | 946 | ||
947 | LLQuaternion quat; | 947 | LLQuaternion quat; |
948 | S32 count = sscanf( buf, "%f %f %f %f", quat.mQ + 0, quat.mQ + 1, quat.mQ + 2, quat.mQ + 3 ); | 948 | S32 count = sscanf( buf.c_str(), "%f %f %f %f", quat.mQ + 0, quat.mQ + 1, quat.mQ + 2, quat.mQ + 3 ); |
949 | if( 4 == count ) | 949 | if( 4 == count ) |
950 | { | 950 | { |
951 | value->set( quat ); | 951 | value->set( quat ); |
diff --git a/linden/indra/llmath/llquaternion.h b/linden/indra/llmath/llquaternion.h index 048db2d..1eb982e 100644 --- a/linden/indra/llmath/llquaternion.h +++ b/linden/indra/llmath/llquaternion.h | |||
@@ -158,7 +158,7 @@ public: | |||
158 | friend const char *OrderToString( const Order order ); | 158 | friend const char *OrderToString( const Order order ); |
159 | friend Order StringToOrder( const char *str ); | 159 | friend Order StringToOrder( const char *str ); |
160 | 160 | ||
161 | static BOOL parseQuat(const char* buf, LLQuaternion* value); | 161 | static BOOL parseQuat(const std::string& buf, LLQuaternion* value); |
162 | 162 | ||
163 | // For debugging, only | 163 | // For debugging, only |
164 | //static U32 mMultCount; | 164 | //static U32 mMultCount; |
diff --git a/linden/indra/llmath/llrand.cpp b/linden/indra/llmath/llrand.cpp deleted file mode 100644 index bc8c867..0000000 --- a/linden/indra/llmath/llrand.cpp +++ /dev/null | |||
@@ -1,176 +0,0 @@ | |||
1 | /** | ||
2 | * @file llrand.cpp | ||
3 | * @brief Global random generator. | ||
4 | * | ||
5 | * $LicenseInfo:firstyear=2000&license=viewergpl$ | ||
6 | * | ||
7 | * Copyright (c) 2000-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 | #include "linden_common.h" | ||
33 | |||
34 | #include "llrand.h" | ||
35 | #include "lluuid.h" | ||
36 | |||
37 | /** | ||
38 | * Through analysis, we have decided that we want to take values which | ||
39 | * are close enough to 1.0 to map back to 0.0. We came to this | ||
40 | * conclusion from noting that: | ||
41 | * | ||
42 | * [0.0, 1.0) | ||
43 | * | ||
44 | * when scaled to the integer set: | ||
45 | * | ||
46 | * [0, 4) | ||
47 | * | ||
48 | * there is some value close enough to 1.0 that when multiplying by 4, | ||
49 | * gets truncated to 4. Therefore: | ||
50 | * | ||
51 | * [0,1-eps] => 0 | ||
52 | * [1,2-eps] => 1 | ||
53 | * [2,3-eps] => 2 | ||
54 | * [3,4-eps] => 3 | ||
55 | * | ||
56 | * So 0 gets uneven distribution if we simply clamp. The actual | ||
57 | * clamp utilized in this file is to map values out of range back | ||
58 | * to 0 to restore uniform distribution. | ||
59 | * | ||
60 | * Also, for clamping floats when asking for a distribution from | ||
61 | * [0.0,g) we have determined that for values of g < 0.5, then | ||
62 | * rand*g=g, which is not the desired result. As above, we clamp to 0 | ||
63 | * to restore uniform distribution. | ||
64 | */ | ||
65 | |||
66 | // *NOTE: The system rand implementation is probably not correct. | ||
67 | #define LL_USE_SYSTEM_RAND 0 | ||
68 | |||
69 | #if LL_USE_SYSTEM_RAND | ||
70 | #include <cstdlib> | ||
71 | #endif | ||
72 | |||
73 | #if LL_USE_SYSTEM_RAND | ||
74 | class LLSeedRand | ||
75 | { | ||
76 | public: | ||
77 | LLSeedRand() | ||
78 | { | ||
79 | #if LL_WINDOWS | ||
80 | srand(LLUUID::getRandomSeed()); | ||
81 | #else | ||
82 | srand48(LLUUID::getRandomSeed()); | ||
83 | #endif | ||
84 | } | ||
85 | }; | ||
86 | static LLSeedRand sRandomSeeder; | ||
87 | inline F64 ll_internal_random_double() | ||
88 | { | ||
89 | #if LL_WINDOWS | ||
90 | return (F64)rand() / (F64)RAND_MAX; | ||
91 | #else | ||
92 | return drand48(); | ||
93 | #endif | ||
94 | } | ||
95 | inline F32 ll_internal_random_float() | ||
96 | { | ||
97 | #if LL_WINDOWS | ||
98 | return (F32)rand() / (F32)RAND_MAX; | ||
99 | #else | ||
100 | return (F32)drand48(); | ||
101 | #endif | ||
102 | } | ||
103 | #else | ||
104 | static LLRandLagFib2281 gRandomGenerator(LLUUID::getRandomSeed()); | ||
105 | inline F64 ll_internal_random_double() | ||
106 | { | ||
107 | // *HACK: Through experimentation, we have found that dual core | ||
108 | // CPUs (or at least multi-threaded processes) seem to | ||
109 | // occasionally give an obviously incorrect random number -- like | ||
110 | // 5^15 or something. Sooooo, clamp it as described above. | ||
111 | F64 rv = gRandomGenerator(); | ||
112 | if(!((rv >= 0.0) && (rv < 1.0))) return fmod(rv, 1.0); | ||
113 | return rv; | ||
114 | } | ||
115 | |||
116 | inline F32 ll_internal_random_float() | ||
117 | { | ||
118 | // The clamping rules are described above. | ||
119 | F32 rv = (F32)gRandomGenerator(); | ||
120 | if(!((rv >= 0.0f) && (rv < 1.0f))) return fmod(rv, 1.f); | ||
121 | return rv; | ||
122 | } | ||
123 | #endif | ||
124 | |||
125 | S32 ll_rand() | ||
126 | { | ||
127 | return ll_rand(RAND_MAX); | ||
128 | } | ||
129 | |||
130 | S32 ll_rand(S32 val) | ||
131 | { | ||
132 | // The clamping rules are described above. | ||
133 | S32 rv = (S32)(ll_internal_random_double() * val); | ||
134 | if(rv == val) return 0; | ||
135 | return rv; | ||
136 | } | ||
137 | |||
138 | F32 ll_frand() | ||
139 | { | ||
140 | return ll_internal_random_float(); | ||
141 | } | ||
142 | |||
143 | F32 ll_frand(F32 val) | ||
144 | { | ||
145 | // The clamping rules are described above. | ||
146 | F32 rv = ll_internal_random_float() * val; | ||
147 | if(val > 0) | ||
148 | { | ||
149 | if(rv >= val) return 0.0f; | ||
150 | } | ||
151 | else | ||
152 | { | ||
153 | if(rv <= val) return 0.0f; | ||
154 | } | ||
155 | return rv; | ||
156 | } | ||
157 | |||
158 | F64 ll_drand() | ||
159 | { | ||
160 | return ll_internal_random_double(); | ||
161 | } | ||
162 | |||
163 | F64 ll_drand(F64 val) | ||
164 | { | ||
165 | // The clamping rules are described above. | ||
166 | F64 rv = ll_internal_random_double() * val; | ||
167 | if(val > 0) | ||
168 | { | ||
169 | if(rv >= val) return 0.0; | ||
170 | } | ||
171 | else | ||
172 | { | ||
173 | if(rv <= val) return 0.0; | ||
174 | } | ||
175 | return rv; | ||
176 | } | ||
diff --git a/linden/indra/llmath/llrand.h b/linden/indra/llmath/llrand.h deleted file mode 100644 index 0a28213..0000000 --- a/linden/indra/llmath/llrand.h +++ /dev/null | |||
@@ -1,132 +0,0 @@ | |||
1 | /** | ||
2 | * @file llrand.h | ||
3 | * @brief Information, functions, and typedefs for randomness. | ||
4 | * | ||
5 | * $LicenseInfo:firstyear=2000&license=viewergpl$ | ||
6 | * | ||
7 | * Copyright (c) 2000-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 LL_LLRAND_H | ||
33 | #define LL_LLRAND_H | ||
34 | |||
35 | #include <boost/random/lagged_fibonacci.hpp> | ||
36 | #include <boost/random/mersenne_twister.hpp> | ||
37 | |||
38 | /** | ||
39 | * Use the boost random number generators if you want a stateful | ||
40 | * random numbers. If you want more random numbers, use the | ||
41 | * c-functions since they will generate faster/better randomness | ||
42 | * across the process. | ||
43 | * | ||
44 | * I tested some of the boost random engines, and picked a good double | ||
45 | * generator and a good integer generator. I also took some timings | ||
46 | * for them on linux using gcc 3.3.5. The harness also did some other | ||
47 | * fairly trivial operations to try to limit compiler optimizations, | ||
48 | * so these numbers are only good for relative comparisons. | ||
49 | * | ||
50 | * usec/inter algorithm | ||
51 | * 0.21 boost::minstd_rand0 | ||
52 | * 0.039 boost:lagged_fibonacci19937 | ||
53 | * 0.036 boost:lagged_fibonacci607 | ||
54 | * 0.44 boost::hellekalek1995 | ||
55 | * 0.44 boost::ecuyer1988 | ||
56 | * 0.042 boost::rand48 | ||
57 | * 0.043 boost::mt11213b | ||
58 | * 0.028 stdlib random() | ||
59 | * 0.05 stdlib lrand48() | ||
60 | * 0.034 stdlib rand() | ||
61 | * 0.020 the old & lame LLRand | ||
62 | */ | ||
63 | |||
64 | /** | ||
65 | *@brief Generate a float from [0, RAND_MAX). | ||
66 | */ | ||
67 | S32 ll_rand(); | ||
68 | |||
69 | /** | ||
70 | *@brief Generate a float from [0, val) or (val, 0]. | ||
71 | */ | ||
72 | S32 ll_rand(S32 val); | ||
73 | |||
74 | /** | ||
75 | *@brief Generate a float from [0, 1.0). | ||
76 | */ | ||
77 | F32 ll_frand(); | ||
78 | |||
79 | /** | ||
80 | *@brief Generate a float from [0, val) or (val, 0]. | ||
81 | */ | ||
82 | F32 ll_frand(F32 val); | ||
83 | |||
84 | /** | ||
85 | *@brief Generate a double from [0, 1.0). | ||
86 | */ | ||
87 | F64 ll_drand(); | ||
88 | |||
89 | /** | ||
90 | *@brief Generate a double from [0, val) or (val, 0]. | ||
91 | */ | ||
92 | F64 ll_drand(F64 val); | ||
93 | |||
94 | /** | ||
95 | * @brief typedefs for good boost lagged fibonacci. | ||
96 | * @see boost::lagged_fibonacci | ||
97 | * | ||
98 | * These generators will quickly generate doubles. Note the memory | ||
99 | * requirements, because they are somewhat high. I chose the smallest | ||
100 | * one, and one comparable in speed but higher periodicity without | ||
101 | * outrageous memory requirements. | ||
102 | * To use: | ||
103 | * LLRandLagFib607 foo((U32)time(NULL)); | ||
104 | * double bar = foo(); | ||
105 | */ | ||
106 | |||
107 | typedef boost::lagged_fibonacci607 LLRandLagFib607; | ||
108 | /**< | ||
109 | * lengh of cycle: 2^32,000 | ||
110 | * memory: 607*sizeof(double) (about 5K) | ||
111 | */ | ||
112 | |||
113 | typedef boost::lagged_fibonacci2281 LLRandLagFib2281; | ||
114 | /**< | ||
115 | * lengh of cycle: 2^120,000 | ||
116 | * memory: 2281*sizeof(double) (about 17K) | ||
117 | */ | ||
118 | |||
119 | /** | ||
120 | * @breif typedefs for a good boost mersenne twister implementation. | ||
121 | * @see boost::mersenne_twister | ||
122 | * | ||
123 | * This fairly quickly generates U32 values | ||
124 | * To use: | ||
125 | * LLRandMT19937 foo((U32)time(NULL)); | ||
126 | * U32 bar = foo(); | ||
127 | * | ||
128 | * lengh of cycle: 2^19,937-1 | ||
129 | * memory: about 2496 bytes | ||
130 | */ | ||
131 | typedef boost::mt11213b LLRandMT19937; | ||
132 | #endif | ||
diff --git a/linden/indra/llmath/llrect.h b/linden/indra/llmath/llrect.h index f2a5d75..ebe5d83 100644 --- a/linden/indra/llmath/llrect.h +++ b/linden/indra/llmath/llrect.h | |||
@@ -183,10 +183,11 @@ public: | |||
183 | 183 | ||
184 | LLRectBase& setCenterAndSize(Type x, Type y, Type width, Type height) | 184 | LLRectBase& setCenterAndSize(Type x, Type y, Type width, Type height) |
185 | { | 185 | { |
186 | // width and height could be odd, so favor top, right with extra pixel | ||
186 | mLeft = x - width/2; | 187 | mLeft = x - width/2; |
187 | mTop = y + height/2; | ||
188 | mRight = x + width/2; | ||
189 | mBottom = y - height/2; | 188 | mBottom = y - height/2; |
189 | mTop = mBottom + height; | ||
190 | mRight = mLeft + width; | ||
190 | return *this; | 191 | return *this; |
191 | } | 192 | } |
192 | 193 | ||
diff --git a/linden/indra/llmath/llsdutil_math.cpp b/linden/indra/llmath/llsdutil_math.cpp new file mode 100644 index 0000000..5b72875 --- /dev/null +++ b/linden/indra/llmath/llsdutil_math.cpp | |||
@@ -0,0 +1,172 @@ | |||
1 | /** | ||
2 | * @file llsdutil_math.cpp | ||
3 | * @author Phoenix | ||
4 | * @date 2006-05-24 | ||
5 | * @brief Implementation of classes, functions, etc, for using structured data. | ||
6 | * | ||
7 | * $LicenseInfo:firstyear=2006&license=viewergpl$ | ||
8 | * | ||
9 | * Copyright (c) 2006-2008, Linden Research, Inc. | ||
10 | * | ||
11 | * Second Life Viewer Source Code | ||
12 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
13 | * to you under the terms of the GNU General Public License, version 2.0 | ||
14 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
15 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
16 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
17 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
18 | * | ||
19 | * There are special exceptions to the terms and conditions of the GPL as | ||
20 | * it is applied to this Source Code. View the full text of the exception | ||
21 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
22 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
23 | * | ||
24 | * By copying, modifying or distributing this software, you acknowledge | ||
25 | * that you have read and understood your obligations described above, | ||
26 | * and agree to abide by those obligations. | ||
27 | * | ||
28 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
29 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
30 | * COMPLETENESS OR PERFORMANCE. | ||
31 | * $/LicenseInfo$ | ||
32 | */ | ||
33 | |||
34 | #include "linden_common.h" | ||
35 | |||
36 | #include "llsdutil.h" | ||
37 | |||
38 | #include "v3math.h" | ||
39 | #include "v4math.h" | ||
40 | #include "v3dmath.h" | ||
41 | #include "v2math.h" | ||
42 | #include "llquaternion.h" | ||
43 | #include "v4color.h" | ||
44 | |||
45 | #if LL_WINDOWS | ||
46 | # define WIN32_LEAN_AND_MEAN | ||
47 | # include <winsock2.h> // for htonl | ||
48 | #elif LL_LINUX || LL_SOLARIS | ||
49 | # include <netinet/in.h> | ||
50 | #elif LL_DARWIN | ||
51 | # include <arpa/inet.h> | ||
52 | #endif | ||
53 | |||
54 | #include "llsdserialize.h" | ||
55 | |||
56 | // vector3 | ||
57 | LLSD ll_sd_from_vector3(const LLVector3& vec) | ||
58 | { | ||
59 | LLSD rv; | ||
60 | rv.append((F64)vec.mV[VX]); | ||
61 | rv.append((F64)vec.mV[VY]); | ||
62 | rv.append((F64)vec.mV[VZ]); | ||
63 | return rv; | ||
64 | } | ||
65 | |||
66 | LLVector3 ll_vector3_from_sd(const LLSD& sd, S32 start_index) | ||
67 | { | ||
68 | LLVector3 rv; | ||
69 | rv.mV[VX] = (F32)sd[start_index].asReal(); | ||
70 | rv.mV[VY] = (F32)sd[++start_index].asReal(); | ||
71 | rv.mV[VZ] = (F32)sd[++start_index].asReal(); | ||
72 | return rv; | ||
73 | } | ||
74 | |||
75 | // vector4 | ||
76 | LLSD ll_sd_from_vector4(const LLVector4& vec) | ||
77 | { | ||
78 | LLSD rv; | ||
79 | rv.append((F64)vec.mV[VX]); | ||
80 | rv.append((F64)vec.mV[VY]); | ||
81 | rv.append((F64)vec.mV[VZ]); | ||
82 | rv.append((F64)vec.mV[VW]); | ||
83 | return rv; | ||
84 | } | ||
85 | |||
86 | LLVector4 ll_vector4_from_sd(const LLSD& sd, S32 start_index) | ||
87 | { | ||
88 | LLVector4 rv; | ||
89 | rv.mV[VX] = (F32)sd[start_index].asReal(); | ||
90 | rv.mV[VY] = (F32)sd[++start_index].asReal(); | ||
91 | rv.mV[VZ] = (F32)sd[++start_index].asReal(); | ||
92 | rv.mV[VW] = (F32)sd[++start_index].asReal(); | ||
93 | return rv; | ||
94 | } | ||
95 | |||
96 | // vector3d | ||
97 | LLSD ll_sd_from_vector3d(const LLVector3d& vec) | ||
98 | { | ||
99 | LLSD rv; | ||
100 | rv.append(vec.mdV[VX]); | ||
101 | rv.append(vec.mdV[VY]); | ||
102 | rv.append(vec.mdV[VZ]); | ||
103 | return rv; | ||
104 | } | ||
105 | |||
106 | LLVector3d ll_vector3d_from_sd(const LLSD& sd, S32 start_index) | ||
107 | { | ||
108 | LLVector3d rv; | ||
109 | rv.mdV[VX] = sd[start_index].asReal(); | ||
110 | rv.mdV[VY] = sd[++start_index].asReal(); | ||
111 | rv.mdV[VZ] = sd[++start_index].asReal(); | ||
112 | return rv; | ||
113 | } | ||
114 | |||
115 | //vector2 | ||
116 | LLSD ll_sd_from_vector2(const LLVector2& vec) | ||
117 | { | ||
118 | LLSD rv; | ||
119 | rv.append((F64)vec.mV[VX]); | ||
120 | rv.append((F64)vec.mV[VY]); | ||
121 | return rv; | ||
122 | } | ||
123 | |||
124 | LLVector2 ll_vector2_from_sd(const LLSD& sd) | ||
125 | { | ||
126 | LLVector2 rv; | ||
127 | rv.mV[VX] = (F32)sd[0].asReal(); | ||
128 | rv.mV[VY] = (F32)sd[1].asReal(); | ||
129 | return rv; | ||
130 | } | ||
131 | |||
132 | // Quaternion | ||
133 | LLSD ll_sd_from_quaternion(const LLQuaternion& quat) | ||
134 | { | ||
135 | LLSD rv; | ||
136 | rv.append((F64)quat.mQ[VX]); | ||
137 | rv.append((F64)quat.mQ[VY]); | ||
138 | rv.append((F64)quat.mQ[VZ]); | ||
139 | rv.append((F64)quat.mQ[VW]); | ||
140 | return rv; | ||
141 | } | ||
142 | |||
143 | LLQuaternion ll_quaternion_from_sd(const LLSD& sd) | ||
144 | { | ||
145 | LLQuaternion quat; | ||
146 | quat.mQ[VX] = (F32)sd[0].asReal(); | ||
147 | quat.mQ[VY] = (F32)sd[1].asReal(); | ||
148 | quat.mQ[VZ] = (F32)sd[2].asReal(); | ||
149 | quat.mQ[VW] = (F32)sd[3].asReal(); | ||
150 | return quat; | ||
151 | } | ||
152 | |||
153 | // color4 | ||
154 | LLSD ll_sd_from_color4(const LLColor4& c) | ||
155 | { | ||
156 | LLSD rv; | ||
157 | rv.append(c.mV[0]); | ||
158 | rv.append(c.mV[1]); | ||
159 | rv.append(c.mV[2]); | ||
160 | rv.append(c.mV[3]); | ||
161 | return rv; | ||
162 | } | ||
163 | |||
164 | LLColor4 ll_color4_from_sd(const LLSD& sd) | ||
165 | { | ||
166 | LLColor4 c; | ||
167 | c.mV[0] = (F32)sd[0].asReal(); | ||
168 | c.mV[1] = (F32)sd[1].asReal(); | ||
169 | c.mV[2] = (F32)sd[2].asReal(); | ||
170 | c.mV[3] = (F32)sd[3].asReal(); | ||
171 | return c; | ||
172 | } | ||
diff --git a/linden/indra/llmath/llsphere.cpp b/linden/indra/llmath/llsphere.cpp index 62f6e27..f253b6c 100644 --- a/linden/indra/llmath/llsphere.cpp +++ b/linden/indra/llmath/llsphere.cpp | |||
@@ -20,6 +20,8 @@ | |||
20 | * $/LicenseInfo$ | 20 | * $/LicenseInfo$ |
21 | */ | 21 | */ |
22 | 22 | ||
23 | #include "linden_common.h" | ||
24 | |||
23 | #include "llsphere.h" | 25 | #include "llsphere.h" |
24 | 26 | ||
25 | LLSphere::LLSphere() | 27 | LLSphere::LLSphere() |
diff --git a/linden/indra/llmath/lluuid.cpp b/linden/indra/llmath/lluuid.cpp deleted file mode 100644 index d835cbc..0000000 --- a/linden/indra/llmath/lluuid.cpp +++ /dev/null | |||
@@ -1,923 +0,0 @@ | |||
1 | /** | ||
2 | * @file lluuid.cpp | ||
3 | * | ||
4 | * $LicenseInfo:firstyear=2000&license=viewergpl$ | ||
5 | * | ||
6 | * Copyright (c) 2000-2008, Linden Research, Inc. | ||
7 | * | ||
8 | * Second Life Viewer Source Code | ||
9 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
10 | * to you under the terms of the GNU General Public License, version 2.0 | ||
11 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
12 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
13 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
14 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
15 | * | ||
16 | * There are special exceptions to the terms and conditions of the GPL as | ||
17 | * it is applied to this Source Code. View the full text of the exception | ||
18 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
19 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
20 | * | ||
21 | * By copying, modifying or distributing this software, you acknowledge | ||
22 | * that you have read and understood your obligations described above, | ||
23 | * and agree to abide by those obligations. | ||
24 | * | ||
25 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
26 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
27 | * COMPLETENESS OR PERFORMANCE. | ||
28 | * $/LicenseInfo$ | ||
29 | */ | ||
30 | |||
31 | #include "linden_common.h" | ||
32 | |||
33 | // We can't use WIN32_LEAN_AND_MEAN here, needs lots of includes. | ||
34 | #if LL_WINDOWS | ||
35 | # undef WIN32_LEAN_AND_MEAN | ||
36 | # include <winsock2.h> | ||
37 | # include <windows.h> | ||
38 | #endif | ||
39 | |||
40 | #include "lldefs.h" | ||
41 | #include "llerror.h" | ||
42 | |||
43 | #include "lluuid.h" | ||
44 | #include "llerror.h" | ||
45 | #include "llrand.h" | ||
46 | #include "llmd5.h" | ||
47 | #include "llstring.h" | ||
48 | #include "lltimer.h" | ||
49 | |||
50 | const LLUUID LLUUID::null; | ||
51 | const LLTransactionID LLTransactionID::tnull; | ||
52 | |||
53 | /* | ||
54 | |||
55 | NOT DONE YET!!! | ||
56 | |||
57 | static char BASE85_TABLE[] = { | ||
58 | '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', | ||
59 | 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', | ||
60 | 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', | ||
61 | 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', | ||
62 | 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', | ||
63 | 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', | ||
64 | 'y', 'z', '!', '#', '$', '%', '&', '(', ')', '*', | ||
65 | '+', '-', ';', '[', '=', '>', '?', '@', '^', '_', | ||
66 | '`', '{', '|', '}', '~', '\0' | ||
67 | }; | ||
68 | |||
69 | |||
70 | void encode( char * fiveChars, unsigned int word ) throw( ) | ||
71 | { | ||
72 | for( int ix = 0; ix < 5; ++ix ) { | ||
73 | fiveChars[4-ix] = encodeTable[ word % 85]; | ||
74 | word /= 85; | ||
75 | } | ||
76 | } | ||
77 | |||
78 | To decode: | ||
79 | unsigned int decode( char const * fiveChars ) throw( bad_input_data ) | ||
80 | { | ||
81 | unsigned int ret = 0; | ||
82 | for( int ix = 0; ix < 5; ++ix ) { | ||
83 | char * s = strchr( encodeTable, fiveChars[ ix ] ); | ||
84 | if( s == 0 ) throw bad_input_data(); | ||
85 | ret = ret * 85 + (s-encodeTable); | ||
86 | } | ||
87 | return ret; | ||
88 | } | ||
89 | |||
90 | void LLUUID::toBase85(char* out) | ||
91 | { | ||
92 | U32* me = (U32*)&(mData[0]); | ||
93 | for(S32 i = 0; i < 4; ++i) | ||
94 | { | ||
95 | char* o = &out[i*i]; | ||
96 | for(S32 j = 0; j < 5; ++j) | ||
97 | { | ||
98 | o[4-j] = BASE85_TABLE[ me[i] % 85]; | ||
99 | word /= 85; | ||
100 | } | ||
101 | } | ||
102 | } | ||
103 | |||
104 | unsigned int decode( char const * fiveChars ) throw( bad_input_data ) | ||
105 | { | ||
106 | unsigned int ret = 0; | ||
107 | for( S32 ix = 0; ix < 5; ++ix ) | ||
108 | { | ||
109 | char * s = strchr( encodeTable, fiveChars[ ix ] ); | ||
110 | ret = ret * 85 + (s-encodeTable); | ||
111 | } | ||
112 | return ret; | ||
113 | } | ||
114 | */ | ||
115 | |||
116 | #define LL_USE_JANKY_RANDOM_NUMBER_GENERATOR 0 | ||
117 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
118 | /** | ||
119 | * @brief a global for | ||
120 | */ | ||
121 | static U64 sJankyRandomSeed(LLUUID::getRandomSeed()); | ||
122 | |||
123 | /** | ||
124 | * @brief generate a random U32. | ||
125 | */ | ||
126 | U32 janky_fast_random_bytes() | ||
127 | { | ||
128 | sJankyRandomSeed = U64L(1664525) * sJankyRandomSeed + U64L(1013904223); | ||
129 | return (U32)sJankyRandomSeed; | ||
130 | } | ||
131 | |||
132 | /** | ||
133 | * @brief generate a random U32 from [0, val) | ||
134 | */ | ||
135 | U32 janky_fast_random_byes_range(U32 val) | ||
136 | { | ||
137 | sJankyRandomSeed = U64L(1664525) * sJankyRandomSeed + U64L(1013904223); | ||
138 | return (U32)(sJankyRandomSeed) % val; | ||
139 | } | ||
140 | |||
141 | /** | ||
142 | * @brief generate a random U32 from [0, val) | ||
143 | */ | ||
144 | U32 janky_fast_random_seeded_bytes(U32 seed, U32 val) | ||
145 | { | ||
146 | seed = U64L(1664525) * (U64)(seed) + U64L(1013904223); | ||
147 | return (U32)(seed) % val; | ||
148 | } | ||
149 | #endif | ||
150 | |||
151 | // Common to all UUID implementations | ||
152 | void LLUUID::toString(char *out) const | ||
153 | { | ||
154 | sprintf(out, | ||
155 | "%02x%02x%02x%02x-%02x%02x-%02x%02x-%02x%02x-%02x%02x%02x%02x%02x%02x", | ||
156 | (U8)(mData[0]), | ||
157 | (U8)(mData[1]), | ||
158 | (U8)(mData[2]), | ||
159 | (U8)(mData[3]), | ||
160 | (U8)(mData[4]), | ||
161 | (U8)(mData[5]), | ||
162 | (U8)(mData[6]), | ||
163 | (U8)(mData[7]), | ||
164 | (U8)(mData[8]), | ||
165 | (U8)(mData[9]), | ||
166 | (U8)(mData[10]), | ||
167 | (U8)(mData[11]), | ||
168 | (U8)(mData[12]), | ||
169 | (U8)(mData[13]), | ||
170 | (U8)(mData[14]), | ||
171 | (U8)(mData[15])); | ||
172 | } | ||
173 | |||
174 | void LLUUID::toCompressedString(char *out) const | ||
175 | { | ||
176 | memcpy(out, mData, UUID_BYTES); /* Flawfinder: ignore */ | ||
177 | out[UUID_BYTES] = '\0'; | ||
178 | } | ||
179 | |||
180 | std::string LLUUID::getString() const | ||
181 | { | ||
182 | return asString(); | ||
183 | } | ||
184 | |||
185 | std::string LLUUID::asString() const | ||
186 | { | ||
187 | char str[UUID_STR_SIZE]; /* Flawfinder: ignore */ | ||
188 | toString(str); | ||
189 | return std::string(str); | ||
190 | } | ||
191 | |||
192 | BOOL LLUUID::set(const std::string& in_string, BOOL emit) | ||
193 | { | ||
194 | return set(in_string.c_str(), emit); | ||
195 | } | ||
196 | |||
197 | BOOL LLUUID::set(const char *in_string, BOOL emit) | ||
198 | { | ||
199 | BOOL broken_format = FALSE; | ||
200 | if (!in_string) | ||
201 | { | ||
202 | llerrs << "No string pointer in LLUUID::set!" << llendl; | ||
203 | setNull(); | ||
204 | return FALSE; | ||
205 | } | ||
206 | |||
207 | // empty strings should make NULL uuid | ||
208 | if (!in_string[0]) | ||
209 | { | ||
210 | setNull(); | ||
211 | return TRUE; | ||
212 | } | ||
213 | |||
214 | if (strlen(in_string) != (UUID_STR_LENGTH - 1)) /* Flawfinder: ignore */ | ||
215 | { | ||
216 | // I'm a moron. First implementation didn't have the right UUID format. | ||
217 | // Shouldn't see any of these any more | ||
218 | if (strlen(in_string) == (UUID_STR_LENGTH - 2)) /* Flawfinder: ignore */ | ||
219 | { | ||
220 | if(emit) | ||
221 | { | ||
222 | llinfos << "Warning! Using broken UUID string format" << llendl; | ||
223 | } | ||
224 | broken_format = TRUE; | ||
225 | } | ||
226 | else | ||
227 | { | ||
228 | // Bad UUID string. Spam as INFO, as most cases we don't care. | ||
229 | if(emit) | ||
230 | { | ||
231 | llinfos << "Bad UUID string: " << in_string << llendl; | ||
232 | } | ||
233 | setNull(); | ||
234 | return FALSE; | ||
235 | } | ||
236 | } | ||
237 | |||
238 | U8 cur_pos = 0; | ||
239 | S32 i; | ||
240 | for (i = 0; i < UUID_BYTES; i++) | ||
241 | { | ||
242 | if ((i == 4) || (i == 6) || (i == 8) || (i == 10)) | ||
243 | { | ||
244 | cur_pos++; | ||
245 | if (broken_format && (i==10)) | ||
246 | { | ||
247 | // Missing - in the broken format | ||
248 | cur_pos--; | ||
249 | } | ||
250 | } | ||
251 | |||
252 | mData[i] = 0; | ||
253 | |||
254 | if ((*(in_string + cur_pos) >= '0') && (*(in_string+cur_pos) <= '9')) | ||
255 | { | ||
256 | mData[i] += (U8)(*(in_string + cur_pos) - '0'); | ||
257 | } | ||
258 | else if ((*(in_string + cur_pos) >= 'a') && (*(in_string+cur_pos) <='f')) | ||
259 | { | ||
260 | mData[i] += (U8)(10 + *(in_string + cur_pos) - 'a'); | ||
261 | } | ||
262 | else if ((*(in_string + cur_pos) >= 'A') && (*(in_string+cur_pos) <='F')) | ||
263 | { | ||
264 | mData[i] += (U8)(10 + *(in_string + cur_pos) - 'A'); | ||
265 | } | ||
266 | else | ||
267 | { | ||
268 | if(emit) | ||
269 | { | ||
270 | llwarns << "Invalid UUID string character" << llendl; | ||
271 | } | ||
272 | setNull(); | ||
273 | return FALSE; | ||
274 | } | ||
275 | |||
276 | mData[i] = mData[i] << 4; | ||
277 | cur_pos++; | ||
278 | |||
279 | if ((*(in_string + cur_pos) >= '0') && (*(in_string+cur_pos) <= '9')) | ||
280 | { | ||
281 | mData[i] += (U8)(*(in_string + cur_pos) - '0'); | ||
282 | } | ||
283 | else if ((*(in_string + cur_pos) >= 'a') && (*(in_string+cur_pos) <='f')) | ||
284 | { | ||
285 | mData[i] += (U8)(10 + *(in_string + cur_pos) - 'a'); | ||
286 | } | ||
287 | else if ((*(in_string + cur_pos) >= 'A') && (*(in_string+cur_pos) <='F')) | ||
288 | { | ||
289 | mData[i] += (U8)(10 + *(in_string + cur_pos) - 'A'); | ||
290 | } | ||
291 | else | ||
292 | { | ||
293 | if(emit) | ||
294 | { | ||
295 | llwarns << "Invalid UUID string character" << llendl; | ||
296 | } | ||
297 | setNull(); | ||
298 | return FALSE; | ||
299 | } | ||
300 | cur_pos++; | ||
301 | } | ||
302 | |||
303 | return TRUE; | ||
304 | } | ||
305 | |||
306 | BOOL LLUUID::validate(const std::string& in_string) | ||
307 | { | ||
308 | return validate(in_string.c_str()); | ||
309 | } | ||
310 | |||
311 | BOOL LLUUID::validate(const char *in_string) | ||
312 | { | ||
313 | BOOL broken_format = FALSE; | ||
314 | if (!in_string) | ||
315 | { | ||
316 | return FALSE; | ||
317 | } | ||
318 | if (strlen(in_string) != (UUID_STR_LENGTH - 1)) /* Flawfinder: ignore */ | ||
319 | { | ||
320 | // I'm a moron. First implementation didn't have the right UUID format. | ||
321 | if (strlen(in_string) == (UUID_STR_LENGTH - 2)) /* Flawfinder: ignore */ | ||
322 | { | ||
323 | broken_format = TRUE; | ||
324 | } | ||
325 | else | ||
326 | { | ||
327 | return FALSE; | ||
328 | } | ||
329 | } | ||
330 | |||
331 | U8 cur_pos = 0; | ||
332 | U32 i; | ||
333 | for (i = 0; i < 16; i++) | ||
334 | { | ||
335 | if ((i == 4) || (i == 6) || (i == 8) || (i == 10)) | ||
336 | { | ||
337 | cur_pos++; | ||
338 | if (broken_format && (i==10)) | ||
339 | { | ||
340 | // Missing - in the broken format | ||
341 | cur_pos--; | ||
342 | } | ||
343 | } | ||
344 | |||
345 | if ((*(in_string + cur_pos) >= '0') && (*(in_string+cur_pos) <= '9')) | ||
346 | { | ||
347 | } | ||
348 | else if ((*(in_string + cur_pos) >= 'a') && (*(in_string+cur_pos) <='f')) | ||
349 | { | ||
350 | } | ||
351 | else if ((*(in_string + cur_pos) >= 'A') && (*(in_string+cur_pos) <='F')) | ||
352 | { | ||
353 | } | ||
354 | else | ||
355 | { | ||
356 | return FALSE; | ||
357 | } | ||
358 | |||
359 | cur_pos++; | ||
360 | |||
361 | if ((*(in_string + cur_pos) >= '0') && (*(in_string+cur_pos) <= '9')) | ||
362 | { | ||
363 | } | ||
364 | else if ((*(in_string + cur_pos) >= 'a') && (*(in_string+cur_pos) <='f')) | ||
365 | { | ||
366 | } | ||
367 | else if ((*(in_string + cur_pos) >= 'A') && (*(in_string+cur_pos) <='F')) | ||
368 | { | ||
369 | } | ||
370 | else | ||
371 | { | ||
372 | return FALSE; | ||
373 | } | ||
374 | cur_pos++; | ||
375 | } | ||
376 | return TRUE; | ||
377 | } | ||
378 | |||
379 | const LLUUID& LLUUID::operator^=(const LLUUID& rhs) | ||
380 | { | ||
381 | U32* me = (U32*)&(mData[0]); | ||
382 | const U32* other = (U32*)&(rhs.mData[0]); | ||
383 | for(S32 i = 0; i < 4; ++i) | ||
384 | { | ||
385 | me[i] = me[i] ^ other[i]; | ||
386 | } | ||
387 | return *this; | ||
388 | } | ||
389 | |||
390 | LLUUID LLUUID::operator^(const LLUUID& rhs) const | ||
391 | { | ||
392 | LLUUID id(*this); | ||
393 | id ^= rhs; | ||
394 | return id; | ||
395 | } | ||
396 | |||
397 | void LLUUID::combine(const LLUUID& other, LLUUID& result) const | ||
398 | { | ||
399 | LLMD5 md5_uuid; | ||
400 | md5_uuid.update((unsigned char*)mData, 16); | ||
401 | md5_uuid.update((unsigned char*)other.mData, 16); | ||
402 | md5_uuid.finalize(); | ||
403 | md5_uuid.raw_digest(result.mData); | ||
404 | } | ||
405 | |||
406 | LLUUID LLUUID::combine(const LLUUID &other) const | ||
407 | { | ||
408 | LLUUID combination; | ||
409 | combine(other, combination); | ||
410 | return combination; | ||
411 | } | ||
412 | |||
413 | std::ostream& operator<<(std::ostream& s, const LLUUID &uuid) | ||
414 | { | ||
415 | char uuid_str[UUID_STR_LENGTH]; | ||
416 | |||
417 | uuid.toString(uuid_str); | ||
418 | s << uuid_str; | ||
419 | return s; | ||
420 | } | ||
421 | |||
422 | std::istream& operator>>(std::istream &s, LLUUID &uuid) | ||
423 | { | ||
424 | U32 i; | ||
425 | char uuid_str[UUID_STR_LENGTH]; /* Flawfinder: ignore */ | ||
426 | for (i = 0; i < UUID_STR_LENGTH-1; i++) | ||
427 | { | ||
428 | s >> uuid_str[i]; | ||
429 | } | ||
430 | uuid_str[i] = '\0'; | ||
431 | uuid.set(uuid_str); | ||
432 | return s; | ||
433 | } | ||
434 | |||
435 | static void get_random_bytes(void *buf, int nbytes) | ||
436 | { | ||
437 | int i; | ||
438 | char *cp = (char *) buf; | ||
439 | |||
440 | // *NOTE: If we are not using the janky generator ll_rand() | ||
441 | // generates at least 3 good bytes of data since it is 0 to | ||
442 | // RAND_MAX. This could be made more efficient by copying all the | ||
443 | // bytes. | ||
444 | for (i=0; i < nbytes; i++) | ||
445 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
446 | *cp++ = janky_fast_random_bytes() & 0xFF; | ||
447 | #else | ||
448 | *cp++ = ll_rand() & 0xFF; | ||
449 | #endif | ||
450 | return; | ||
451 | } | ||
452 | |||
453 | #if LL_WINDOWS | ||
454 | typedef struct _ASTAT_ | ||
455 | { | ||
456 | ADAPTER_STATUS adapt; | ||
457 | NAME_BUFFER NameBuff [30]; | ||
458 | }ASTAT, * PASTAT; | ||
459 | |||
460 | // static | ||
461 | S32 LLUUID::getNodeID(unsigned char * node_id) | ||
462 | { | ||
463 | ASTAT Adapter; | ||
464 | NCB Ncb; | ||
465 | UCHAR uRetCode; | ||
466 | LANA_ENUM lenum; | ||
467 | int i; | ||
468 | int retval = 0; | ||
469 | |||
470 | memset( &Ncb, 0, sizeof(Ncb) ); | ||
471 | Ncb.ncb_command = NCBENUM; | ||
472 | Ncb.ncb_buffer = (UCHAR *)&lenum; | ||
473 | Ncb.ncb_length = sizeof(lenum); | ||
474 | uRetCode = Netbios( &Ncb ); | ||
475 | // printf( "The NCBENUM return code is: 0x%x \n", uRetCode ); | ||
476 | |||
477 | for(i=0; i < lenum.length ;i++) | ||
478 | { | ||
479 | memset( &Ncb, 0, sizeof(Ncb) ); | ||
480 | Ncb.ncb_command = NCBRESET; | ||
481 | Ncb.ncb_lana_num = lenum.lana[i]; | ||
482 | |||
483 | uRetCode = Netbios( &Ncb ); | ||
484 | // printf( "The NCBRESET on LANA %d return code is: 0x%x \n", | ||
485 | // lenum.lana[i], uRetCode ); | ||
486 | |||
487 | memset( &Ncb, 0, sizeof (Ncb) ); | ||
488 | Ncb.ncb_command = NCBASTAT; | ||
489 | Ncb.ncb_lana_num = lenum.lana[i]; | ||
490 | |||
491 | strcpy( (char *)Ncb.ncb_callname, "* " ); /* Flawfinder: ignore */ | ||
492 | Ncb.ncb_buffer = (unsigned char *)&Adapter; | ||
493 | Ncb.ncb_length = sizeof(Adapter); | ||
494 | |||
495 | uRetCode = Netbios( &Ncb ); | ||
496 | // printf( "The NCBASTAT on LANA %d return code is: 0x%x \n", | ||
497 | // lenum.lana[i], uRetCode ); | ||
498 | if ( uRetCode == 0 ) | ||
499 | { | ||
500 | // printf( "The Ethernet Number on LANA %d is: %02x%02x%02x%02x%02x%02x\n", | ||
501 | // lenum.lana[i], | ||
502 | // Adapter.adapt.adapter_address[0], | ||
503 | // Adapter.adapt.adapter_address[1], | ||
504 | // Adapter.adapt.adapter_address[2], | ||
505 | // Adapter.adapt.adapter_address[3], | ||
506 | // Adapter.adapt.adapter_address[4], | ||
507 | // Adapter.adapt.adapter_address[5] ); | ||
508 | memcpy(node_id,Adapter.adapt.adapter_address,6); /* Flawfinder: ignore */ | ||
509 | retval = 1; | ||
510 | |||
511 | } | ||
512 | } | ||
513 | return retval; | ||
514 | } | ||
515 | |||
516 | #elif LL_DARWIN | ||
517 | // Mac OS X version of the UUID generation code... | ||
518 | /* | ||
519 | * Get an ethernet hardware address, if we can find it... | ||
520 | */ | ||
521 | #include <unistd.h> | ||
522 | #include <sys/types.h> | ||
523 | #include <sys/time.h> | ||
524 | #include <sys/socket.h> | ||
525 | #include <sys/ioctl.h> | ||
526 | #include <net/if.h> | ||
527 | #include <net/if_types.h> | ||
528 | #include <net/if_dl.h> | ||
529 | #include <net/route.h> | ||
530 | #include <ifaddrs.h> | ||
531 | |||
532 | // static | ||
533 | S32 LLUUID::getNodeID(unsigned char *node_id) | ||
534 | { | ||
535 | int i; | ||
536 | unsigned char *a = NULL; | ||
537 | struct ifaddrs *ifap, *ifa; | ||
538 | int rv; | ||
539 | S32 result = 0; | ||
540 | |||
541 | if ((rv=getifaddrs(&ifap))==-1) | ||
542 | { | ||
543 | return -1; | ||
544 | } | ||
545 | if (ifap == NULL) | ||
546 | { | ||
547 | return -1; | ||
548 | } | ||
549 | |||
550 | for (ifa = ifap; ifa != NULL; ifa = ifa->ifa_next) | ||
551 | { | ||
552 | // printf("Interface %s, address family %d, ", ifa->ifa_name, ifa->ifa_addr->sa_family); | ||
553 | for(i=0; i< ifa->ifa_addr->sa_len; i++) | ||
554 | { | ||
555 | // printf("%02X ", (unsigned char)ifa->ifa_addr->sa_data[i]); | ||
556 | } | ||
557 | // printf("\n"); | ||
558 | |||
559 | if(ifa->ifa_addr->sa_family == AF_LINK) | ||
560 | { | ||
561 | // This is a link-level address | ||
562 | struct sockaddr_dl *lla = (struct sockaddr_dl *)ifa->ifa_addr; | ||
563 | |||
564 | // printf("\tLink level address, type %02X\n", lla->sdl_type); | ||
565 | |||
566 | if(lla->sdl_type == IFT_ETHER) | ||
567 | { | ||
568 | // Use the first ethernet MAC in the list. | ||
569 | // For some reason, the macro LLADDR() defined in net/if_dl.h doesn't expand correctly. This is what it would do. | ||
570 | a = (unsigned char *)&((lla)->sdl_data); | ||
571 | a += (lla)->sdl_nlen; | ||
572 | |||
573 | if (!a[0] && !a[1] && !a[2] && !a[3] && !a[4] && !a[5]) | ||
574 | { | ||
575 | continue; | ||
576 | } | ||
577 | |||
578 | if (node_id) | ||
579 | { | ||
580 | memcpy(node_id, a, 6); | ||
581 | result = 1; | ||
582 | } | ||
583 | |||
584 | // We found one. | ||
585 | break; | ||
586 | } | ||
587 | } | ||
588 | } | ||
589 | freeifaddrs(ifap); | ||
590 | |||
591 | return result; | ||
592 | } | ||
593 | |||
594 | #else | ||
595 | |||
596 | // Linux version of the UUID generation code... | ||
597 | /* | ||
598 | * Get the ethernet hardware address, if we can find it... | ||
599 | */ | ||
600 | #include <unistd.h> | ||
601 | #include <fcntl.h> | ||
602 | #include <errno.h> | ||
603 | #include <sys/types.h> | ||
604 | #include <sys/time.h> | ||
605 | #include <sys/stat.h> | ||
606 | #include <sys/file.h> | ||
607 | #include <sys/ioctl.h> | ||
608 | #include <sys/socket.h> | ||
609 | #include <net/if.h> | ||
610 | #define HAVE_NETINET_IN_H | ||
611 | #ifdef HAVE_NETINET_IN_H | ||
612 | #include <netinet/in.h> | ||
613 | #if LL_SOLARIS | ||
614 | #include <sys/sockio.h> | ||
615 | #elif !LL_DARWIN | ||
616 | #include <linux/sockios.h> | ||
617 | #endif | ||
618 | #endif | ||
619 | |||
620 | // static | ||
621 | S32 LLUUID::getNodeID(unsigned char *node_id) | ||
622 | { | ||
623 | int sd; | ||
624 | struct ifreq ifr, *ifrp; | ||
625 | struct ifconf ifc; | ||
626 | char buf[1024]; | ||
627 | int n, i; | ||
628 | unsigned char *a; | ||
629 | |||
630 | /* | ||
631 | * BSD 4.4 defines the size of an ifreq to be | ||
632 | * max(sizeof(ifreq), sizeof(ifreq.ifr_name)+ifreq.ifr_addr.sa_len | ||
633 | * However, under earlier systems, sa_len isn't present, so the size is | ||
634 | * just sizeof(struct ifreq) | ||
635 | */ | ||
636 | #ifdef HAVE_SA_LEN | ||
637 | #ifndef max | ||
638 | #define max(a,b) ((a) > (b) ? (a) : (b)) | ||
639 | #endif | ||
640 | #define ifreq_size(i) max(sizeof(struct ifreq),\ | ||
641 | sizeof((i).ifr_name)+(i).ifr_addr.sa_len) | ||
642 | #else | ||
643 | #define ifreq_size(i) sizeof(struct ifreq) | ||
644 | #endif /* HAVE_SA_LEN*/ | ||
645 | |||
646 | sd = socket(AF_INET, SOCK_DGRAM, IPPROTO_IP); | ||
647 | if (sd < 0) { | ||
648 | return -1; | ||
649 | } | ||
650 | memset(buf, 0, sizeof(buf)); | ||
651 | ifc.ifc_len = sizeof(buf); | ||
652 | ifc.ifc_buf = buf; | ||
653 | if (ioctl (sd, SIOCGIFCONF, (char *)&ifc) < 0) { | ||
654 | close(sd); | ||
655 | return -1; | ||
656 | } | ||
657 | n = ifc.ifc_len; | ||
658 | for (i = 0; i < n; i+= ifreq_size(*ifr) ) { | ||
659 | ifrp = (struct ifreq *)((char *) ifc.ifc_buf+i); | ||
660 | strncpy(ifr.ifr_name, ifrp->ifr_name, IFNAMSIZ); /* Flawfinder: ignore */ | ||
661 | #ifdef SIOCGIFHWADDR | ||
662 | if (ioctl(sd, SIOCGIFHWADDR, &ifr) < 0) | ||
663 | continue; | ||
664 | a = (unsigned char *) &ifr.ifr_hwaddr.sa_data; | ||
665 | #else | ||
666 | #ifdef SIOCGENADDR | ||
667 | if (ioctl(sd, SIOCGENADDR, &ifr) < 0) | ||
668 | continue; | ||
669 | a = (unsigned char *) ifr.ifr_enaddr; | ||
670 | #else | ||
671 | /* | ||
672 | * XXX we don't have a way of getting the hardware | ||
673 | * address | ||
674 | */ | ||
675 | close(sd); | ||
676 | return 0; | ||
677 | #endif /* SIOCGENADDR */ | ||
678 | #endif /* SIOCGIFHWADDR */ | ||
679 | if (!a[0] && !a[1] && !a[2] && !a[3] && !a[4] && !a[5]) | ||
680 | continue; | ||
681 | if (node_id) { | ||
682 | memcpy(node_id, a, 6); /* Flawfinder: ignore */ | ||
683 | close(sd); | ||
684 | return 1; | ||
685 | } | ||
686 | } | ||
687 | close(sd); | ||
688 | return 0; | ||
689 | } | ||
690 | |||
691 | #endif | ||
692 | |||
693 | S32 LLUUID::cmpTime(uuid_time_t *t1, uuid_time_t *t2) | ||
694 | { | ||
695 | // Compare two time values. | ||
696 | |||
697 | if (t1->high < t2->high) return -1; | ||
698 | if (t1->high > t2->high) return 1; | ||
699 | if (t1->low < t2->low) return -1; | ||
700 | if (t1->low > t2->low) return 1; | ||
701 | return 0; | ||
702 | } | ||
703 | |||
704 | void LLUUID::getSystemTime(uuid_time_t *timestamp) | ||
705 | { | ||
706 | // Get system time with 100ns precision. Time is since Oct 15, 1582. | ||
707 | #if LL_WINDOWS | ||
708 | ULARGE_INTEGER time; | ||
709 | GetSystemTimeAsFileTime((FILETIME *)&time); | ||
710 | // NT keeps time in FILETIME format which is 100ns ticks since | ||
711 | // Jan 1, 1601. UUIDs use time in 100ns ticks since Oct 15, 1582. | ||
712 | // The difference is 17 Days in Oct + 30 (Nov) + 31 (Dec) | ||
713 | // + 18 years and 5 leap days. | ||
714 | time.QuadPart += | ||
715 | (unsigned __int64) (1000*1000*10) // seconds | ||
716 | * (unsigned __int64) (60 * 60 * 24) // days | ||
717 | * (unsigned __int64) (17+30+31+365*18+5); // # of days | ||
718 | |||
719 | timestamp->high = time.HighPart; | ||
720 | timestamp->low = time.LowPart; | ||
721 | #else | ||
722 | struct timeval tp; | ||
723 | gettimeofday(&tp, 0); | ||
724 | |||
725 | // Offset between UUID formatted times and Unix formatted times. | ||
726 | // UUID UTC base time is October 15, 1582. | ||
727 | // Unix base time is January 1, 1970. | ||
728 | U64 uuid_time = ((U64)tp.tv_sec * 10000000) + (tp.tv_usec * 10) + | ||
729 | U64L(0x01B21DD213814000); | ||
730 | timestamp->high = (U32) (uuid_time >> 32); | ||
731 | timestamp->low = (U32) (uuid_time & 0xFFFFFFFF); | ||
732 | #endif | ||
733 | } | ||
734 | |||
735 | void LLUUID::getCurrentTime(uuid_time_t *timestamp) | ||
736 | { | ||
737 | // Get current time as 60 bit 100ns ticks since whenever. | ||
738 | // Compensate for the fact that real clock resolution is less | ||
739 | // than 100ns. | ||
740 | |||
741 | const U32 uuids_per_tick = 1024; | ||
742 | |||
743 | static uuid_time_t time_last; | ||
744 | static U32 uuids_this_tick; | ||
745 | static BOOL init = FALSE; | ||
746 | |||
747 | if (!init) { | ||
748 | getSystemTime(&time_last); | ||
749 | uuids_this_tick = uuids_per_tick; | ||
750 | init = TRUE; | ||
751 | } | ||
752 | |||
753 | uuid_time_t time_now = {0,0}; | ||
754 | |||
755 | while (1) { | ||
756 | getSystemTime(&time_now); | ||
757 | |||
758 | // if clock reading changed since last UUID generated | ||
759 | if (cmpTime(&time_last, &time_now)) { | ||
760 | // reset count of uuid's generated with this clock reading | ||
761 | uuids_this_tick = 0; | ||
762 | break; | ||
763 | } | ||
764 | if (uuids_this_tick < uuids_per_tick) { | ||
765 | uuids_this_tick++; | ||
766 | break; | ||
767 | } | ||
768 | // going too fast for our clock; spin | ||
769 | } | ||
770 | |||
771 | time_last = time_now; | ||
772 | |||
773 | if (uuids_this_tick != 0) { | ||
774 | if (time_now.low & 0x80000000) { | ||
775 | time_now.low += uuids_this_tick; | ||
776 | if (!(time_now.low & 0x80000000)) | ||
777 | time_now.high++; | ||
778 | } else | ||
779 | time_now.low += uuids_this_tick; | ||
780 | } | ||
781 | |||
782 | timestamp->high = time_now.high; | ||
783 | timestamp->low = time_now.low; | ||
784 | } | ||
785 | |||
786 | void LLUUID::generate() | ||
787 | { | ||
788 | // Create a UUID. | ||
789 | uuid_time_t timestamp; | ||
790 | |||
791 | static unsigned char node_id[6]; /* Flawfinder: ignore */ | ||
792 | static int has_init = 0; | ||
793 | |||
794 | // Create a UUID. | ||
795 | static uuid_time_t time_last = {0,0}; | ||
796 | static U16 clock_seq = 0; | ||
797 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
798 | static U32 seed = 0L; // dummy seed. reset it below | ||
799 | #endif | ||
800 | if (!has_init) | ||
801 | { | ||
802 | if (getNodeID(node_id) <= 0) | ||
803 | { | ||
804 | get_random_bytes(node_id, 6); | ||
805 | /* | ||
806 | * Set multicast bit, to prevent conflicts | ||
807 | * with IEEE 802 addresses obtained from | ||
808 | * network cards | ||
809 | */ | ||
810 | node_id[0] |= 0x80; | ||
811 | } | ||
812 | |||
813 | getCurrentTime(&time_last); | ||
814 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
815 | seed = time_last.low; | ||
816 | #endif | ||
817 | |||
818 | #if LL_USE_JANKY_RANDOM_NUMBER_GENERATOR | ||
819 | clock_seq = (U16)janky_fast_random_seeded_bytes(seed, 65536); | ||
820 | #else | ||
821 | clock_seq = (U16)ll_rand(65536); | ||
822 | #endif | ||
823 | has_init = 1; | ||
824 | } | ||
825 | |||
826 | // get current time | ||
827 | getCurrentTime(×tamp); | ||
828 | |||
829 | // if clock went backward change clockseq | ||
830 | if (cmpTime(×tamp, &time_last) == -1) { | ||
831 | clock_seq = (clock_seq + 1) & 0x3FFF; | ||
832 | if (clock_seq == 0) clock_seq++; | ||
833 | } | ||
834 | |||
835 | memcpy(mData+10, node_id, 6); /* Flawfinder: ignore */ | ||
836 | U32 tmp; | ||
837 | tmp = timestamp.low; | ||
838 | mData[3] = (unsigned char) tmp; | ||
839 | tmp >>= 8; | ||
840 | mData[2] = (unsigned char) tmp; | ||
841 | tmp >>= 8; | ||
842 | mData[1] = (unsigned char) tmp; | ||
843 | tmp >>= 8; | ||
844 | mData[0] = (unsigned char) tmp; | ||
845 | |||
846 | tmp = (U16) timestamp.high; | ||
847 | mData[5] = (unsigned char) tmp; | ||
848 | tmp >>= 8; | ||
849 | mData[4] = (unsigned char) tmp; | ||
850 | |||
851 | tmp = (timestamp.high >> 16) | 0x1000; | ||
852 | mData[7] = (unsigned char) tmp; | ||
853 | tmp >>= 8; | ||
854 | mData[6] = (unsigned char) tmp; | ||
855 | |||
856 | tmp = clock_seq; | ||
857 | mData[9] = (unsigned char) tmp; | ||
858 | tmp >>= 8; | ||
859 | mData[8] = (unsigned char) tmp; | ||
860 | |||
861 | LLMD5 md5_uuid; | ||
862 | |||
863 | md5_uuid.update(mData,16); | ||
864 | md5_uuid.finalize(); | ||
865 | md5_uuid.raw_digest(mData); | ||
866 | |||
867 | time_last = timestamp; | ||
868 | } | ||
869 | |||
870 | void LLUUID::generate(std::string hash_string) | ||
871 | { | ||
872 | LLMD5 md5_uuid((U8*)hash_string.c_str()); | ||
873 | md5_uuid.raw_digest(mData); | ||
874 | } | ||
875 | |||
876 | U32 LLUUID::getRandomSeed() | ||
877 | { | ||
878 | static unsigned char seed[16]; /* Flawfinder: ignore */ | ||
879 | |||
880 | getNodeID(&seed[0]); | ||
881 | seed[6]='\0'; | ||
882 | seed[7]='\0'; | ||
883 | getSystemTime((uuid_time_t *)(&seed[8])); | ||
884 | |||
885 | LLMD5 md5_seed; | ||
886 | |||
887 | md5_seed.update(seed,16); | ||
888 | md5_seed.finalize(); | ||
889 | md5_seed.raw_digest(seed); | ||
890 | |||
891 | return(*(U32 *)seed); | ||
892 | } | ||
893 | |||
894 | BOOL LLUUID::parseUUID(const char* buf, LLUUID* value) | ||
895 | { | ||
896 | if( buf == NULL || buf[0] == '\0' || value == NULL) | ||
897 | { | ||
898 | return FALSE; | ||
899 | } | ||
900 | |||
901 | LLString temp( buf ); | ||
902 | LLString::trim(temp); | ||
903 | if( LLUUID::validate( temp ) ) | ||
904 | { | ||
905 | value->set( temp ); | ||
906 | return TRUE; | ||
907 | } | ||
908 | return FALSE; | ||
909 | } | ||
910 | |||
911 | LLAssetID LLTransactionID::makeAssetID(const LLUUID& session) const | ||
912 | { | ||
913 | LLAssetID result; | ||
914 | if (isNull()) | ||
915 | { | ||
916 | result.setNull(); | ||
917 | } | ||
918 | else | ||
919 | { | ||
920 | combine(session, result); | ||
921 | } | ||
922 | return result; | ||
923 | } | ||
diff --git a/linden/indra/llmath/lluuid.h b/linden/indra/llmath/lluuid.h deleted file mode 100644 index 48308f2..0000000 --- a/linden/indra/llmath/lluuid.h +++ /dev/null | |||
@@ -1,330 +0,0 @@ | |||
1 | /** | ||
2 | * @file lluuid.h | ||
3 | * | ||
4 | * $LicenseInfo:firstyear=2000&license=viewergpl$ | ||
5 | * | ||
6 | * Copyright (c) 2000-2008, Linden Research, Inc. | ||
7 | * | ||
8 | * Second Life Viewer Source Code | ||
9 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
10 | * to you under the terms of the GNU General Public License, version 2.0 | ||
11 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
12 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
13 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
14 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
15 | * | ||
16 | * There are special exceptions to the terms and conditions of the GPL as | ||
17 | * it is applied to this Source Code. View the full text of the exception | ||
18 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
19 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
20 | * | ||
21 | * By copying, modifying or distributing this software, you acknowledge | ||
22 | * that you have read and understood your obligations described above, | ||
23 | * and agree to abide by those obligations. | ||
24 | * | ||
25 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
26 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
27 | * COMPLETENESS OR PERFORMANCE. | ||
28 | * $/LicenseInfo$ | ||
29 | */ | ||
30 | |||
31 | #ifndef LL_LLUUID_H | ||
32 | #define LL_LLUUID_H | ||
33 | |||
34 | #include <iostream> | ||
35 | #include <set> | ||
36 | #include "stdtypes.h" | ||
37 | |||
38 | const S32 UUID_BYTES = 16; | ||
39 | const S32 UUID_WORDS = 4; | ||
40 | const S32 UUID_STR_LENGTH = 37; // actually wrong, should be 36 and use size below | ||
41 | const S32 UUID_STR_SIZE = 37; | ||
42 | const S32 UUID_BASE85_LENGTH = 21; // including the trailing NULL. | ||
43 | |||
44 | struct uuid_time_t { | ||
45 | U32 high; | ||
46 | U32 low; | ||
47 | }; | ||
48 | |||
49 | class LLUUID | ||
50 | { | ||
51 | public: | ||
52 | // | ||
53 | // CREATORS | ||
54 | // | ||
55 | LLUUID(); | ||
56 | explicit LLUUID(const char *in_string); // Convert from string. | ||
57 | explicit LLUUID(const std::string& in_string); // Convert from string. | ||
58 | LLUUID(const LLUUID &in); | ||
59 | LLUUID &operator=(const LLUUID &rhs); | ||
60 | |||
61 | ~LLUUID(); | ||
62 | |||
63 | // | ||
64 | // MANIPULATORS | ||
65 | // | ||
66 | void generate(); // Generate a new UUID | ||
67 | void generate(std::string stream); //Generate a new UUID based on hash of input stream | ||
68 | BOOL set(const char *in_string, BOOL emit = TRUE); // Convert from string, if emit is FALSE, do not emit warnings | ||
69 | BOOL set(const std::string& in_string, BOOL emit = TRUE); // Convert from string, if emit is FALSE, do not emit warnings | ||
70 | void setNull(); // Faster than setting to LLUUID::null. | ||
71 | |||
72 | S32 cmpTime(uuid_time_t *t1, uuid_time_t *t2); | ||
73 | static void getSystemTime(uuid_time_t *timestamp); | ||
74 | void getCurrentTime(uuid_time_t *timestamp); | ||
75 | |||
76 | // | ||
77 | // ACCESSORS | ||
78 | // | ||
79 | BOOL isNull() const; // Faster than comparing to LLUUID::null. | ||
80 | BOOL notNull() const; // Faster than comparing to LLUUID::null. | ||
81 | // JC: This is dangerous. It allows UUIDs to be cast automatically | ||
82 | // to integers, among other things. Use isNull() or notNull(). | ||
83 | // operator bool() const; | ||
84 | |||
85 | // JC: These must return real bool's (not BOOLs) or else use of the STL | ||
86 | // will generate bool-to-int performance warnings. | ||
87 | bool operator==(const LLUUID &rhs) const; | ||
88 | bool operator!=(const LLUUID &rhs) const; | ||
89 | bool operator<(const LLUUID &rhs) const; | ||
90 | bool operator>(const LLUUID &rhs) const; | ||
91 | |||
92 | // xor functions. Useful since any two random uuids xored together | ||
93 | // will yield a determinate third random unique id that can be | ||
94 | // used as a key in a single uuid that represents 2. | ||
95 | const LLUUID& operator^=(const LLUUID& rhs); | ||
96 | LLUUID operator^(const LLUUID& rhs) const; | ||
97 | |||
98 | // similar to functions above, but not invertible | ||
99 | // yields a third random UUID that can be reproduced from the two inputs | ||
100 | // but which, given the result and one of the inputs can't be used to | ||
101 | // deduce the other input | ||
102 | LLUUID combine(const LLUUID& other) const; | ||
103 | void combine(const LLUUID& other, LLUUID& result) const; | ||
104 | |||
105 | friend std::ostream& operator<<(std::ostream& s, const LLUUID &uuid); | ||
106 | friend std::istream& operator>>(std::istream& s, LLUUID &uuid); | ||
107 | |||
108 | void toString(char *out) const; // Does not allocate memory, needs 36 characters (including \0) | ||
109 | void toCompressedString(char *out) const; // Does not allocate memory, needs 17 characters (including \0) | ||
110 | |||
111 | std::string asString() const; | ||
112 | std::string getString() const; | ||
113 | |||
114 | U16 getCRC16() const; | ||
115 | U32 getCRC32() const; | ||
116 | |||
117 | static BOOL validate(const std::string& in_string); // Validate that the UUID string is legal. | ||
118 | static BOOL validate(const char *in_string); // Validate that the UUID string is legal. | ||
119 | |||
120 | static const LLUUID null; | ||
121 | |||
122 | static U32 getRandomSeed(); | ||
123 | static S32 getNodeID(unsigned char * node_id); | ||
124 | |||
125 | static BOOL parseUUID(const char* buf, LLUUID* value); | ||
126 | |||
127 | U8 mData[UUID_BYTES]; | ||
128 | }; | ||
129 | |||
130 | |||
131 | // Construct | ||
132 | inline LLUUID::LLUUID() | ||
133 | { | ||
134 | setNull(); | ||
135 | } | ||
136 | |||
137 | |||
138 | // Faster than copying from memory | ||
139 | inline void LLUUID::setNull() | ||
140 | { | ||
141 | U32 *word = (U32 *)mData; | ||
142 | word[0] = 0; | ||
143 | word[1] = 0; | ||
144 | word[2] = 0; | ||
145 | word[3] = 0; | ||
146 | } | ||
147 | |||
148 | |||
149 | // Compare | ||
150 | inline bool LLUUID::operator==(const LLUUID& rhs) const | ||
151 | { | ||
152 | U32 *tmp = (U32 *)mData; | ||
153 | U32 *rhstmp = (U32 *)rhs.mData; | ||
154 | // Note: binary & to avoid branching | ||
155 | return | ||
156 | (tmp[0] == rhstmp[0]) & | ||
157 | (tmp[1] == rhstmp[1]) & | ||
158 | (tmp[2] == rhstmp[2]) & | ||
159 | (tmp[3] == rhstmp[3]); | ||
160 | } | ||
161 | |||
162 | |||
163 | inline bool LLUUID::operator!=(const LLUUID& rhs) const | ||
164 | { | ||
165 | U32 *tmp = (U32 *)mData; | ||
166 | U32 *rhstmp = (U32 *)rhs.mData; | ||
167 | // Note: binary | to avoid branching | ||
168 | return | ||
169 | (tmp[0] != rhstmp[0]) | | ||
170 | (tmp[1] != rhstmp[1]) | | ||
171 | (tmp[2] != rhstmp[2]) | | ||
172 | (tmp[3] != rhstmp[3]); | ||
173 | } | ||
174 | |||
175 | /* | ||
176 | // JC: This is dangerous. It allows UUIDs to be cast automatically | ||
177 | // to integers, among other things. Use isNull() or notNull(). | ||
178 | inline LLUUID::operator bool() const | ||
179 | { | ||
180 | U32 *word = (U32 *)mData; | ||
181 | return (word[0] | word[1] | word[2] | word[3]) > 0; | ||
182 | } | ||
183 | */ | ||
184 | |||
185 | inline BOOL LLUUID::notNull() const | ||
186 | { | ||
187 | U32 *word = (U32 *)mData; | ||
188 | return (word[0] | word[1] | word[2] | word[3]) > 0; | ||
189 | } | ||
190 | |||
191 | // Faster than == LLUUID::null because doesn't require | ||
192 | // as much memory access. | ||
193 | inline BOOL LLUUID::isNull() const | ||
194 | { | ||
195 | U32 *word = (U32 *)mData; | ||
196 | // If all bits are zero, return !0 == TRUE | ||
197 | return !(word[0] | word[1] | word[2] | word[3]); | ||
198 | } | ||
199 | |||
200 | // Copy constructor | ||
201 | inline LLUUID::LLUUID(const LLUUID& rhs) | ||
202 | { | ||
203 | U32 *tmp = (U32 *)mData; | ||
204 | U32 *rhstmp = (U32 *)rhs.mData; | ||
205 | tmp[0] = rhstmp[0]; | ||
206 | tmp[1] = rhstmp[1]; | ||
207 | tmp[2] = rhstmp[2]; | ||
208 | tmp[3] = rhstmp[3]; | ||
209 | } | ||
210 | |||
211 | inline LLUUID::~LLUUID() | ||
212 | { | ||
213 | } | ||
214 | |||
215 | // Assignment | ||
216 | inline LLUUID& LLUUID::operator=(const LLUUID& rhs) | ||
217 | { | ||
218 | // No need to check the case where this==&rhs. The branch is slower than the write. | ||
219 | U32 *tmp = (U32 *)mData; | ||
220 | U32 *rhstmp = (U32 *)rhs.mData; | ||
221 | tmp[0] = rhstmp[0]; | ||
222 | tmp[1] = rhstmp[1]; | ||
223 | tmp[2] = rhstmp[2]; | ||
224 | tmp[3] = rhstmp[3]; | ||
225 | |||
226 | return *this; | ||
227 | } | ||
228 | |||
229 | |||
230 | inline LLUUID::LLUUID(const char *in_string) | ||
231 | { | ||
232 | if (!in_string || in_string[0] == 0) | ||
233 | { | ||
234 | setNull(); | ||
235 | return; | ||
236 | } | ||
237 | |||
238 | set(in_string); | ||
239 | } | ||
240 | |||
241 | inline LLUUID::LLUUID(const std::string& in_string) | ||
242 | { | ||
243 | if (in_string.empty()) | ||
244 | { | ||
245 | setNull(); | ||
246 | return; | ||
247 | } | ||
248 | |||
249 | set(in_string); | ||
250 | } | ||
251 | |||
252 | // IW: DON'T "optimize" these w/ U32s or you'll scoogie the sort order | ||
253 | // IW: this will make me very sad | ||
254 | inline bool LLUUID::operator<(const LLUUID &rhs) const | ||
255 | { | ||
256 | U32 i; | ||
257 | for( i = 0; i < (UUID_BYTES - 1); i++ ) | ||
258 | { | ||
259 | if( mData[i] != rhs.mData[i] ) | ||
260 | { | ||
261 | return (mData[i] < rhs.mData[i]); | ||
262 | } | ||
263 | } | ||
264 | return (mData[UUID_BYTES - 1] < rhs.mData[UUID_BYTES - 1]); | ||
265 | } | ||
266 | |||
267 | inline bool LLUUID::operator>(const LLUUID &rhs) const | ||
268 | { | ||
269 | U32 i; | ||
270 | for( i = 0; i < (UUID_BYTES - 1); i++ ) | ||
271 | { | ||
272 | if( mData[i] != rhs.mData[i] ) | ||
273 | { | ||
274 | return (mData[i] > rhs.mData[i]); | ||
275 | } | ||
276 | } | ||
277 | return (mData[UUID_BYTES - 1] > rhs.mData[UUID_BYTES - 1]); | ||
278 | } | ||
279 | |||
280 | inline U16 LLUUID::getCRC16() const | ||
281 | { | ||
282 | // A UUID is 16 bytes, or 8 shorts. | ||
283 | U16 *short_data = (U16*)mData; | ||
284 | U16 out = 0; | ||
285 | out += short_data[0]; | ||
286 | out += short_data[1]; | ||
287 | out += short_data[2]; | ||
288 | out += short_data[3]; | ||
289 | out += short_data[4]; | ||
290 | out += short_data[5]; | ||
291 | out += short_data[6]; | ||
292 | out += short_data[7]; | ||
293 | return out; | ||
294 | } | ||
295 | |||
296 | inline U32 LLUUID::getCRC32() const | ||
297 | { | ||
298 | U32 *tmp = (U32*)mData; | ||
299 | return tmp[0] + tmp[1] + tmp[2] + tmp[3]; | ||
300 | } | ||
301 | |||
302 | |||
303 | // Helper structure for ordering lluuids in stl containers. | ||
304 | // eg: std::map<LLUUID, LLWidget*, lluuid_less> widget_map; | ||
305 | struct lluuid_less | ||
306 | { | ||
307 | bool operator()(const LLUUID& lhs, const LLUUID& rhs) const | ||
308 | { | ||
309 | return (lhs < rhs) ? true : false; | ||
310 | } | ||
311 | }; | ||
312 | |||
313 | typedef std::set<LLUUID, lluuid_less> uuid_list_t; | ||
314 | |||
315 | /* | ||
316 | * Sub-classes for keeping transaction IDs and asset IDs | ||
317 | * straight. | ||
318 | */ | ||
319 | typedef LLUUID LLAssetID; | ||
320 | |||
321 | class LLTransactionID : public LLUUID | ||
322 | { | ||
323 | public: | ||
324 | LLTransactionID() : LLUUID() { } | ||
325 | |||
326 | static const LLTransactionID tnull; | ||
327 | LLAssetID makeAssetID(const LLUUID& session) const; | ||
328 | }; | ||
329 | |||
330 | #endif | ||
diff --git a/linden/indra/llmath/llvolume.cpp b/linden/indra/llmath/llvolume.cpp index f7c9286..7b6c6a9 100644 --- a/linden/indra/llmath/llvolume.cpp +++ b/linden/indra/llmath/llvolume.cpp | |||
@@ -82,11 +82,6 @@ const F32 TAPER_MAX = 1.f; | |||
82 | const F32 SKEW_MIN = -0.95f; | 82 | const F32 SKEW_MIN = -0.95f; |
83 | const F32 SKEW_MAX = 0.95f; | 83 | const F32 SKEW_MAX = 0.95f; |
84 | 84 | ||
85 | const S32 SCULPT_REZ_1 = 6; // changed from 4 to 6 - 6 looks round whereas 4 looks square | ||
86 | const S32 SCULPT_REZ_2 = 8; | ||
87 | const S32 SCULPT_REZ_3 = 16; | ||
88 | const S32 SCULPT_REZ_4 = 32; | ||
89 | |||
90 | const F32 SCULPT_MIN_AREA = 0.002f; | 85 | const F32 SCULPT_MIN_AREA = 0.002f; |
91 | 86 | ||
92 | BOOL check_same_clock_dir( const LLVector3& pt1, const LLVector3& pt2, const LLVector3& pt3, const LLVector3& norm) | 87 | BOOL check_same_clock_dir( const LLVector3& pt1, const LLVector3& pt2, const LLVector3& pt3, const LLVector3& norm) |
@@ -104,46 +99,128 @@ BOOL check_same_clock_dir( const LLVector3& pt1, const LLVector3& pt2, const LLV | |||
104 | } | 99 | } |
105 | } | 100 | } |
106 | 101 | ||
107 | // intersect test between triangle pt1,pt2,pt3 and line from linept to linept+vect | 102 | BOOL LLLineSegmentBoxIntersect(const LLVector3& start, const LLVector3& end, const LLVector3& center, const LLVector3& size) |
108 | //returns TRUE if intersecting and moves linept to the point of intersection | 103 | { |
109 | BOOL LLTriangleLineSegmentIntersect( const LLVector3& pt1, const LLVector3& pt2, const LLVector3& pt3, LLVector3& linept, const LLVector3& vect) | 104 | float fAWdU[3]; |
105 | LLVector3 dir; | ||
106 | LLVector3 diff; | ||
107 | |||
108 | for (U32 i = 0; i < 3; i++) | ||
109 | { | ||
110 | dir.mV[i] = 0.5f * (end.mV[i] - start.mV[i]); | ||
111 | diff.mV[i] = (0.5f * (end.mV[i] + start.mV[i])) - center.mV[i]; | ||
112 | fAWdU[i] = fabsf(dir.mV[i]); | ||
113 | if(fabsf(diff.mV[i])>size.mV[i] + fAWdU[i]) return false; | ||
114 | } | ||
115 | |||
116 | float f; | ||
117 | f = dir.mV[1] * diff.mV[2] - dir.mV[2] * diff.mV[1]; if(fabsf(f)>size.mV[1]*fAWdU[2] + size.mV[2]*fAWdU[1]) return false; | ||
118 | f = dir.mV[2] * diff.mV[0] - dir.mV[0] * diff.mV[2]; if(fabsf(f)>size.mV[0]*fAWdU[2] + size.mV[2]*fAWdU[0]) return false; | ||
119 | f = dir.mV[0] * diff.mV[1] - dir.mV[1] * diff.mV[0]; if(fabsf(f)>size.mV[0]*fAWdU[1] + size.mV[1]*fAWdU[0]) return false; | ||
120 | |||
121 | return true; | ||
122 | } | ||
123 | |||
124 | |||
125 | // intersect test between triangle vert0, vert1, vert2 and a ray from orig in direction dir. | ||
126 | // returns TRUE if intersecting and returns barycentric coordinates in intersection_a, intersection_b, | ||
127 | // and returns the intersection point along dir in intersection_t. | ||
128 | |||
129 | // Moller-Trumbore algorithm | ||
130 | BOOL LLTriangleRayIntersect(const LLVector3& vert0, const LLVector3& vert1, const LLVector3& vert2, const LLVector3& orig, const LLVector3& dir, | ||
131 | F32* intersection_a, F32* intersection_b, F32* intersection_t, BOOL two_sided) | ||
110 | { | 132 | { |
111 | LLVector3 V1 = pt2-pt1; | 133 | F32 u, v, t; |
112 | LLVector3 V2 = pt3-pt2; | ||
113 | 134 | ||
114 | LLVector3 norm = V1 % V2; | 135 | /* find vectors for two edges sharing vert0 */ |
136 | LLVector3 edge1 = vert1 - vert0; | ||
115 | 137 | ||
116 | F32 dotprod = norm * vect; | 138 | LLVector3 edge2 = vert2 - vert0;; |
117 | 139 | ||
118 | if(dotprod < 0) | 140 | /* begin calculating determinant - also used to calculate U parameter */ |
141 | LLVector3 pvec = dir % edge2; | ||
142 | |||
143 | /* if determinant is near zero, ray lies in plane of triangle */ | ||
144 | F32 det = edge1 * pvec; | ||
145 | |||
146 | if (!two_sided) | ||
119 | { | 147 | { |
120 | //Find point of intersect to triangle plane. | 148 | if (det < F_APPROXIMATELY_ZERO) |
121 | //find t to intersect point | 149 | { |
122 | F32 t = -(norm * (linept-pt1))/dotprod; | 150 | return FALSE; |
151 | } | ||
152 | |||
153 | /* calculate distance from vert0 to ray origin */ | ||
154 | LLVector3 tvec = orig - vert0; | ||
123 | 155 | ||
124 | // if ds is neg line started past triangle so can't hit triangle. | 156 | /* calculate U parameter and test bounds */ |
125 | if (t > 0) | 157 | u = tvec * pvec; |
158 | |||
159 | if (u < 0.f || u > det) | ||
126 | { | 160 | { |
127 | return FALSE; | 161 | return FALSE; |
128 | } | 162 | } |
129 | 163 | ||
130 | LLVector3 pt_int = linept + (vect*t); | 164 | /* prepare to test V parameter */ |
165 | LLVector3 qvec = tvec % edge1; | ||
131 | 166 | ||
132 | if(check_same_clock_dir(pt1, pt2, pt_int, norm)) | 167 | /* calculate V parameter and test bounds */ |
168 | v = dir * qvec; | ||
169 | if (v < 0.f || u + v > det) | ||
133 | { | 170 | { |
134 | if(check_same_clock_dir(pt2, pt3, pt_int, norm)) | 171 | return FALSE; |
172 | } | ||
173 | |||
174 | /* calculate t, scale parameters, ray intersects triangle */ | ||
175 | t = edge2 * qvec; | ||
176 | F32 inv_det = 1.0 / det; | ||
177 | t *= inv_det; | ||
178 | u *= inv_det; | ||
179 | v *= inv_det; | ||
180 | } | ||
181 | |||
182 | else // two sided | ||
135 | { | 183 | { |
136 | if(check_same_clock_dir(pt3, pt1, pt_int, norm)) | 184 | if (det > -F_APPROXIMATELY_ZERO && det < F_APPROXIMATELY_ZERO) |
137 | { | 185 | { |
138 | // answer in pt_int is insde triangle | 186 | return FALSE; |
139 | linept.setVec(pt_int); | ||
140 | return TRUE; | ||
141 | } | 187 | } |
188 | F32 inv_det = 1.0 / det; | ||
189 | |||
190 | /* calculate distance from vert0 to ray origin */ | ||
191 | LLVector3 tvec = orig - vert0; | ||
192 | |||
193 | /* calculate U parameter and test bounds */ | ||
194 | u = (tvec * pvec) * inv_det; | ||
195 | if (u < 0.f || u > 1.f) | ||
196 | { | ||
197 | return FALSE; | ||
142 | } | 198 | } |
199 | |||
200 | /* prepare to test V parameter */ | ||
201 | LLVector3 qvec = tvec - edge1; | ||
202 | |||
203 | /* calculate V parameter and test bounds */ | ||
204 | v = (dir * qvec) * inv_det; | ||
205 | |||
206 | if (v < 0.f || u + v > 1.f) | ||
207 | { | ||
208 | return FALSE; | ||
143 | } | 209 | } |
210 | |||
211 | /* calculate t, ray intersects triangle */ | ||
212 | t = (edge2 * qvec) * inv_det; | ||
144 | } | 213 | } |
145 | 214 | ||
146 | return FALSE; | 215 | if (intersection_a != NULL) |
216 | *intersection_a = u; | ||
217 | if (intersection_b != NULL) | ||
218 | *intersection_b = v; | ||
219 | if (intersection_t != NULL) | ||
220 | *intersection_t = t; | ||
221 | |||
222 | |||
223 | return TRUE; | ||
147 | } | 224 | } |
148 | 225 | ||
149 | 226 | ||
@@ -198,9 +275,6 @@ void LLProfile::genNGon(const LLProfileParams& params, S32 sides, F32 offset, F3 | |||
198 | F32 t, t_step, t_first, t_fraction, ang, ang_step; | 275 | F32 t, t_step, t_first, t_fraction, ang, ang_step; |
199 | LLVector3 pt1,pt2; | 276 | LLVector3 pt1,pt2; |
200 | 277 | ||
201 | mMaxX = 0.f; | ||
202 | mMinX = 0.f; | ||
203 | |||
204 | F32 begin = params.getBegin(); | 278 | F32 begin = params.getBegin(); |
205 | F32 end = params.getEnd(); | 279 | F32 end = params.getEnd(); |
206 | 280 | ||
@@ -236,15 +310,6 @@ void LLProfile::genNGon(const LLProfileParams& params, S32 sides, F32 offset, F3 | |||
236 | if (t_fraction < 0.9999f) | 310 | if (t_fraction < 0.9999f) |
237 | { | 311 | { |
238 | LLVector3 new_pt = lerp(pt1, pt2, t_fraction); | 312 | LLVector3 new_pt = lerp(pt1, pt2, t_fraction); |
239 | F32 pt_x = new_pt.mV[VX]; | ||
240 | if (pt_x < mMinX) | ||
241 | { | ||
242 | mMinX = pt_x; | ||
243 | } | ||
244 | else if (pt_x > mMaxX) | ||
245 | { | ||
246 | mMaxX = pt_x; | ||
247 | } | ||
248 | mProfile.push_back(new_pt); | 313 | mProfile.push_back(new_pt); |
249 | } | 314 | } |
250 | 315 | ||
@@ -254,16 +319,6 @@ void LLProfile::genNGon(const LLProfileParams& params, S32 sides, F32 offset, F3 | |||
254 | // Iterate through all the integer steps of t. | 319 | // Iterate through all the integer steps of t. |
255 | pt1.setVec(cos(ang)*scale,sin(ang)*scale,t); | 320 | pt1.setVec(cos(ang)*scale,sin(ang)*scale,t); |
256 | 321 | ||
257 | F32 pt_x = pt1.mV[VX]; | ||
258 | if (pt_x < mMinX) | ||
259 | { | ||
260 | mMinX = pt_x; | ||
261 | } | ||
262 | else if (pt_x > mMaxX) | ||
263 | { | ||
264 | mMaxX = pt_x; | ||
265 | } | ||
266 | |||
267 | if (mProfile.size() > 0) { | 322 | if (mProfile.size() > 0) { |
268 | LLVector3 p = mProfile[mProfile.size()-1]; | 323 | LLVector3 p = mProfile[mProfile.size()-1]; |
269 | for (S32 i = 0; i < split && mProfile.size() > 0; i++) { | 324 | for (S32 i = 0; i < split && mProfile.size() > 0; i++) { |
@@ -287,15 +342,6 @@ void LLProfile::genNGon(const LLProfileParams& params, S32 sides, F32 offset, F3 | |||
287 | if (t_fraction > 0.0001f) | 342 | if (t_fraction > 0.0001f) |
288 | { | 343 | { |
289 | LLVector3 new_pt = lerp(pt1, pt2, t_fraction); | 344 | LLVector3 new_pt = lerp(pt1, pt2, t_fraction); |
290 | F32 pt_x = new_pt.mV[VX]; | ||
291 | if (pt_x < mMinX) | ||
292 | { | ||
293 | mMinX = pt_x; | ||
294 | } | ||
295 | else if (pt_x > mMaxX) | ||
296 | { | ||
297 | mMaxX = pt_x; | ||
298 | } | ||
299 | 345 | ||
300 | if (mProfile.size() > 0) { | 346 | if (mProfile.size() > 0) { |
301 | LLVector3 p = mProfile[mProfile.size()-1]; | 347 | LLVector3 p = mProfile[mProfile.size()-1]; |
@@ -472,31 +518,9 @@ LLProfile::Face* LLProfile::addHole(const LLProfileParams& params, BOOL flat, F3 | |||
472 | } | 518 | } |
473 | 519 | ||
474 | 520 | ||
475 | S32 sculpt_sides(F32 detail) | ||
476 | { | ||
477 | |||
478 | // detail is usually one of: 1, 1.5, 2.5, 4.0. | ||
479 | |||
480 | if (detail <= 1.0) | ||
481 | { | ||
482 | return SCULPT_REZ_1; | ||
483 | } | ||
484 | if (detail <= 2.0) | ||
485 | { | ||
486 | return SCULPT_REZ_2; | ||
487 | } | ||
488 | if (detail <= 3.0) | ||
489 | { | ||
490 | return SCULPT_REZ_3; | ||
491 | } | ||
492 | else | ||
493 | { | ||
494 | return SCULPT_REZ_4; | ||
495 | } | ||
496 | } | ||
497 | |||
498 | 521 | ||
499 | BOOL LLProfile::generate(const LLProfileParams& params, BOOL path_open,F32 detail, S32 split, BOOL is_sculpted) | 522 | BOOL LLProfile::generate(const LLProfileParams& params, BOOL path_open,F32 detail, S32 split, |
523 | BOOL is_sculpted, S32 sculpt_size) | ||
500 | { | 524 | { |
501 | LLMemType m1(LLMemType::MTYPE_VOLUME); | 525 | LLMemType m1(LLMemType::MTYPE_VOLUME); |
502 | 526 | ||
@@ -640,7 +664,7 @@ BOOL LLProfile::generate(const LLProfileParams& params, BOOL path_open,F32 detai | |||
640 | S32 sides = (S32)circle_detail; | 664 | S32 sides = (S32)circle_detail; |
641 | 665 | ||
642 | if (is_sculpted) | 666 | if (is_sculpted) |
643 | sides = sculpt_sides(detail); | 667 | sides = sculpt_size; |
644 | 668 | ||
645 | genNGon(params, sides); | 669 | genNGon(params, sides); |
646 | 670 | ||
@@ -1131,7 +1155,8 @@ const LLVector2 LLPathParams::getEndScale() const | |||
1131 | return end_scale; | 1155 | return end_scale; |
1132 | } | 1156 | } |
1133 | 1157 | ||
1134 | BOOL LLPath::generate(const LLPathParams& params, F32 detail, S32 split, BOOL is_sculpted) | 1158 | BOOL LLPath::generate(const LLPathParams& params, F32 detail, S32 split, |
1159 | BOOL is_sculpted, S32 sculpt_size) | ||
1135 | { | 1160 | { |
1136 | LLMemType m1(LLMemType::MTYPE_VOLUME); | 1161 | LLMemType m1(LLMemType::MTYPE_VOLUME); |
1137 | 1162 | ||
@@ -1194,7 +1219,7 @@ BOOL LLPath::generate(const LLPathParams& params, F32 detail, S32 split, BOOL is | |||
1194 | S32 sides = (S32)llfloor(llfloor((MIN_DETAIL_FACES * detail + twist_mag * 3.5f * (detail-0.5f))) * params.getRevolutions()); | 1219 | S32 sides = (S32)llfloor(llfloor((MIN_DETAIL_FACES * detail + twist_mag * 3.5f * (detail-0.5f))) * params.getRevolutions()); |
1195 | 1220 | ||
1196 | if (is_sculpted) | 1221 | if (is_sculpted) |
1197 | sides = sculpt_sides(detail); | 1222 | sides = sculpt_size; |
1198 | 1223 | ||
1199 | genNGon(params, sides); | 1224 | genNGon(params, sides); |
1200 | } | 1225 | } |
@@ -1259,7 +1284,8 @@ BOOL LLPath::generate(const LLPathParams& params, F32 detail, S32 split, BOOL is | |||
1259 | return TRUE; | 1284 | return TRUE; |
1260 | } | 1285 | } |
1261 | 1286 | ||
1262 | BOOL LLDynamicPath::generate(const LLPathParams& params, F32 detail, S32 split, BOOL is_sculpted) | 1287 | BOOL LLDynamicPath::generate(const LLPathParams& params, F32 detail, S32 split, |
1288 | BOOL is_sculpted, S32 sculpt_size) | ||
1263 | { | 1289 | { |
1264 | LLMemType m1(LLMemType::MTYPE_VOLUME); | 1290 | LLMemType m1(LLMemType::MTYPE_VOLUME); |
1265 | 1291 | ||
@@ -1979,6 +2005,12 @@ void LLVolume::sculptGeneratePlaceholder() | |||
1979 | // create the vertices from the map | 2005 | // create the vertices from the map |
1980 | void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, U8 sculpt_type) | 2006 | void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, U8 sculpt_type) |
1981 | { | 2007 | { |
2008 | U8 sculpt_stitching = sculpt_type & LL_SCULPT_TYPE_MASK; | ||
2009 | BOOL sculpt_invert = sculpt_type & LL_SCULPT_FLAG_INVERT; | ||
2010 | BOOL sculpt_mirror = sculpt_type & LL_SCULPT_FLAG_MIRROR; | ||
2011 | BOOL reverse_horizontal = (sculpt_invert ? !sculpt_mirror : sculpt_mirror); // XOR | ||
2012 | |||
2013 | |||
1982 | LLMemType m1(LLMemType::MTYPE_VOLUME); | 2014 | LLMemType m1(LLMemType::MTYPE_VOLUME); |
1983 | 2015 | ||
1984 | S32 sizeS = mPathp->mPath.size(); | 2016 | S32 sizeS = mPathp->mPath.size(); |
@@ -1993,13 +2025,21 @@ void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 | |||
1993 | S32 i = t + line; | 2025 | S32 i = t + line; |
1994 | Point& pt = mMesh[i]; | 2026 | Point& pt = mMesh[i]; |
1995 | 2027 | ||
1996 | U32 x = (U32) ((F32)t/(sizeT-1) * (F32) sculpt_width); | 2028 | S32 reversed_t = t; |
2029 | |||
2030 | if (reverse_horizontal) | ||
2031 | { | ||
2032 | reversed_t = sizeT - t - 1; | ||
2033 | } | ||
2034 | |||
2035 | U32 x = (U32) ((F32)reversed_t/(sizeT-1) * (F32) sculpt_width); | ||
1997 | U32 y = (U32) ((F32)s/(sizeS-1) * (F32) sculpt_height); | 2036 | U32 y = (U32) ((F32)s/(sizeS-1) * (F32) sculpt_height); |
1998 | 2037 | ||
2038 | |||
1999 | if (y == 0) // top row stitching | 2039 | if (y == 0) // top row stitching |
2000 | { | 2040 | { |
2001 | // pinch? | 2041 | // pinch? |
2002 | if (sculpt_type == LL_SCULPT_TYPE_SPHERE) | 2042 | if (sculpt_stitching == LL_SCULPT_TYPE_SPHERE) |
2003 | { | 2043 | { |
2004 | x = sculpt_width / 2; | 2044 | x = sculpt_width / 2; |
2005 | } | 2045 | } |
@@ -2008,7 +2048,7 @@ void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 | |||
2008 | if (y == sculpt_height) // bottom row stitching | 2048 | if (y == sculpt_height) // bottom row stitching |
2009 | { | 2049 | { |
2010 | // wrap? | 2050 | // wrap? |
2011 | if (sculpt_type == LL_SCULPT_TYPE_TORUS) | 2051 | if (sculpt_stitching == LL_SCULPT_TYPE_TORUS) |
2012 | { | 2052 | { |
2013 | y = 0; | 2053 | y = 0; |
2014 | } | 2054 | } |
@@ -2018,7 +2058,7 @@ void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 | |||
2018 | } | 2058 | } |
2019 | 2059 | ||
2020 | // pinch? | 2060 | // pinch? |
2021 | if (sculpt_type == LL_SCULPT_TYPE_SPHERE) | 2061 | if (sculpt_stitching == LL_SCULPT_TYPE_SPHERE) |
2022 | { | 2062 | { |
2023 | x = sculpt_width / 2; | 2063 | x = sculpt_width / 2; |
2024 | } | 2064 | } |
@@ -2027,9 +2067,9 @@ void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 | |||
2027 | if (x == sculpt_width) // side stitching | 2067 | if (x == sculpt_width) // side stitching |
2028 | { | 2068 | { |
2029 | // wrap? | 2069 | // wrap? |
2030 | if ((sculpt_type == LL_SCULPT_TYPE_SPHERE) || | 2070 | if ((sculpt_stitching == LL_SCULPT_TYPE_SPHERE) || |
2031 | (sculpt_type == LL_SCULPT_TYPE_TORUS) || | 2071 | (sculpt_stitching == LL_SCULPT_TYPE_TORUS) || |
2032 | (sculpt_type == LL_SCULPT_TYPE_CYLINDER)) | 2072 | (sculpt_stitching == LL_SCULPT_TYPE_CYLINDER)) |
2033 | { | 2073 | { |
2034 | x = 0; | 2074 | x = 0; |
2035 | } | 2075 | } |
@@ -2041,12 +2081,69 @@ void LLVolume::sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 | |||
2041 | } | 2081 | } |
2042 | 2082 | ||
2043 | pt.mPos = sculpt_xy_to_vector(x, y, sculpt_width, sculpt_height, sculpt_components, sculpt_data); | 2083 | pt.mPos = sculpt_xy_to_vector(x, y, sculpt_width, sculpt_height, sculpt_components, sculpt_data); |
2084 | |||
2085 | if (sculpt_mirror) | ||
2086 | { | ||
2087 | pt.mPos.mV[VX] *= -1.f; | ||
2088 | } | ||
2044 | } | 2089 | } |
2090 | |||
2045 | line += sizeT; | 2091 | line += sizeT; |
2046 | } | 2092 | } |
2047 | } | 2093 | } |
2048 | 2094 | ||
2049 | 2095 | ||
2096 | const S32 SCULPT_REZ_1 = 6; // changed from 4 to 6 - 6 looks round whereas 4 looks square | ||
2097 | const S32 SCULPT_REZ_2 = 8; | ||
2098 | const S32 SCULPT_REZ_3 = 16; | ||
2099 | const S32 SCULPT_REZ_4 = 32; | ||
2100 | |||
2101 | S32 sculpt_sides(F32 detail) | ||
2102 | { | ||
2103 | |||
2104 | // detail is usually one of: 1, 1.5, 2.5, 4.0. | ||
2105 | |||
2106 | if (detail <= 1.0) | ||
2107 | { | ||
2108 | return SCULPT_REZ_1; | ||
2109 | } | ||
2110 | if (detail <= 2.0) | ||
2111 | { | ||
2112 | return SCULPT_REZ_2; | ||
2113 | } | ||
2114 | if (detail <= 3.0) | ||
2115 | { | ||
2116 | return SCULPT_REZ_3; | ||
2117 | } | ||
2118 | else | ||
2119 | { | ||
2120 | return SCULPT_REZ_4; | ||
2121 | } | ||
2122 | } | ||
2123 | |||
2124 | |||
2125 | |||
2126 | // determine the number of vertices in both s and t direction for this sculpt | ||
2127 | void sculpt_calc_mesh_resolution(U16 width, U16 height, U8 type, F32 detail, S32& s, S32& t) | ||
2128 | { | ||
2129 | S32 vertices = sculpt_sides(detail); | ||
2130 | |||
2131 | F32 ratio; | ||
2132 | if ((width == 0) || (height == 0)) | ||
2133 | ratio = 1.f; | ||
2134 | else | ||
2135 | ratio = (F32) width / (F32) height; | ||
2136 | |||
2137 | |||
2138 | s = (S32)(vertices / fsqrtf(ratio)); | ||
2139 | |||
2140 | s = llmax(s, 3); // no degenerate sizes, please | ||
2141 | t = vertices * vertices / s; | ||
2142 | |||
2143 | t = llmax(t, 3); // no degenerate sizes, please | ||
2144 | s = vertices * vertices / t; | ||
2145 | } | ||
2146 | |||
2050 | // sculpt replaces generate() for sculpted surfaces | 2147 | // sculpt replaces generate() for sculpted surfaces |
2051 | void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, S32 sculpt_level) | 2148 | void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, S32 sculpt_level) |
2052 | { | 2149 | { |
@@ -2061,11 +2158,16 @@ void LLVolume::sculpt(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, | |||
2061 | data_is_empty = TRUE; | 2158 | data_is_empty = TRUE; |
2062 | } | 2159 | } |
2063 | 2160 | ||
2064 | mPathp->generate(mParams.getPathParams(), mDetail, 0, TRUE); | 2161 | S32 requested_sizeS = 0; |
2065 | mProfilep->generate(mParams.getProfileParams(), mPathp->isOpen(), mDetail, 0, TRUE); | 2162 | S32 requested_sizeT = 0; |
2066 | 2163 | ||
2067 | S32 sizeS = mPathp->mPath.size(); | 2164 | sculpt_calc_mesh_resolution(sculpt_width, sculpt_height, sculpt_type, mDetail, requested_sizeS, requested_sizeT); |
2068 | S32 sizeT = mProfilep->mProfile.size(); | 2165 | |
2166 | mPathp->generate(mParams.getPathParams(), mDetail, 0, TRUE, requested_sizeS); | ||
2167 | mProfilep->generate(mParams.getProfileParams(), mPathp->isOpen(), mDetail, 0, TRUE, requested_sizeT); | ||
2168 | |||
2169 | S32 sizeS = mPathp->mPath.size(); // we requested a specific size, now see what we really got | ||
2170 | S32 sizeT = mProfilep->mProfile.size(); // we requested a specific size, now see what we really got | ||
2069 | 2171 | ||
2070 | // weird crash bug - DEV-11158 - trying to collect more data: | 2172 | // weird crash bug - DEV-11158 - trying to collect more data: |
2071 | if ((sizeS == 0) || (sizeT == 0)) | 2173 | if ((sizeS == 0) || (sizeT == 0)) |
@@ -3405,47 +3507,99 @@ void LLVolume::generateSilhouetteVertices(std::vector<LLVector3> &vertices, | |||
3405 | } | 3507 | } |
3406 | } | 3508 | } |
3407 | 3509 | ||
3408 | S32 LLVolume::lineSegmentIntersect(const LLVector3& start, LLVector3& end) const | 3510 | S32 LLVolume::lineSegmentIntersect(const LLVector3& start, const LLVector3& end, |
3511 | S32 face, | ||
3512 | LLVector3* intersection,LLVector2* tex_coord, LLVector3* normal, LLVector3* bi_normal) | ||
3409 | { | 3513 | { |
3410 | S32 ret = -1; | 3514 | S32 hit_face = -1; |
3411 | 3515 | ||
3412 | LLVector3 vec = end - start; | 3516 | S32 start_face; |
3517 | S32 end_face; | ||
3413 | 3518 | ||
3414 | for (S32 i = 0; i < getNumFaces(); i++) | 3519 | if (face == -1) // ALL_SIDES |
3415 | { | 3520 | { |
3416 | const LLVolumeFace& face = getVolumeFace(i); | 3521 | start_face = 0; |
3522 | end_face = getNumFaces() - 1; | ||
3523 | } | ||
3524 | else | ||
3525 | { | ||
3526 | start_face = face; | ||
3527 | end_face = face; | ||
3528 | } | ||
3529 | |||
3530 | LLVector3 dir = end - start; | ||
3531 | |||
3532 | F32 closest_t = 2.f; // must be larger than 1 | ||
3533 | |||
3534 | for (S32 i = start_face; i <= end_face; i++) | ||
3535 | { | ||
3536 | const LLVolumeFace &face = getVolumeFace((U32)i); | ||
3537 | |||
3538 | LLVector3 box_center = (face.mExtents[0] + face.mExtents[1]) / 2.f; | ||
3539 | LLVector3 box_size = face.mExtents[1] - face.mExtents[0]; | ||
3540 | |||
3541 | if (LLLineSegmentBoxIntersect(start, end, box_center, box_size)) | ||
3542 | { | ||
3543 | if (bi_normal != NULL) // if the caller wants binormals, we may need to generate them | ||
3544 | { | ||
3545 | genBinormals(i); | ||
3546 | } | ||
3547 | |||
3548 | for (U32 tri = 0; tri < face.mIndices.size()/3; tri++) | ||
3549 | { | ||
3550 | S32 index1 = face.mIndices[tri*3+0]; | ||
3551 | S32 index2 = face.mIndices[tri*3+1]; | ||
3552 | S32 index3 = face.mIndices[tri*3+2]; | ||
3417 | 3553 | ||
3418 | for (U32 j = 0; j < face.mIndices.size()/3; j++) | 3554 | F32 a, b, t; |
3555 | |||
3556 | if (LLTriangleRayIntersect(face.mVertices[index1].mPosition, | ||
3557 | face.mVertices[index2].mPosition, | ||
3558 | face.mVertices[index3].mPosition, | ||
3559 | start, dir, &a, &b, &t, FALSE)) | ||
3560 | { | ||
3561 | if ((t >= 0.f) && // if hit is after start | ||
3562 | (t <= 1.f) && // and before end | ||
3563 | (t < closest_t)) // and this hit is closer | ||
3419 | { | 3564 | { |
3420 | //approximate normal | 3565 | closest_t = t; |
3421 | S32 v1 = face.mIndices[j*3+0]; | 3566 | hit_face = i; |
3422 | S32 v2 = face.mIndices[j*3+1]; | ||
3423 | S32 v3 = face.mIndices[j*3+2]; | ||
3424 | 3567 | ||
3425 | LLVector3 norm = (face.mVertices[v2].mPosition - face.mVertices[v1].mPosition) % | 3568 | if (intersection != NULL) |
3426 | (face.mVertices[v3].mPosition - face.mVertices[v2].mPosition); | 3569 | { |
3570 | *intersection = start + dir * closest_t; | ||
3571 | } | ||
3427 | 3572 | ||
3428 | if (norm.magVecSquared() >= 0.00000001f) | 3573 | if (tex_coord != NULL) |
3429 | { | 3574 | { |
3430 | //get view vector | 3575 | *tex_coord = ((1.f - a - b) * face.mVertices[index1].mTexCoord + |
3431 | //LLVector3 view = (start-face.mVertices[v1].mPosition); | 3576 | a * face.mVertices[index2].mTexCoord + |
3432 | //if (view * norm < 0.0f) | 3577 | b * face.mVertices[index3].mTexCoord); |
3578 | |||
3579 | } | ||
3580 | |||
3581 | if (normal != NULL) | ||
3433 | { | 3582 | { |
3434 | if (LLTriangleLineSegmentIntersect( face.mVertices[v1].mPosition, | 3583 | *normal = ((1.f - a - b) * face.mVertices[index1].mNormal + |
3435 | face.mVertices[v2].mPosition, | 3584 | a * face.mVertices[index2].mNormal + |
3436 | face.mVertices[v3].mPosition, | 3585 | b * face.mVertices[index3].mNormal); |
3437 | end, | 3586 | } |
3438 | vec)) | 3587 | |
3588 | if (bi_normal != NULL) | ||
3439 | { | 3589 | { |
3440 | vec = end-start; | 3590 | *bi_normal = ((1.f - a - b) * face.mVertices[index1].mBinormal + |
3441 | ret = (S32) i; | 3591 | a * face.mVertices[index2].mBinormal + |
3592 | b * face.mVertices[index3].mBinormal); | ||
3593 | } | ||
3594 | |||
3442 | } | 3595 | } |
3443 | } | 3596 | } |
3444 | } | 3597 | } |
3445 | } | 3598 | } |
3446 | } | 3599 | } |
3447 | 3600 | ||
3448 | return ret; | 3601 | |
3602 | return hit_face; | ||
3449 | } | 3603 | } |
3450 | 3604 | ||
3451 | class LLVertexIndexPair | 3605 | class LLVertexIndexPair |
@@ -4768,6 +4922,13 @@ BOOL LLVolumeFace::createSide(LLVolume* volume, BOOL partial_build) | |||
4768 | LLMemType m1(LLMemType::MTYPE_VOLUME); | 4922 | LLMemType m1(LLMemType::MTYPE_VOLUME); |
4769 | 4923 | ||
4770 | BOOL flat = mTypeMask & FLAT_MASK; | 4924 | BOOL flat = mTypeMask & FLAT_MASK; |
4925 | |||
4926 | U8 sculpt_type = volume->getParams().getSculptType(); | ||
4927 | U8 sculpt_stitching = sculpt_type & LL_SCULPT_TYPE_MASK; | ||
4928 | BOOL sculpt_invert = sculpt_type & LL_SCULPT_FLAG_INVERT; | ||
4929 | BOOL sculpt_mirror = sculpt_type & LL_SCULPT_FLAG_MIRROR; | ||
4930 | BOOL sculpt_reverse_horizontal = (sculpt_invert ? !sculpt_mirror : sculpt_mirror); // XOR | ||
4931 | |||
4771 | S32 num_vertices, num_indices; | 4932 | S32 num_vertices, num_indices; |
4772 | 4933 | ||
4773 | const std::vector<LLVolume::Point>& mesh = volume->getMesh(); | 4934 | const std::vector<LLVolume::Point>& mesh = volume->getMesh(); |
@@ -4834,6 +4995,11 @@ BOOL LLVolumeFace::createSide(LLVolume* volume, BOOL partial_build) | |||
4834 | } | 4995 | } |
4835 | } | 4996 | } |
4836 | 4997 | ||
4998 | if (sculpt_reverse_horizontal) | ||
4999 | { | ||
5000 | ss = 1.f - ss; | ||
5001 | } | ||
5002 | |||
4837 | // Check to see if this triangle wraps around the array. | 5003 | // Check to see if this triangle wraps around the array. |
4838 | if (mBeginS + s >= max_s) | 5004 | if (mBeginS + s >= max_s) |
4839 | { | 5005 | { |
@@ -4995,9 +5161,7 @@ BOOL LLVolumeFace::createSide(LLVolume* volume, BOOL partial_build) | |||
4995 | 5161 | ||
4996 | BOOL s_bottom_converges = ((mVertices[0].mPosition - mVertices[mNumS*(mNumT-2)].mPosition).magVecSquared() < 0.000001f); | 5162 | BOOL s_bottom_converges = ((mVertices[0].mPosition - mVertices[mNumS*(mNumT-2)].mPosition).magVecSquared() < 0.000001f); |
4997 | BOOL s_top_converges = ((mVertices[mNumS-1].mPosition - mVertices[mNumS*(mNumT-2)+mNumS-1].mPosition).magVecSquared() < 0.000001f); | 5163 | BOOL s_top_converges = ((mVertices[mNumS-1].mPosition - mVertices[mNumS*(mNumT-2)+mNumS-1].mPosition).magVecSquared() < 0.000001f); |
4998 | U8 sculpt_type = volume->getParams().getSculptType(); | 5164 | if (sculpt_stitching == LL_SCULPT_TYPE_NONE) // logic for non-sculpt volumes |
4999 | |||
5000 | if (sculpt_type == LL_SCULPT_TYPE_NONE) // logic for non-sculpt volumes | ||
5001 | { | 5165 | { |
5002 | if (volume->getPath().isOpen() == FALSE) | 5166 | if (volume->getPath().isOpen() == FALSE) |
5003 | { //wrap normals on T | 5167 | { //wrap normals on T |
@@ -5046,15 +5210,15 @@ BOOL LLVolumeFace::createSide(LLVolume* volume, BOOL partial_build) | |||
5046 | BOOL wrap_s = FALSE; | 5210 | BOOL wrap_s = FALSE; |
5047 | BOOL wrap_t = FALSE; | 5211 | BOOL wrap_t = FALSE; |
5048 | 5212 | ||
5049 | if (sculpt_type == LL_SCULPT_TYPE_SPHERE) | 5213 | if (sculpt_stitching == LL_SCULPT_TYPE_SPHERE) |
5050 | average_poles = TRUE; | 5214 | average_poles = TRUE; |
5051 | 5215 | ||
5052 | if ((sculpt_type == LL_SCULPT_TYPE_SPHERE) || | 5216 | if ((sculpt_stitching == LL_SCULPT_TYPE_SPHERE) || |
5053 | (sculpt_type == LL_SCULPT_TYPE_TORUS) || | 5217 | (sculpt_stitching == LL_SCULPT_TYPE_TORUS) || |
5054 | (sculpt_type == LL_SCULPT_TYPE_CYLINDER)) | 5218 | (sculpt_stitching == LL_SCULPT_TYPE_CYLINDER)) |
5055 | wrap_s = TRUE; | 5219 | wrap_s = TRUE; |
5056 | 5220 | ||
5057 | if (sculpt_type == LL_SCULPT_TYPE_TORUS) | 5221 | if (sculpt_stitching == LL_SCULPT_TYPE_TORUS) |
5058 | wrap_t = TRUE; | 5222 | wrap_t = TRUE; |
5059 | 5223 | ||
5060 | 5224 | ||
diff --git a/linden/indra/llmath/llvolume.h b/linden/indra/llmath/llvolume.h index 5b48cfc..8ac0e71 100644 --- a/linden/indra/llmath/llvolume.h +++ b/linden/indra/llmath/llvolume.h | |||
@@ -175,7 +175,7 @@ const LLFaceID LL_FACE_OUTER_SIDE_3 = 0x1 << 8; | |||
175 | 175 | ||
176 | //============================================================================ | 176 | //============================================================================ |
177 | 177 | ||
178 | // sculpt types | 178 | // sculpt types + flags |
179 | 179 | ||
180 | const U8 LL_SCULPT_TYPE_NONE = 0; | 180 | const U8 LL_SCULPT_TYPE_NONE = 0; |
181 | const U8 LL_SCULPT_TYPE_SPHERE = 1; | 181 | const U8 LL_SCULPT_TYPE_SPHERE = 1; |
@@ -183,21 +183,30 @@ const U8 LL_SCULPT_TYPE_TORUS = 2; | |||
183 | const U8 LL_SCULPT_TYPE_PLANE = 3; | 183 | const U8 LL_SCULPT_TYPE_PLANE = 3; |
184 | const U8 LL_SCULPT_TYPE_CYLINDER = 4; | 184 | const U8 LL_SCULPT_TYPE_CYLINDER = 4; |
185 | 185 | ||
186 | const U8 LL_SCULPT_TYPE_MASK = LL_SCULPT_TYPE_SPHERE | LL_SCULPT_TYPE_TORUS | LL_SCULPT_TYPE_PLANE | LL_SCULPT_TYPE_CYLINDER; | ||
187 | |||
188 | const U8 LL_SCULPT_FLAG_INVERT = 64; | ||
189 | const U8 LL_SCULPT_FLAG_MIRROR = 128; | ||
186 | 190 | ||
187 | 191 | ||
188 | class LLProfileParams | 192 | class LLProfileParams |
189 | { | 193 | { |
190 | public: | 194 | public: |
191 | LLProfileParams() | 195 | LLProfileParams() |
196 | : mCurveType(LL_PCODE_PROFILE_SQUARE), | ||
197 | mBegin(0.f), | ||
198 | mEnd(1.f), | ||
199 | mHollow(0.f), | ||
200 | mCRC(0) | ||
192 | { | 201 | { |
193 | mCurveType = LL_PCODE_PROFILE_SQUARE; | ||
194 | mBegin = 0.f; | ||
195 | mEnd = 1.f; | ||
196 | mHollow = 0.f; | ||
197 | } | 202 | } |
198 | 203 | ||
199 | LLProfileParams(U8 curve, F32 begin, F32 end, F32 hollow) | 204 | LLProfileParams(U8 curve, F32 begin, F32 end, F32 hollow) |
200 | : mCurveType(curve), mBegin(begin), mEnd(end), mHollow(hollow) | 205 | : mCurveType(curve), |
206 | mBegin(begin), | ||
207 | mEnd(end), | ||
208 | mHollow(hollow), | ||
209 | mCRC(0) | ||
201 | { | 210 | { |
202 | } | 211 | } |
203 | 212 | ||
@@ -222,6 +231,7 @@ public: | |||
222 | temp_f32 = 1.f; | 231 | temp_f32 = 1.f; |
223 | } | 232 | } |
224 | mHollow = temp_f32; | 233 | mHollow = temp_f32; |
234 | mCRC = 0; | ||
225 | } | 235 | } |
226 | 236 | ||
227 | bool operator==(const LLProfileParams ¶ms) const; | 237 | bool operator==(const LLProfileParams ¶ms) const; |
@@ -309,27 +319,36 @@ class LLPathParams | |||
309 | { | 319 | { |
310 | public: | 320 | public: |
311 | LLPathParams() | 321 | LLPathParams() |
322 | : | ||
323 | mCurveType(LL_PCODE_PATH_LINE), | ||
324 | mBegin(0.f), | ||
325 | mEnd(1.f), | ||
326 | mScale(1.f,1.f), | ||
327 | mShear(0.f,0.f), | ||
328 | mTwistBegin(0.f), | ||
329 | mTwistEnd(0.f), | ||
330 | mRadiusOffset(0.f), | ||
331 | mTaper(0.f,0.f), | ||
332 | mRevolutions(1.f), | ||
333 | mSkew(0.f), | ||
334 | mCRC(0) | ||
312 | { | 335 | { |
313 | mBegin = 0.f; | ||
314 | mEnd = 1.f; | ||
315 | mScale.setVec(1.f,1.f); | ||
316 | mShear.setVec(0.f,0.f); | ||
317 | mCurveType = LL_PCODE_PATH_LINE; | ||
318 | mTwistBegin = 0.f; | ||
319 | mTwistEnd = 0.f; | ||
320 | mRadiusOffset = 0.f; | ||
321 | mTaper.setVec(0.f,0.f); | ||
322 | mRevolutions = 1.f; | ||
323 | mSkew = 0.f; | ||
324 | } | 336 | } |
325 | 337 | ||
326 | LLPathParams(U8 curve, F32 begin, F32 end, F32 scx, F32 scy, F32 shx, F32 shy, F32 twistend, F32 twistbegin, F32 radiusoffset, F32 tx, F32 ty, F32 revolutions, F32 skew) | 338 | LLPathParams(U8 curve, F32 begin, F32 end, F32 scx, F32 scy, F32 shx, F32 shy, F32 twistend, F32 twistbegin, F32 radiusoffset, F32 tx, F32 ty, F32 revolutions, F32 skew) |
327 | : mCurveType(curve), mBegin(begin), mEnd(end), mTwistBegin(twistbegin), mTwistEnd(twistend), | 339 | : mCurveType(curve), |
328 | mRadiusOffset(radiusoffset), mRevolutions(revolutions), mSkew(skew) | 340 | mBegin(begin), |
341 | mEnd(end), | ||
342 | mScale(scx,scy), | ||
343 | mShear(shx,shy), | ||
344 | mTwistBegin(twistbegin), | ||
345 | mTwistEnd(twistend), | ||
346 | mRadiusOffset(radiusoffset), | ||
347 | mTaper(tx,ty), | ||
348 | mRevolutions(revolutions), | ||
349 | mSkew(skew), | ||
350 | mCRC(0) | ||
329 | { | 351 | { |
330 | mScale.setVec(scx,scy); | ||
331 | mShear.setVec(shx,shy); | ||
332 | mTaper.setVec(tx,ty); | ||
333 | } | 352 | } |
334 | 353 | ||
335 | LLPathParams(U8 curve, U16 begin, U16 end, U8 scx, U8 scy, U8 shx, U8 shy, U8 twistend, U8 twistbegin, U8 radiusoffset, U8 tx, U8 ty, U8 revolutions, U8 skew) | 354 | LLPathParams(U8 curve, U16 begin, U16 end, U8 scx, U8 scy, U8 shx, U8 shy, U8 twistend, U8 twistbegin, U8 radiusoffset, U8 tx, U8 ty, U8 revolutions, U8 skew) |
@@ -347,6 +366,8 @@ public: | |||
347 | mTaper.setVec(U8_TO_F32(tx) * TAPER_QUANTA,U8_TO_F32(ty) * TAPER_QUANTA); | 366 | mTaper.setVec(U8_TO_F32(tx) * TAPER_QUANTA,U8_TO_F32(ty) * TAPER_QUANTA); |
348 | mRevolutions = ((F32)revolutions) * REV_QUANTA + 1.0f; | 367 | mRevolutions = ((F32)revolutions) * REV_QUANTA + 1.0f; |
349 | mSkew = U8_TO_F32(skew) * SCALE_QUANTA; | 368 | mSkew = U8_TO_F32(skew) * SCALE_QUANTA; |
369 | |||
370 | mCRC = 0; | ||
350 | } | 371 | } |
351 | 372 | ||
352 | bool operator==(const LLPathParams ¶ms) const; | 373 | bool operator==(const LLPathParams ¶ms) const; |
@@ -525,6 +546,7 @@ class LLVolumeParams | |||
525 | { | 546 | { |
526 | public: | 547 | public: |
527 | LLVolumeParams() | 548 | LLVolumeParams() |
549 | : mSculptType(LL_SCULPT_TYPE_NONE) | ||
528 | { | 550 | { |
529 | } | 551 | } |
530 | 552 | ||
@@ -649,7 +671,9 @@ public: | |||
649 | mConcave(FALSE), | 671 | mConcave(FALSE), |
650 | mDirty(TRUE), | 672 | mDirty(TRUE), |
651 | mTotalOut(0), | 673 | mTotalOut(0), |
652 | mTotal(2) | 674 | mTotal(2), |
675 | mMinX(0.f), | ||
676 | mMaxX(0.f) | ||
653 | { | 677 | { |
654 | } | 678 | } |
655 | 679 | ||
@@ -660,7 +684,8 @@ public: | |||
660 | BOOL isFlat(S32 face) const { return (mFaces[face].mCount == 2); } | 684 | BOOL isFlat(S32 face) const { return (mFaces[face].mCount == 2); } |
661 | BOOL isOpen() const { return mOpen; } | 685 | BOOL isOpen() const { return mOpen; } |
662 | void setDirty() { mDirty = TRUE; } | 686 | void setDirty() { mDirty = TRUE; } |
663 | BOOL generate(const LLProfileParams& params, BOOL path_open, F32 detail = 1.0f, S32 split = 0, BOOL is_sculpted = FALSE); | 687 | BOOL generate(const LLProfileParams& params, BOOL path_open, F32 detail = 1.0f, S32 split = 0, |
688 | BOOL is_sculpted = FALSE, S32 sculpt_size = 0); | ||
664 | BOOL isConcave() const { return mConcave; } | 689 | BOOL isConcave() const { return mConcave; } |
665 | public: | 690 | public: |
666 | struct Face | 691 | struct Face |
@@ -678,8 +703,6 @@ public: | |||
678 | std::vector<Face> mFaces; | 703 | std::vector<Face> mFaces; |
679 | std::vector<LLVector3> mEdgeNormals; | 704 | std::vector<LLVector3> mEdgeNormals; |
680 | std::vector<LLVector3> mEdgeCenters; | 705 | std::vector<LLVector3> mEdgeCenters; |
681 | F32 mMaxX; | ||
682 | F32 mMinX; | ||
683 | 706 | ||
684 | friend std::ostream& operator<<(std::ostream &s, const LLProfile &profile); | 707 | friend std::ostream& operator<<(std::ostream &s, const LLProfile &profile); |
685 | 708 | ||
@@ -698,6 +721,9 @@ protected: | |||
698 | 721 | ||
699 | S32 mTotalOut; | 722 | S32 mTotalOut; |
700 | S32 mTotal; | 723 | S32 mTotal; |
724 | |||
725 | F32 mMaxX; | ||
726 | F32 mMinX; | ||
701 | }; | 727 | }; |
702 | 728 | ||
703 | //------------------------------------------------------------------- | 729 | //------------------------------------------------------------------- |
@@ -728,7 +754,8 @@ public: | |||
728 | virtual ~LLPath(); | 754 | virtual ~LLPath(); |
729 | 755 | ||
730 | void genNGon(const LLPathParams& params, S32 sides, F32 offset=0.0f, F32 end_scale = 1.f, F32 twist_scale = 1.f); | 756 | void genNGon(const LLPathParams& params, S32 sides, F32 offset=0.0f, F32 end_scale = 1.f, F32 twist_scale = 1.f); |
731 | virtual BOOL generate(const LLPathParams& params, F32 detail=1.0f, S32 split = 0, BOOL is_sculpted = FALSE); | 757 | virtual BOOL generate(const LLPathParams& params, F32 detail=1.0f, S32 split = 0, |
758 | BOOL is_sculpted = FALSE, S32 sculpt_size = 0); | ||
732 | 759 | ||
733 | BOOL isOpen() const { return mOpen; } | 760 | BOOL isOpen() const { return mOpen; } |
734 | F32 getStep() const { return mStep; } | 761 | F32 getStep() const { return mStep; } |
@@ -754,7 +781,8 @@ class LLDynamicPath : public LLPath | |||
754 | { | 781 | { |
755 | public: | 782 | public: |
756 | LLDynamicPath() : LLPath() { } | 783 | LLDynamicPath() : LLPath() { } |
757 | /*virtual*/ BOOL generate(const LLPathParams& params, F32 detail=1.0f, S32 split = 0, BOOL is_sculpted = FALSE); | 784 | /*virtual*/ BOOL generate(const LLPathParams& params, F32 detail=1.0f, S32 split = 0, |
785 | BOOL is_sculpted = FALSE, S32 sculpt_size = 0); | ||
758 | }; | 786 | }; |
759 | 787 | ||
760 | // Yet another "face" class - caches volume-specific, but not instance-specific data for faces) | 788 | // Yet another "face" class - caches volume-specific, but not instance-specific data for faces) |
@@ -885,7 +913,13 @@ public: | |||
885 | //get the face index of the face that intersects with the given line segment at the point | 913 | //get the face index of the face that intersects with the given line segment at the point |
886 | //closest to start. Moves end to the point of intersection. Returns -1 if no intersection. | 914 | //closest to start. Moves end to the point of intersection. Returns -1 if no intersection. |
887 | //Line segment must be in volume space. | 915 | //Line segment must be in volume space. |
888 | S32 lineSegmentIntersect(const LLVector3& start, LLVector3& end) const; | 916 | S32 lineSegmentIntersect(const LLVector3& start, const LLVector3& end, |
917 | S32 face = -1, // which face to check, -1 = ALL_SIDES | ||
918 | LLVector3* intersection = NULL, // return the intersection point | ||
919 | LLVector2* tex_coord = NULL, // return the texture coordinates of the intersection point | ||
920 | LLVector3* normal = NULL, // return the surface normal at the intersection point | ||
921 | LLVector3* bi_normal = NULL // return the surface bi-normal at the intersection point | ||
922 | ); | ||
889 | 923 | ||
890 | // The following cleans up vertices and triangles, | 924 | // The following cleans up vertices and triangles, |
891 | // getting rid of degenerate triangles and duplicate vertices, | 925 | // getting rid of degenerate triangles and duplicate vertices, |
@@ -916,6 +950,8 @@ private: | |||
916 | F32 sculptGetSurfaceArea(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data); | 950 | F32 sculptGetSurfaceArea(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data); |
917 | void sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, U8 sculpt_type); | 951 | void sculptGenerateMapVertices(U16 sculpt_width, U16 sculpt_height, S8 sculpt_components, const U8* sculpt_data, U8 sculpt_type); |
918 | void sculptGeneratePlaceholder(); | 952 | void sculptGeneratePlaceholder(); |
953 | void sculptCalcMeshResolution(U16 width, U16 height, U8 type, S32& s, S32& t); | ||
954 | |||
919 | 955 | ||
920 | protected: | 956 | protected: |
921 | BOOL generate(); | 957 | BOOL generate(); |
@@ -946,4 +982,10 @@ LLVector3 calc_binormal_from_triangle( | |||
946 | const LLVector3& pos2, | 982 | const LLVector3& pos2, |
947 | const LLVector2& tex2); | 983 | const LLVector2& tex2); |
948 | 984 | ||
985 | BOOL LLLineSegmentBoxIntersect(const LLVector3& start, const LLVector3& end, const LLVector3& center, const LLVector3& size); | ||
986 | BOOL LLTriangleRayIntersect(const LLVector3& vert0, const LLVector3& vert1, const LLVector3& vert2, const LLVector3& orig, const LLVector3& dir, | ||
987 | F32* intersection_a, F32* intersection_b, F32* intersection_t, BOOL two_sided); | ||
988 | |||
989 | |||
990 | |||
949 | #endif | 991 | #endif |
diff --git a/linden/indra/llmath/llvolumemgr.cpp b/linden/indra/llmath/llvolumemgr.cpp index 0b5464c..a3cd6b5 100644 --- a/linden/indra/llmath/llvolumemgr.cpp +++ b/linden/indra/llmath/llvolumemgr.cpp | |||
@@ -115,7 +115,7 @@ LLVolume* LLVolumeMgr::refVolume(const LLVolumeParams &volume_params, const S32 | |||
115 | { | 115 | { |
116 | mDataMutex->unlock(); | 116 | mDataMutex->unlock(); |
117 | } | 117 | } |
118 | return volgroupp->getLODVolume(detail); | 118 | return volgroupp->refLOD(detail); |
119 | } | 119 | } |
120 | 120 | ||
121 | // virtual | 121 | // virtual |
@@ -294,7 +294,7 @@ bool LLVolumeLODGroup::cleanupRefs() | |||
294 | return res; | 294 | return res; |
295 | } | 295 | } |
296 | 296 | ||
297 | LLVolume* LLVolumeLODGroup::getLODVolume(const S32 detail) | 297 | LLVolume* LLVolumeLODGroup::refLOD(const S32 detail) |
298 | { | 298 | { |
299 | llassert(detail >=0 && detail < NUM_LODS); | 299 | llassert(detail >=0 && detail < NUM_LODS); |
300 | mAccessCount[detail]++; | 300 | mAccessCount[detail]++; |
@@ -376,7 +376,6 @@ F32 LLVolumeLODGroup::getVolumeScaleFromDetail(const S32 detail) | |||
376 | 376 | ||
377 | F32 LLVolumeLODGroup::dump() | 377 | F32 LLVolumeLODGroup::dump() |
378 | { | 378 | { |
379 | char dump_str[255]; /* Flawfinder: ignore */ | ||
380 | F32 usage = 0.f; | 379 | F32 usage = 0.f; |
381 | for (S32 i = 0; i < NUM_LODS; i++) | 380 | for (S32 i = 0; i < NUM_LODS; i++) |
382 | { | 381 | { |
@@ -387,7 +386,7 @@ F32 LLVolumeLODGroup::dump() | |||
387 | } | 386 | } |
388 | usage = usage / (F32)NUM_LODS; | 387 | usage = usage / (F32)NUM_LODS; |
389 | 388 | ||
390 | snprintf(dump_str, sizeof(dump_str), "%.3f %d %d %d %d", usage, mAccessCount[0], mAccessCount[1], mAccessCount[2], mAccessCount[3]); /* Flawfinder: ignore */ | 389 | std::string dump_str = llformat("%.3f %d %d %d %d", usage, mAccessCount[0], mAccessCount[1], mAccessCount[2], mAccessCount[3]); |
391 | 390 | ||
392 | llinfos << dump_str << llendl; | 391 | llinfos << dump_str << llendl; |
393 | return usage; | 392 | return usage; |
diff --git a/linden/indra/llmath/llvolumemgr.h b/linden/indra/llmath/llvolumemgr.h index dcaca01..d579fed 100644 --- a/linden/indra/llmath/llvolumemgr.h +++ b/linden/indra/llmath/llvolumemgr.h | |||
@@ -59,7 +59,7 @@ public: | |||
59 | static void getDetailProximity(const F32 tan_angle, F32 &to_lower, F32& to_higher); | 59 | static void getDetailProximity(const F32 tan_angle, F32 &to_lower, F32& to_higher); |
60 | static F32 getVolumeScaleFromDetail(const S32 detail); | 60 | static F32 getVolumeScaleFromDetail(const S32 detail); |
61 | 61 | ||
62 | LLVolume* getLODVolume(const S32 detail); | 62 | LLVolume* refLOD(const S32 detail); |
63 | BOOL derefLOD(LLVolume *volumep); | 63 | BOOL derefLOD(LLVolume *volumep); |
64 | S32 getNumRefs() const { return mRefs; } | 64 | S32 getNumRefs() const { return mRefs; } |
65 | 65 | ||
diff --git a/linden/indra/llmath/v2math.cpp b/linden/indra/llmath/v2math.cpp index 76fa60f..c3bb093 100644 --- a/linden/indra/llmath/v2math.cpp +++ b/linden/indra/llmath/v2math.cpp | |||
@@ -33,6 +33,7 @@ | |||
33 | 33 | ||
34 | //#include "vmath.h" | 34 | //#include "vmath.h" |
35 | #include "v2math.h" | 35 | #include "v2math.h" |
36 | #include "v3math.h" | ||
36 | #include "v4math.h" | 37 | #include "v4math.h" |
37 | #include "m4math.h" | 38 | #include "m4math.h" |
38 | #include "m3math.h" | 39 | #include "m3math.h" |
diff --git a/linden/indra/llmath/v2math.h b/linden/indra/llmath/v2math.h index 5a520d2..350079d 100644 --- a/linden/indra/llmath/v2math.h +++ b/linden/indra/llmath/v2math.h | |||
@@ -33,6 +33,7 @@ | |||
33 | #define LL_V2MATH_H | 33 | #define LL_V2MATH_H |
34 | 34 | ||
35 | #include "llmath.h" | 35 | #include "llmath.h" |
36 | #include "v3math.h" | ||
36 | 37 | ||
37 | class LLVector4; | 38 | class LLVector4; |
38 | class LLMatrix3; | 39 | class LLMatrix3; |
@@ -49,9 +50,10 @@ class LLVector2 | |||
49 | 50 | ||
50 | static LLVector2 zero; | 51 | static LLVector2 zero; |
51 | 52 | ||
52 | LLVector2(); // Initializes LLVector2 to (0, 0) | 53 | LLVector2(); // Initializes LLVector2 to (0, 0) |
53 | LLVector2(F32 x, F32 y); // Initializes LLVector2 to (x. y) | 54 | LLVector2(F32 x, F32 y); // Initializes LLVector2 to (x. y) |
54 | LLVector2(const F32 *vec); // Initializes LLVector2 to (vec[0]. vec[1]) | 55 | LLVector2(const F32 *vec); // Initializes LLVector2 to (vec[0]. vec[1]) |
56 | explicit LLVector2(const LLVector3 &vec); // Initializes LLVector2 to (vec[0]. vec[1]) | ||
55 | 57 | ||
56 | // Clears LLVector2 to (0, 0). DEPRECATED - prefer zeroVec. | 58 | // Clears LLVector2 to (0, 0). DEPRECATED - prefer zeroVec. |
57 | void clear(); | 59 | void clear(); |
@@ -137,6 +139,12 @@ inline LLVector2::LLVector2(const F32 *vec) | |||
137 | mV[VY] = vec[VY]; | 139 | mV[VY] = vec[VY]; |
138 | } | 140 | } |
139 | 141 | ||
142 | inline LLVector2::LLVector2(const LLVector3 &vec) | ||
143 | { | ||
144 | mV[VX] = vec.mV[VX]; | ||
145 | mV[VY] = vec.mV[VY]; | ||
146 | } | ||
147 | |||
140 | 148 | ||
141 | // Clear and Assignment Functions | 149 | // Clear and Assignment Functions |
142 | 150 | ||
diff --git a/linden/indra/llmath/v3color.h b/linden/indra/llmath/v3color.h index a3bf385..b9bc641 100644 --- a/linden/indra/llmath/v3color.h +++ b/linden/indra/llmath/v3color.h | |||
@@ -174,6 +174,10 @@ inline LLColor3::LLColor3(const F32 *vec) | |||
174 | mV[VZ] = vec[VZ]; | 174 | mV[VZ] = vec[VZ]; |
175 | } | 175 | } |
176 | 176 | ||
177 | #if LL_WINDOWS | ||
178 | # pragma warning( disable : 4996 ) // strncpy teh sux0r | ||
179 | #endif | ||
180 | |||
177 | inline LLColor3::LLColor3(char* color_string) // takes a string of format "RRGGBB" where RR is hex 00..FF | 181 | inline LLColor3::LLColor3(char* color_string) // takes a string of format "RRGGBB" where RR is hex 00..FF |
178 | { | 182 | { |
179 | if (strlen(color_string) < 6) /* Flawfinder: ignore */ | 183 | if (strlen(color_string) < 6) /* Flawfinder: ignore */ |
diff --git a/linden/indra/llmath/v3dmath.cpp b/linden/indra/llmath/v3dmath.cpp index b59f519..5a3246c 100644 --- a/linden/indra/llmath/v3dmath.cpp +++ b/linden/indra/llmath/v3dmath.cpp | |||
@@ -132,15 +132,15 @@ const LLVector3d& LLVector3d::rotVec(F64 angle, F64 x, F64 y, F64 z) | |||
132 | } | 132 | } |
133 | 133 | ||
134 | 134 | ||
135 | BOOL LLVector3d::parseVector3d(const char* buf, LLVector3d* value) | 135 | BOOL LLVector3d::parseVector3d(const std::string& buf, LLVector3d* value) |
136 | { | 136 | { |
137 | if( buf == NULL || buf[0] == '\0' || value == NULL) | 137 | if( buf.empty() || value == NULL) |
138 | { | 138 | { |
139 | return FALSE; | 139 | return FALSE; |
140 | } | 140 | } |
141 | 141 | ||
142 | LLVector3d v; | 142 | LLVector3d v; |
143 | S32 count = sscanf( buf, "%lf %lf %lf", v.mdV + 0, v.mdV + 1, v.mdV + 2 ); | 143 | S32 count = sscanf( buf.c_str(), "%lf %lf %lf", v.mdV + 0, v.mdV + 1, v.mdV + 2 ); |
144 | if( 3 == count ) | 144 | if( 3 == count ) |
145 | { | 145 | { |
146 | value->setVec( v ); | 146 | value->setVec( v ); |
diff --git a/linden/indra/llmath/v3dmath.h b/linden/indra/llmath/v3dmath.h index 9bd80b8..ecb333a 100644 --- a/linden/indra/llmath/v3dmath.h +++ b/linden/indra/llmath/v3dmath.h | |||
@@ -95,6 +95,10 @@ class LLVector3d | |||
95 | F64 magVecSquared() const; // Returns magnitude squared of LLVector3d | 95 | F64 magVecSquared() const; // Returns magnitude squared of LLVector3d |
96 | inline F64 normVec(); // Normalizes and returns the magnitude of LLVector3d | 96 | inline F64 normVec(); // Normalizes and returns the magnitude of LLVector3d |
97 | 97 | ||
98 | F64 length() const; // Returns magnitude of LLVector3d | ||
99 | F64 lengthSquared() const; // Returns magnitude squared of LLVector3d | ||
100 | inline F64 normalize(); // Normalizes and returns the magnitude of LLVector3d | ||
101 | |||
98 | const LLVector3d& rotVec(const F64 angle, const LLVector3d &vec); // Rotates about vec by angle radians | 102 | const LLVector3d& rotVec(const F64 angle, const LLVector3d &vec); // Rotates about vec by angle radians |
99 | const LLVector3d& rotVec(const F64 angle, const F64 x, const F64 y, const F64 z); // Rotates about x,y,z by angle radians | 103 | const LLVector3d& rotVec(const F64 angle, const F64 x, const F64 y, const F64 z); // Rotates about x,y,z by angle radians |
100 | const LLVector3d& rotVec(const LLMatrix3 &mat); // Rotates by LLMatrix4 mat | 104 | const LLVector3d& rotVec(const LLMatrix3 &mat); // Rotates by LLMatrix4 mat |
@@ -128,7 +132,7 @@ class LLVector3d | |||
128 | 132 | ||
129 | friend std::ostream& operator<<(std::ostream& s, const LLVector3d &a); // Stream a | 133 | friend std::ostream& operator<<(std::ostream& s, const LLVector3d &a); // Stream a |
130 | 134 | ||
131 | static BOOL parseVector3d(const char* buf, LLVector3d* value); | 135 | static BOOL parseVector3d(const std::string& buf, LLVector3d* value); |
132 | 136 | ||
133 | }; | 137 | }; |
134 | 138 | ||
@@ -261,6 +265,28 @@ inline F64 LLVector3d::normVec(void) | |||
261 | return (mag); | 265 | return (mag); |
262 | } | 266 | } |
263 | 267 | ||
268 | inline F64 LLVector3d::normalize(void) | ||
269 | { | ||
270 | F64 mag = fsqrtf(mdV[0]*mdV[0] + mdV[1]*mdV[1] + mdV[2]*mdV[2]); | ||
271 | F64 oomag; | ||
272 | |||
273 | if (mag > FP_MAG_THRESHOLD) | ||
274 | { | ||
275 | oomag = 1.f/mag; | ||
276 | mdV[0] *= oomag; | ||
277 | mdV[1] *= oomag; | ||
278 | mdV[2] *= oomag; | ||
279 | } | ||
280 | else | ||
281 | { | ||
282 | mdV[0] = 0.f; | ||
283 | mdV[1] = 0.f; | ||
284 | mdV[2] = 0.f; | ||
285 | mag = 0; | ||
286 | } | ||
287 | return (mag); | ||
288 | } | ||
289 | |||
264 | // LLVector3d Magnitude and Normalization Functions | 290 | // LLVector3d Magnitude and Normalization Functions |
265 | 291 | ||
266 | inline F64 LLVector3d::magVec(void) const | 292 | inline F64 LLVector3d::magVec(void) const |
@@ -273,6 +299,16 @@ inline F64 LLVector3d::magVecSquared(void) const | |||
273 | return mdV[0]*mdV[0] + mdV[1]*mdV[1] + mdV[2]*mdV[2]; | 299 | return mdV[0]*mdV[0] + mdV[1]*mdV[1] + mdV[2]*mdV[2]; |
274 | } | 300 | } |
275 | 301 | ||
302 | inline F64 LLVector3d::length(void) const | ||
303 | { | ||
304 | return fsqrtf(mdV[0]*mdV[0] + mdV[1]*mdV[1] + mdV[2]*mdV[2]); | ||
305 | } | ||
306 | |||
307 | inline F64 LLVector3d::lengthSquared(void) const | ||
308 | { | ||
309 | return mdV[0]*mdV[0] + mdV[1]*mdV[1] + mdV[2]*mdV[2]; | ||
310 | } | ||
311 | |||
276 | inline LLVector3d operator+(const LLVector3d &a, const LLVector3d &b) | 312 | inline LLVector3d operator+(const LLVector3d &a, const LLVector3d &b) |
277 | { | 313 | { |
278 | LLVector3d c(a); | 314 | LLVector3d c(a); |
@@ -416,8 +452,8 @@ inline F64 angle_between(const LLVector3d& a, const LLVector3d& b) | |||
416 | { | 452 | { |
417 | LLVector3d an = a; | 453 | LLVector3d an = a; |
418 | LLVector3d bn = b; | 454 | LLVector3d bn = b; |
419 | an.normVec(); | 455 | an.normalize(); |
420 | bn.normVec(); | 456 | bn.normalize(); |
421 | F64 cosine = an * bn; | 457 | F64 cosine = an * bn; |
422 | F64 angle = (cosine >= 1.0f) ? 0.0f : | 458 | F64 angle = (cosine >= 1.0f) ? 0.0f : |
423 | (cosine <= -1.0f) ? F_PI : | 459 | (cosine <= -1.0f) ? F_PI : |
@@ -429,8 +465,8 @@ inline BOOL are_parallel(const LLVector3d &a, const LLVector3d &b, const F64 eps | |||
429 | { | 465 | { |
430 | LLVector3d an = a; | 466 | LLVector3d an = a; |
431 | LLVector3d bn = b; | 467 | LLVector3d bn = b; |
432 | an.normVec(); | 468 | an.normalize(); |
433 | bn.normVec(); | 469 | bn.normalize(); |
434 | F64 dot = an * bn; | 470 | F64 dot = an * bn; |
435 | if ( (1.0f - fabs(dot)) < epsilon) | 471 | if ( (1.0f - fabs(dot)) < epsilon) |
436 | { | 472 | { |
@@ -443,7 +479,7 @@ inline BOOL are_parallel(const LLVector3d &a, const LLVector3d &b, const F64 eps | |||
443 | inline LLVector3d projected_vec(const LLVector3d &a, const LLVector3d &b) | 479 | inline LLVector3d projected_vec(const LLVector3d &a, const LLVector3d &b) |
444 | { | 480 | { |
445 | LLVector3d project_axis = b; | 481 | LLVector3d project_axis = b; |
446 | project_axis.normVec(); | 482 | project_axis.normalize(); |
447 | return project_axis * (a * project_axis); | 483 | return project_axis * (a * project_axis); |
448 | } | 484 | } |
449 | 485 | ||
diff --git a/linden/indra/llmath/v3math.cpp b/linden/indra/llmath/v3math.cpp index bbe460f..cb87836 100644 --- a/linden/indra/llmath/v3math.cpp +++ b/linden/indra/llmath/v3math.cpp | |||
@@ -34,6 +34,7 @@ | |||
34 | #include "v3math.h" | 34 | #include "v3math.h" |
35 | 35 | ||
36 | //#include "vmath.h" | 36 | //#include "vmath.h" |
37 | #include "v2math.h" | ||
37 | #include "v4math.h" | 38 | #include "v4math.h" |
38 | #include "m4math.h" | 39 | #include "m4math.h" |
39 | #include "m3math.h" | 40 | #include "m3math.h" |
@@ -73,6 +74,72 @@ BOOL LLVector3::clamp(F32 min, F32 max) | |||
73 | return ret; | 74 | return ret; |
74 | } | 75 | } |
75 | 76 | ||
77 | // Clamps length to an upper limit. | ||
78 | // Returns TRUE if the data changed | ||
79 | BOOL LLVector3::clampLength( F32 length_limit ) | ||
80 | { | ||
81 | BOOL changed = FALSE; | ||
82 | |||
83 | F32 len = length(); | ||
84 | if (llfinite(len)) | ||
85 | { | ||
86 | if ( len > length_limit) | ||
87 | { | ||
88 | normalize(); | ||
89 | if (length_limit < 0.f) | ||
90 | { | ||
91 | length_limit = 0.f; | ||
92 | } | ||
93 | mV[0] *= length_limit; | ||
94 | mV[1] *= length_limit; | ||
95 | mV[2] *= length_limit; | ||
96 | changed = TRUE; | ||
97 | } | ||
98 | } | ||
99 | else | ||
100 | { // this vector may still be salvagable | ||
101 | F32 max_abs_component = 0.f; | ||
102 | for (S32 i = 0; i < 3; ++i) | ||
103 | { | ||
104 | F32 abs_component = fabs(mV[i]); | ||
105 | if (llfinite(abs_component)) | ||
106 | { | ||
107 | if (abs_component > max_abs_component) | ||
108 | { | ||
109 | max_abs_component = abs_component; | ||
110 | } | ||
111 | } | ||
112 | else | ||
113 | { | ||
114 | // no it can't be salvaged --> clear it | ||
115 | clear(); | ||
116 | changed = TRUE; | ||
117 | break; | ||
118 | } | ||
119 | } | ||
120 | if (!changed) | ||
121 | { | ||
122 | // yes it can be salvaged --> | ||
123 | // bring the components down before we normalize | ||
124 | mV[0] /= max_abs_component; | ||
125 | mV[1] /= max_abs_component; | ||
126 | mV[2] /= max_abs_component; | ||
127 | normalize(); | ||
128 | |||
129 | if (length_limit < 0.f) | ||
130 | { | ||
131 | length_limit = 0.f; | ||
132 | } | ||
133 | mV[0] *= length_limit; | ||
134 | mV[1] *= length_limit; | ||
135 | mV[2] *= length_limit; | ||
136 | } | ||
137 | } | ||
138 | |||
139 | return changed; | ||
140 | } | ||
141 | |||
142 | |||
76 | // Sets all values to absolute value of their original values | 143 | // Sets all values to absolute value of their original values |
77 | // Returns TRUE if data changed | 144 | // Returns TRUE if data changed |
78 | BOOL LLVector3::abs() | 145 | BOOL LLVector3::abs() |
@@ -204,6 +271,13 @@ const LLVector3& LLVector3::setVec(const LLVector4 &vec) | |||
204 | return (*this); | 271 | return (*this); |
205 | } | 272 | } |
206 | 273 | ||
274 | LLVector3::LLVector3(const LLVector2 &vec) | ||
275 | { | ||
276 | mV[VX] = (F32)vec.mV[VX]; | ||
277 | mV[VY] = (F32)vec.mV[VY]; | ||
278 | mV[VZ] = 0; | ||
279 | } | ||
280 | |||
207 | LLVector3::LLVector3(const LLVector3d &vec) | 281 | LLVector3::LLVector3(const LLVector3d &vec) |
208 | { | 282 | { |
209 | mV[VX] = (F32)vec.mdV[VX]; | 283 | mV[VX] = (F32)vec.mdV[VX]; |
@@ -260,15 +334,15 @@ const LLVector3& operator*=(LLVector3 &a, const LLQuaternion &rot) | |||
260 | } | 334 | } |
261 | 335 | ||
262 | // static | 336 | // static |
263 | BOOL LLVector3::parseVector3(const char* buf, LLVector3* value) | 337 | BOOL LLVector3::parseVector3(const std::string& buf, LLVector3* value) |
264 | { | 338 | { |
265 | if( buf == NULL || buf[0] == '\0' || value == NULL) | 339 | if( buf.empty() || value == NULL) |
266 | { | 340 | { |
267 | return FALSE; | 341 | return FALSE; |
268 | } | 342 | } |
269 | 343 | ||
270 | LLVector3 v; | 344 | LLVector3 v; |
271 | S32 count = sscanf( buf, "%f %f %f", v.mV + 0, v.mV + 1, v.mV + 2 ); | 345 | S32 count = sscanf( buf.c_str(), "%f %f %f", v.mV + 0, v.mV + 1, v.mV + 2 ); |
272 | if( 3 == count ) | 346 | if( 3 == count ) |
273 | { | 347 | { |
274 | value->setVec( v ); | 348 | value->setVec( v ); |
diff --git a/linden/indra/llmath/v3math.h b/linden/indra/llmath/v3math.h index ddb5e1f..65932cd 100644 --- a/linden/indra/llmath/v3math.h +++ b/linden/indra/llmath/v3math.h | |||
@@ -36,6 +36,7 @@ | |||
36 | #include "llmath.h" | 36 | #include "llmath.h" |
37 | 37 | ||
38 | #include "llsd.h" | 38 | #include "llsd.h" |
39 | class LLVector2; | ||
39 | class LLVector4; | 40 | class LLVector4; |
40 | class LLMatrix3; | 41 | class LLMatrix3; |
41 | class LLVector3d; | 42 | class LLVector3d; |
@@ -62,6 +63,7 @@ class LLVector3 | |||
62 | inline LLVector3(); // Initializes LLVector3 to (0, 0, 0) | 63 | inline LLVector3(); // Initializes LLVector3 to (0, 0, 0) |
63 | inline LLVector3(const F32 x, const F32 y, const F32 z); // Initializes LLVector3 to (x. y, z) | 64 | inline LLVector3(const F32 x, const F32 y, const F32 z); // Initializes LLVector3 to (x. y, z) |
64 | inline explicit LLVector3(const F32 *vec); // Initializes LLVector3 to (vec[0]. vec[1], vec[2]) | 65 | inline explicit LLVector3(const F32 *vec); // Initializes LLVector3 to (vec[0]. vec[1], vec[2]) |
66 | explicit LLVector3(const LLVector2 &vec); // Initializes LLVector3 to (vec[0]. vec[1], 0) | ||
65 | explicit LLVector3(const LLVector3d &vec); // Initializes LLVector3 to (vec[0]. vec[1], vec[2]) | 67 | explicit LLVector3(const LLVector3d &vec); // Initializes LLVector3 to (vec[0]. vec[1], vec[2]) |
66 | explicit LLVector3(const LLVector4 &vec); // Initializes LLVector4 to (vec[0]. vec[1], vec[2]) | 68 | explicit LLVector3(const LLVector4 &vec); // Initializes LLVector4 to (vec[0]. vec[1], vec[2]) |
67 | LLVector3(const LLSD& sd); | 69 | LLVector3(const LLSD& sd); |
@@ -74,6 +76,7 @@ class LLVector3 | |||
74 | 76 | ||
75 | inline BOOL isFinite() const; // checks to see if all values of LLVector3 are finite | 77 | inline BOOL isFinite() const; // checks to see if all values of LLVector3 are finite |
76 | BOOL clamp(F32 min, F32 max); // Clamps all values to (min,max), returns TRUE if data changed | 78 | BOOL clamp(F32 min, F32 max); // Clamps all values to (min,max), returns TRUE if data changed |
79 | BOOL clampLength( F32 length_limit ); // Scales vector to limit length to a value | ||
77 | 80 | ||
78 | void quantize16(F32 lowerxy, F32 upperxy, F32 lowerz, F32 upperz); // changes the vector to reflect quatization | 81 | void quantize16(F32 lowerxy, F32 upperxy, F32 lowerz, F32 upperz); // changes the vector to reflect quatization |
79 | void quantize8(F32 lowerxy, F32 upperxy, F32 lowerz, F32 upperz); // changes the vector to reflect quatization | 82 | void quantize8(F32 lowerxy, F32 upperxy, F32 lowerz, F32 upperz); // changes the vector to reflect quatization |
@@ -147,7 +150,7 @@ class LLVector3 | |||
147 | 150 | ||
148 | friend std::ostream& operator<<(std::ostream& s, const LLVector3 &a); // Stream a | 151 | friend std::ostream& operator<<(std::ostream& s, const LLVector3 &a); // Stream a |
149 | 152 | ||
150 | static BOOL parseVector3(const char* buf, LLVector3* value); | 153 | static BOOL parseVector3(const std::string& buf, LLVector3* value); |
151 | }; | 154 | }; |
152 | 155 | ||
153 | typedef LLVector3 LLSimLocalVec; | 156 | typedef LLVector3 LLSimLocalVec; |
diff --git a/linden/indra/llmath/v4color.cpp b/linden/indra/llmath/v4color.cpp index 8e6907e..88237a0 100644 --- a/linden/indra/llmath/v4color.cpp +++ b/linden/indra/llmath/v4color.cpp | |||
@@ -286,16 +286,14 @@ void LLColor4::calcHSL(F32* hue, F32* saturation, F32* luminance) const | |||
286 | } | 286 | } |
287 | 287 | ||
288 | // static | 288 | // static |
289 | BOOL LLColor4::parseColor(const char* buf, LLColor4* color) | 289 | BOOL LLColor4::parseColor(const std::string& buf, LLColor4* color) |
290 | { | 290 | { |
291 | if( buf == NULL || buf[0] == '\0' || color == NULL) | 291 | if( buf.empty() || color == NULL) |
292 | { | 292 | { |
293 | return FALSE; | 293 | return FALSE; |
294 | } | 294 | } |
295 | 295 | ||
296 | LLString full_string(buf); | 296 | boost_tokenizer tokens(buf, boost::char_separator<char>(", ")); |
297 | |||
298 | boost_tokenizer tokens(full_string, boost::char_separator<char>(", ")); | ||
299 | boost_tokenizer::iterator token_iter = tokens.begin(); | 297 | boost_tokenizer::iterator token_iter = tokens.begin(); |
300 | if (token_iter == tokens.end()) | 298 | if (token_iter == tokens.end()) |
301 | { | 299 | { |
@@ -304,15 +302,15 @@ BOOL LLColor4::parseColor(const char* buf, LLColor4* color) | |||
304 | 302 | ||
305 | // Grab the first token into a string, since we don't know | 303 | // Grab the first token into a string, since we don't know |
306 | // if this is a float or a color name. | 304 | // if this is a float or a color name. |
307 | LLString color_name( (*token_iter) ); | 305 | std::string color_name( (*token_iter) ); |
308 | ++token_iter; | 306 | ++token_iter; |
309 | 307 | ||
310 | if (token_iter != tokens.end()) | 308 | if (token_iter != tokens.end()) |
311 | { | 309 | { |
312 | // There are more tokens to read. This must be a vector. | 310 | // There are more tokens to read. This must be a vector. |
313 | LLColor4 v; | 311 | LLColor4 v; |
314 | LLString::convertToF32( color_name, v.mV[VX] ); | 312 | LLStringUtil::convertToF32( color_name, v.mV[VX] ); |
315 | LLString::convertToF32( *token_iter, v.mV[VY] ); | 313 | LLStringUtil::convertToF32( *token_iter, v.mV[VY] ); |
316 | v.mV[VZ] = 0.0f; | 314 | v.mV[VZ] = 0.0f; |
317 | v.mV[VW] = 1.0f; | 315 | v.mV[VW] = 1.0f; |
318 | 316 | ||
@@ -320,18 +318,18 @@ BOOL LLColor4::parseColor(const char* buf, LLColor4* color) | |||
320 | if (token_iter == tokens.end()) | 318 | if (token_iter == tokens.end()) |
321 | { | 319 | { |
322 | // This is a malformed vector. | 320 | // This is a malformed vector. |
323 | llwarns << "LLColor4::parseColor() malformed color " << full_string << llendl; | 321 | llwarns << "LLColor4::parseColor() malformed color " << buf << llendl; |
324 | } | 322 | } |
325 | else | 323 | else |
326 | { | 324 | { |
327 | // There is a z-component. | 325 | // There is a z-component. |
328 | LLString::convertToF32( *token_iter, v.mV[VZ] ); | 326 | LLStringUtil::convertToF32( *token_iter, v.mV[VZ] ); |
329 | 327 | ||
330 | ++token_iter; | 328 | ++token_iter; |
331 | if (token_iter != tokens.end()) | 329 | if (token_iter != tokens.end()) |
332 | { | 330 | { |
333 | // There is an alpha component. | 331 | // There is an alpha component. |
334 | LLString::convertToF32( *token_iter, v.mV[VW] ); | 332 | LLStringUtil::convertToF32( *token_iter, v.mV[VW] ); |
335 | } | 333 | } |
336 | } | 334 | } |
337 | 335 | ||
@@ -615,19 +613,19 @@ BOOL LLColor4::parseColor(const char* buf, LLColor4* color) | |||
615 | } | 613 | } |
616 | 614 | ||
617 | // static | 615 | // static |
618 | BOOL LLColor4::parseColor4(const char* buf, LLColor4* value) | 616 | BOOL LLColor4::parseColor4(const std::string& buf, LLColor4* value) |
619 | { | 617 | { |
620 | if( buf == NULL || buf[0] == '\0' || value == NULL) | 618 | if( buf.empty() || value == NULL) |
621 | { | 619 | { |
622 | return FALSE; | 620 | return FALSE; |
623 | } | 621 | } |
624 | 622 | ||
625 | LLColor4 v; | 623 | LLColor4 v; |
626 | S32 count = sscanf( buf, "%f, %f, %f, %f", v.mV + 0, v.mV + 1, v.mV + 2, v.mV + 3 ); | 624 | S32 count = sscanf( buf.c_str(), "%f, %f, %f, %f", v.mV + 0, v.mV + 1, v.mV + 2, v.mV + 3 ); |
627 | if (1 == count ) | 625 | if (1 == count ) |
628 | { | 626 | { |
629 | // try this format | 627 | // try this format |
630 | count = sscanf( buf, "%f %f %f %f", v.mV + 0, v.mV + 1, v.mV + 2, v.mV + 3 ); | 628 | count = sscanf( buf.c_str(), "%f %f %f %f", v.mV + 0, v.mV + 1, v.mV + 2, v.mV + 3 ); |
631 | } | 629 | } |
632 | if( 4 == count ) | 630 | if( 4 == count ) |
633 | { | 631 | { |
diff --git a/linden/indra/llmath/v4color.h b/linden/indra/llmath/v4color.h index a2c0fb6..53e4407 100644 --- a/linden/indra/llmath/v4color.h +++ b/linden/indra/llmath/v4color.h | |||
@@ -211,8 +211,8 @@ class LLColor4 | |||
211 | static LLColor4 cyan5; | 211 | static LLColor4 cyan5; |
212 | static LLColor4 cyan6; | 212 | static LLColor4 cyan6; |
213 | 213 | ||
214 | static BOOL parseColor(const char* buf, LLColor4* color); | 214 | static BOOL parseColor(const std::string& buf, LLColor4* color); |
215 | static BOOL parseColor4(const char* buf, LLColor4* color); | 215 | static BOOL parseColor4(const std::string& buf, LLColor4* color); |
216 | 216 | ||
217 | inline void clamp(); | 217 | inline void clamp(); |
218 | }; | 218 | }; |
diff --git a/linden/indra/llmath/v4coloru.cpp b/linden/indra/llmath/v4coloru.cpp index 56a8413..7ad7eb2 100644 --- a/linden/indra/llmath/v4coloru.cpp +++ b/linden/indra/llmath/v4coloru.cpp | |||
@@ -93,19 +93,19 @@ std::ostream& operator<<(std::ostream& s, const LLColor4U &a) | |||
93 | } | 93 | } |
94 | 94 | ||
95 | // static | 95 | // static |
96 | BOOL LLColor4U::parseColor4U(const char* buf, LLColor4U* value) | 96 | BOOL LLColor4U::parseColor4U(const std::string& buf, LLColor4U* value) |
97 | { | 97 | { |
98 | if( buf == NULL || buf[0] == '\0' || value == NULL) | 98 | if( buf.empty() || value == NULL) |
99 | { | 99 | { |
100 | return FALSE; | 100 | return FALSE; |
101 | } | 101 | } |
102 | 102 | ||
103 | U32 v[4]; | 103 | U32 v[4]; |
104 | S32 count = sscanf( buf, "%u, %u, %u, %u", v + 0, v + 1, v + 2, v + 3 ); | 104 | S32 count = sscanf( buf.c_str(), "%u, %u, %u, %u", v + 0, v + 1, v + 2, v + 3 ); |
105 | if (1 == count ) | 105 | if (1 == count ) |
106 | { | 106 | { |
107 | // try this format | 107 | // try this format |
108 | count = sscanf( buf, "%u %u %u %u", v + 0, v + 1, v + 2, v + 3 ); | 108 | count = sscanf( buf.c_str(), "%u %u %u %u", v + 0, v + 1, v + 2, v + 3 ); |
109 | } | 109 | } |
110 | if( 4 != count ) | 110 | if( 4 != count ) |
111 | { | 111 | { |
diff --git a/linden/indra/llmath/v4coloru.h b/linden/indra/llmath/v4coloru.h index c9c5418..910a081 100644 --- a/linden/indra/llmath/v4coloru.h +++ b/linden/indra/llmath/v4coloru.h | |||
@@ -127,7 +127,7 @@ public: | |||
127 | inline void setVecScaleClamp(const LLColor3 &color); | 127 | inline void setVecScaleClamp(const LLColor3 &color); |
128 | inline void setVecScaleClamp(const LLColor4 &color); | 128 | inline void setVecScaleClamp(const LLColor4 &color); |
129 | 129 | ||
130 | static BOOL parseColor4U(const char* buf, LLColor4U* value); | 130 | static BOOL parseColor4U(const std::string& buf, LLColor4U* value); |
131 | 131 | ||
132 | static LLColor4U white; | 132 | static LLColor4U white; |
133 | static LLColor4U black; | 133 | static LLColor4U black; |