diff options
Diffstat (limited to '')
23 files changed, 240 insertions, 91 deletions
diff --git a/linden/indra/llimage/CMakeLists.txt b/linden/indra/llimage/CMakeLists.txt index 5593b4a..1a4d92b 100644 --- a/linden/indra/llimage/CMakeLists.txt +++ b/linden/indra/llimage/CMakeLists.txt | |||
@@ -7,6 +7,7 @@ include(LLCommon) | |||
7 | include(LLImage) | 7 | include(LLImage) |
8 | include(LLMath) | 8 | include(LLMath) |
9 | include(LLVFS) | 9 | include(LLVFS) |
10 | include(ZLIB) | ||
10 | 11 | ||
11 | include_directories( | 12 | include_directories( |
12 | ${LLCOMMON_INCLUDE_DIRS} | 13 | ${LLCOMMON_INCLUDE_DIRS} |
@@ -48,3 +49,9 @@ set_source_files_properties(${llimage_HEADER_FILES} | |||
48 | list(APPEND llimage_SOURCE_FILES ${llimage_HEADER_FILES}) | 49 | list(APPEND llimage_SOURCE_FILES ${llimage_HEADER_FILES}) |
49 | 50 | ||
50 | add_library (llimage ${llimage_SOURCE_FILES}) | 51 | add_library (llimage ${llimage_SOURCE_FILES}) |
52 | target_link_libraries( | ||
53 | llimage | ||
54 | ${JPEG_LIBRARIES} | ||
55 | ${PNG_LIBRARIES} | ||
56 | ${ZLIB_LIBRARIES} | ||
57 | ) | ||
diff --git a/linden/indra/llimage/llimage.cpp b/linden/indra/llimage/llimage.cpp index 814e82f..d4489fc 100644 --- a/linden/indra/llimage/llimage.cpp +++ b/linden/indra/llimage/llimage.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -43,6 +43,49 @@ | |||
43 | #include "llimagejpeg.h" | 43 | #include "llimagejpeg.h" |
44 | #include "llimagepng.h" | 44 | #include "llimagepng.h" |
45 | #include "llimagedxt.h" | 45 | #include "llimagedxt.h" |
46 | #include "llimageworker.h" | ||
47 | |||
48 | //--------------------------------------------------------------------------- | ||
49 | // LLImage | ||
50 | //--------------------------------------------------------------------------- | ||
51 | |||
52 | //static | ||
53 | std::string LLImage::sLastErrorMessage; | ||
54 | LLMutex* LLImage::sMutex = NULL; | ||
55 | |||
56 | //static | ||
57 | void LLImage::initClass(LLWorkerThread* workerthread) | ||
58 | { | ||
59 | sMutex = new LLMutex(NULL); | ||
60 | if (workerthread) | ||
61 | { | ||
62 | LLImageWorker::initImageWorker(workerthread); | ||
63 | } | ||
64 | LLImageJ2C::openDSO(); | ||
65 | } | ||
66 | |||
67 | //static | ||
68 | void LLImage::cleanupClass() | ||
69 | { | ||
70 | LLImageJ2C::closeDSO(); | ||
71 | LLImageWorker::cleanupImageWorker(); | ||
72 | delete sMutex; | ||
73 | sMutex = NULL; | ||
74 | } | ||
75 | |||
76 | //static | ||
77 | const std::string& LLImage::getLastError() | ||
78 | { | ||
79 | static const std::string noerr("No Error"); | ||
80 | return sLastErrorMessage.empty() ? noerr : sLastErrorMessage; | ||
81 | } | ||
82 | |||
83 | //static | ||
84 | void LLImage::setLastError(const std::string& message) | ||
85 | { | ||
86 | LLMutexLock m(sMutex); | ||
87 | sLastErrorMessage = message; | ||
88 | } | ||
46 | 89 | ||
47 | //--------------------------------------------------------------------------- | 90 | //--------------------------------------------------------------------------- |
48 | // LLImageBase | 91 | // LLImageBase |
@@ -95,21 +138,8 @@ void LLImageBase::sanityCheck() | |||
95 | } | 138 | } |
96 | } | 139 | } |
97 | 140 | ||
98 | std::string LLImageBase::sLastErrorMessage; | ||
99 | BOOL LLImageBase::sSizeOverride = FALSE; | 141 | BOOL LLImageBase::sSizeOverride = FALSE; |
100 | 142 | ||
101 | BOOL LLImageBase::setLastError(const std::string& message, const std::string& filename) | ||
102 | { | ||
103 | sLastErrorMessage = message; | ||
104 | if (!filename.empty()) | ||
105 | { | ||
106 | sLastErrorMessage += " FILE:"; | ||
107 | sLastErrorMessage += filename; | ||
108 | } | ||
109 | llwarns << sLastErrorMessage << llendl; | ||
110 | return FALSE; | ||
111 | } | ||
112 | |||
113 | // virtual | 143 | // virtual |
114 | void LLImageBase::deleteData() | 144 | void LLImageBase::deleteData() |
115 | { | 145 | { |
@@ -136,8 +166,6 @@ U8* LLImageBase::allocateData(S32 size) | |||
136 | llerrs << "LLImageBase::allocateData: bad size: " << size << llendl; | 166 | llerrs << "LLImageBase::allocateData: bad size: " << size << llendl; |
137 | } | 167 | } |
138 | 168 | ||
139 | resetLastError(); | ||
140 | |||
141 | if (!mData || size != mDataSize) | 169 | if (!mData || size != mDataSize) |
142 | { | 170 | { |
143 | deleteData(); // virtual | 171 | deleteData(); // virtual |
@@ -1269,6 +1297,23 @@ LLImageFormatted::~LLImageFormatted() | |||
1269 | 1297 | ||
1270 | //---------------------------------------------------------------------------- | 1298 | //---------------------------------------------------------------------------- |
1271 | 1299 | ||
1300 | //virtual | ||
1301 | void LLImageFormatted::resetLastError() | ||
1302 | { | ||
1303 | LLImage::setLastError(""); | ||
1304 | } | ||
1305 | |||
1306 | //virtual | ||
1307 | void LLImageFormatted::setLastError(const std::string& message, const std::string& filename) | ||
1308 | { | ||
1309 | std::string error = message; | ||
1310 | if (!filename.empty()) | ||
1311 | error += std::string(" FILE: ") + filename; | ||
1312 | LLImage::setLastError(error); | ||
1313 | } | ||
1314 | |||
1315 | //---------------------------------------------------------------------------- | ||
1316 | |||
1272 | // static | 1317 | // static |
1273 | LLImageFormatted* LLImageFormatted::createFromType(S8 codec) | 1318 | LLImageFormatted* LLImageFormatted::createFromType(S8 codec) |
1274 | { | 1319 | { |
diff --git a/linden/indra/llimage/llimage.h b/linden/indra/llimage/llimage.h index 98a98c2..321eda8 100644 --- a/linden/indra/llimage/llimage.h +++ b/linden/indra/llimage/llimage.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2000&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2000&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2000-2008, Linden Research, Inc. | 7 | * Copyright (c) 2000-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -59,6 +59,7 @@ const S32 MAX_IMG_PACKET_SIZE = 1000; | |||
59 | class LLImageFormatted; | 59 | class LLImageFormatted; |
60 | class LLImageRaw; | 60 | class LLImageRaw; |
61 | class LLColor4U; | 61 | class LLColor4U; |
62 | class LLWorkerThread; | ||
62 | 63 | ||
63 | typedef enum e_image_codec | 64 | typedef enum e_image_codec |
64 | { | 65 | { |
@@ -74,6 +75,24 @@ typedef enum e_image_codec | |||
74 | } EImageCodec; | 75 | } EImageCodec; |
75 | 76 | ||
76 | //============================================================================ | 77 | //============================================================================ |
78 | // library initialization class | ||
79 | |||
80 | class LLImage | ||
81 | { | ||
82 | public: | ||
83 | static void initClass(LLWorkerThread* workerthread); | ||
84 | static void cleanupClass(); | ||
85 | |||
86 | static const std::string& getLastError(); | ||
87 | static void setLastError(const std::string& message); | ||
88 | |||
89 | protected: | ||
90 | static LLMutex* sMutex; | ||
91 | static std::string sLastErrorMessage; | ||
92 | }; | ||
93 | |||
94 | //============================================================================ | ||
95 | // Image base class | ||
77 | 96 | ||
78 | class LLImageBase : public LLThreadSafeRefCount | 97 | class LLImageBase : public LLThreadSafeRefCount |
79 | { | 98 | { |
@@ -113,10 +132,6 @@ protected: | |||
113 | void setDataAndSize(U8 *data, S32 size) { mData = data; mDataSize = size; }; | 132 | void setDataAndSize(U8 *data, S32 size) { mData = data; mDataSize = size; }; |
114 | 133 | ||
115 | public: | 134 | public: |
116 | static const std::string& getLastError() {return sLastErrorMessage;}; | ||
117 | static void resetLastError() {sLastErrorMessage = "No Error"; }; | ||
118 | static BOOL setLastError(const std::string& message, const std::string& filename = std::string()); // returns FALSE | ||
119 | |||
120 | static void generateMip(const U8 *indata, U8* mipdata, int width, int height, S32 nchannels); | 135 | static void generateMip(const U8 *indata, U8* mipdata, int width, int height, S32 nchannels); |
121 | 136 | ||
122 | // Function for calculating the download priority for textures | 137 | // Function for calculating the download priority for textures |
@@ -141,8 +156,6 @@ private: | |||
141 | public: | 156 | public: |
142 | S16 mMemType; // debug | 157 | S16 mMemType; // debug |
143 | 158 | ||
144 | static std::string sLastErrorMessage; | ||
145 | |||
146 | static BOOL sSizeOverride; | 159 | static BOOL sSizeOverride; |
147 | }; | 160 | }; |
148 | 161 | ||
@@ -245,7 +258,6 @@ public: | |||
245 | LLImageFormatted(S8 codec); | 258 | LLImageFormatted(S8 codec); |
246 | 259 | ||
247 | // LLImageBase | 260 | // LLImageBase |
248 | public: | ||
249 | /*virtual*/ void deleteData(); | 261 | /*virtual*/ void deleteData(); |
250 | /*virtual*/ U8* allocateData(S32 size = -1); | 262 | /*virtual*/ U8* allocateData(S32 size = -1); |
251 | /*virtual*/ U8* reallocateData(S32 size); | 263 | /*virtual*/ U8* reallocateData(S32 size); |
@@ -254,7 +266,6 @@ public: | |||
254 | /*virtual*/ void sanityCheck(); | 266 | /*virtual*/ void sanityCheck(); |
255 | 267 | ||
256 | // New methods | 268 | // New methods |
257 | public: | ||
258 | // subclasses must return a prefered file extension (lowercase without a leading dot) | 269 | // subclasses must return a prefered file extension (lowercase without a leading dot) |
259 | virtual std::string getExtension() = 0; | 270 | virtual std::string getExtension() = 0; |
260 | // calcHeaderSize() returns the maximum size of header; | 271 | // calcHeaderSize() returns the maximum size of header; |
@@ -287,6 +298,10 @@ public: | |||
287 | void setDiscardLevel(S8 discard_level) { mDiscardLevel = discard_level; } | 298 | void setDiscardLevel(S8 discard_level) { mDiscardLevel = discard_level; } |
288 | S8 getDiscardLevel() const { return mDiscardLevel; } | 299 | S8 getDiscardLevel() const { return mDiscardLevel; } |
289 | 300 | ||
301 | // setLastError needs to be deferred for J2C images since it may be called from a DLL | ||
302 | virtual void resetLastError(); | ||
303 | virtual void setLastError(const std::string& message, const std::string& filename = std::string()); | ||
304 | |||
290 | protected: | 305 | protected: |
291 | BOOL copyData(U8 *data, S32 size); // calls updateData() | 306 | BOOL copyData(U8 *data, S32 size); // calls updateData() |
292 | 307 | ||
@@ -295,7 +310,7 @@ protected: | |||
295 | S8 mDecoding; | 310 | S8 mDecoding; |
296 | S8 mDecoded; | 311 | S8 mDecoded; |
297 | S8 mDiscardLevel; | 312 | S8 mDiscardLevel; |
298 | 313 | ||
299 | public: | 314 | public: |
300 | static S32 sGlobalFormattedMemory; | 315 | static S32 sGlobalFormattedMemory; |
301 | }; | 316 | }; |
diff --git a/linden/indra/llimage/llimagebmp.cpp b/linden/indra/llimage/llimagebmp.cpp index c72eb24..ddc8825 100644 --- a/linden/indra/llimage/llimagebmp.cpp +++ b/linden/indra/llimage/llimagebmp.cpp | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | 6 | * Copyright (c) 2001-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagebmp.h b/linden/indra/llimage/llimagebmp.h index 4a0d6fb..9c0c611 100644 --- a/linden/indra/llimage/llimagebmp.h +++ b/linden/indra/llimage/llimagebmp.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagedxt.cpp b/linden/indra/llimage/llimagedxt.cpp index d3b8225..fe66ee3 100644 --- a/linden/indra/llimage/llimagedxt.cpp +++ b/linden/indra/llimage/llimagedxt.cpp | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | 6 | * Copyright (c) 2001-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagedxt.h b/linden/indra/llimage/llimagedxt.h index a3cb4c7..3d81414 100644 --- a/linden/indra/llimage/llimagedxt.h +++ b/linden/indra/llimage/llimagedxt.h | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | 6 | * Copyright (c) 2001-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagej2c.cpp b/linden/indra/llimage/llimagej2c.cpp index 510b303..fe5d656 100644 --- a/linden/indra/llimage/llimagej2c.cpp +++ b/linden/indra/llimage/llimagej2c.cpp | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | 6 | * Copyright (c) 2001-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -219,32 +219,54 @@ LLImageJ2C::~LLImageJ2C() | |||
219 | } | 219 | } |
220 | 220 | ||
221 | // virtual | 221 | // virtual |
222 | void LLImageJ2C::resetLastError() | ||
223 | { | ||
224 | mLastError.clear(); | ||
225 | } | ||
226 | |||
227 | //virtual | ||
228 | void LLImageJ2C::setLastError(const std::string& message, const std::string& filename) | ||
229 | { | ||
230 | mLastError = message; | ||
231 | if (!filename.empty()) | ||
232 | mLastError += std::string(" FILE: ") + filename; | ||
233 | } | ||
234 | |||
235 | // virtual | ||
222 | S8 LLImageJ2C::getRawDiscardLevel() | 236 | S8 LLImageJ2C::getRawDiscardLevel() |
223 | { | 237 | { |
224 | return mRawDiscardLevel; | 238 | return mRawDiscardLevel; |
225 | } | 239 | } |
226 | 240 | ||
227 | BOOL LLImageJ2C::updateData() | 241 | BOOL LLImageJ2C::updateData() |
228 | { | 242 | { |
243 | BOOL res = TRUE; | ||
229 | resetLastError(); | 244 | resetLastError(); |
230 | 245 | ||
231 | // Check to make sure that this instance has been initialized with data | 246 | // Check to make sure that this instance has been initialized with data |
232 | if (!getData() || (getDataSize() < 16)) | 247 | if (!getData() || (getDataSize() < 16)) |
233 | { | 248 | { |
234 | setLastError("LLImageJ2C uninitialized"); | 249 | setLastError("LLImageJ2C uninitialized"); |
235 | return FALSE; | 250 | res = FALSE; |
251 | } | ||
252 | else | ||
253 | { | ||
254 | res = mImpl->getMetadata(*this); | ||
236 | } | 255 | } |
237 | 256 | ||
238 | if (!mImpl->getMetadata(*this)) | 257 | if (res) |
239 | { | 258 | { |
240 | return FALSE; | 259 | // SJB: override discard based on mMaxBytes elsewhere |
260 | S32 max_bytes = getDataSize(); // mMaxBytes ? mMaxBytes : getDataSize(); | ||
261 | S32 discard = calcDiscardLevelBytes(max_bytes); | ||
262 | setDiscardLevel(discard); | ||
241 | } | 263 | } |
242 | // SJB: override discard based on mMaxBytes elsewhere | ||
243 | S32 max_bytes = getDataSize(); // mMaxBytes ? mMaxBytes : getDataSize(); | ||
244 | S32 discard = calcDiscardLevelBytes(max_bytes); | ||
245 | setDiscardLevel(discard); | ||
246 | 264 | ||
247 | return TRUE; | 265 | if (!mLastError.empty()) |
266 | { | ||
267 | LLImage::setLastError(mLastError); | ||
268 | } | ||
269 | return res; | ||
248 | } | 270 | } |
249 | 271 | ||
250 | 272 | ||
@@ -258,20 +280,24 @@ BOOL LLImageJ2C::decodeChannels(LLImageRaw *raw_imagep, F32 decode_time, S32 fir | |||
258 | { | 280 | { |
259 | LLMemType mt1((LLMemType::EMemType)mMemType); | 281 | LLMemType mt1((LLMemType::EMemType)mMemType); |
260 | 282 | ||
283 | BOOL res = TRUE; | ||
284 | |||
261 | resetLastError(); | 285 | resetLastError(); |
262 | 286 | ||
263 | // Check to make sure that this instance has been initialized with data | 287 | // Check to make sure that this instance has been initialized with data |
264 | if (!getData() || (getDataSize() < 16)) | 288 | if (!getData() || (getDataSize() < 16)) |
265 | { | 289 | { |
266 | setLastError("LLImageJ2C uninitialized"); | 290 | setLastError("LLImageJ2C uninitialized"); |
267 | return FALSE; | 291 | res = FALSE; |
268 | } | 292 | } |
269 | 293 | else | |
270 | // Update the raw discard level | 294 | { |
271 | updateRawDiscardLevel(); | 295 | // Update the raw discard level |
272 | 296 | updateRawDiscardLevel(); | |
273 | mDecoding = TRUE; | 297 | mDecoding = TRUE; |
274 | BOOL res = mImpl->decodeImpl(*this, *raw_imagep, decode_time, first_channel, max_channel_count); | 298 | res = mImpl->decodeImpl(*this, *raw_imagep, decode_time, first_channel, max_channel_count); |
299 | } | ||
300 | |||
275 | if (res) | 301 | if (res) |
276 | { | 302 | { |
277 | if (!mDecoding) | 303 | if (!mDecoding) |
@@ -283,9 +309,14 @@ BOOL LLImageJ2C::decodeChannels(LLImageRaw *raw_imagep, F32 decode_time, S32 fir | |||
283 | { | 309 | { |
284 | mDecoding = FALSE; | 310 | mDecoding = FALSE; |
285 | } | 311 | } |
286 | return TRUE; // done | ||
287 | } | 312 | } |
288 | return FALSE; | 313 | |
314 | if (!mLastError.empty()) | ||
315 | { | ||
316 | LLImage::setLastError(mLastError); | ||
317 | } | ||
318 | |||
319 | return res; | ||
289 | } | 320 | } |
290 | 321 | ||
291 | 322 | ||
@@ -298,7 +329,13 @@ BOOL LLImageJ2C::encode(const LLImageRaw *raw_imagep, F32 encode_time) | |||
298 | BOOL LLImageJ2C::encode(const LLImageRaw *raw_imagep, const char* comment_text, F32 encode_time) | 329 | BOOL LLImageJ2C::encode(const LLImageRaw *raw_imagep, const char* comment_text, F32 encode_time) |
299 | { | 330 | { |
300 | LLMemType mt1((LLMemType::EMemType)mMemType); | 331 | LLMemType mt1((LLMemType::EMemType)mMemType); |
301 | return mImpl->encodeImpl(*this, *raw_imagep, comment_text, encode_time, mReversible); | 332 | resetLastError(); |
333 | BOOL res = mImpl->encodeImpl(*this, *raw_imagep, comment_text, encode_time, mReversible); | ||
334 | if (!mLastError.empty()) | ||
335 | { | ||
336 | LLImage::setLastError(mLastError); | ||
337 | } | ||
338 | return res; | ||
302 | } | 339 | } |
303 | 340 | ||
304 | //static | 341 | //static |
@@ -376,6 +413,8 @@ void LLImageJ2C::setReversible(const BOOL reversible) | |||
376 | 413 | ||
377 | BOOL LLImageJ2C::loadAndValidate(const std::string &filename) | 414 | BOOL LLImageJ2C::loadAndValidate(const std::string &filename) |
378 | { | 415 | { |
416 | BOOL res = TRUE; | ||
417 | |||
379 | resetLastError(); | 418 | resetLastError(); |
380 | 419 | ||
381 | S32 file_size = 0; | 420 | S32 file_size = 0; |
@@ -383,27 +422,38 @@ BOOL LLImageJ2C::loadAndValidate(const std::string &filename) | |||
383 | if (!apr_file) | 422 | if (!apr_file) |
384 | { | 423 | { |
385 | setLastError("Unable to open file for reading", filename); | 424 | setLastError("Unable to open file for reading", filename); |
386 | return FALSE; | 425 | res = FALSE; |
387 | } | 426 | } |
388 | if (file_size == 0) | 427 | else if (file_size == 0) |
389 | { | 428 | { |
390 | setLastError("File is empty",filename); | 429 | setLastError("File is empty",filename); |
391 | apr_file_close(apr_file); | 430 | apr_file_close(apr_file); |
392 | return FALSE; | 431 | res = FALSE; |
393 | } | 432 | } |
394 | 433 | else | |
395 | U8 *data = new U8[file_size]; | ||
396 | apr_size_t bytes_read = file_size; | ||
397 | apr_status_t s = apr_file_read(apr_file, data, &bytes_read); // modifies bytes_read | ||
398 | if (s != APR_SUCCESS || (S32)bytes_read != file_size) | ||
399 | { | 434 | { |
400 | delete[] data; | 435 | U8 *data = new U8[file_size]; |
401 | setLastError("Unable to read entire file"); | 436 | apr_size_t bytes_read = file_size; |
402 | return FALSE; | 437 | apr_status_t s = apr_file_read(apr_file, data, &bytes_read); // modifies bytes_read |
438 | apr_file_close(apr_file); | ||
439 | if (s != APR_SUCCESS || (S32)bytes_read != file_size) | ||
440 | { | ||
441 | delete[] data; | ||
442 | setLastError("Unable to read entire file"); | ||
443 | res = FALSE; | ||
444 | } | ||
445 | else | ||
446 | { | ||
447 | res = validate(data, file_size); | ||
448 | } | ||
403 | } | 449 | } |
404 | apr_file_close(apr_file); | ||
405 | 450 | ||
406 | return validate(data, file_size); | 451 | if (!mLastError.empty()) |
452 | { | ||
453 | LLImage::setLastError(mLastError); | ||
454 | } | ||
455 | |||
456 | return res; | ||
407 | } | 457 | } |
408 | 458 | ||
409 | 459 | ||
@@ -411,21 +461,30 @@ BOOL LLImageJ2C::validate(U8 *data, U32 file_size) | |||
411 | { | 461 | { |
412 | LLMemType mt1((LLMemType::EMemType)mMemType); | 462 | LLMemType mt1((LLMemType::EMemType)mMemType); |
413 | 463 | ||
464 | resetLastError(); | ||
465 | |||
414 | setData(data, file_size); | 466 | setData(data, file_size); |
467 | |||
415 | BOOL res = updateData(); | 468 | BOOL res = updateData(); |
416 | if ( !res ) | 469 | if ( res ) |
417 | { | 470 | { |
418 | return FALSE; | 471 | // Check to make sure that this instance has been initialized with data |
472 | if (!getData() || (0 == getDataSize())) | ||
473 | { | ||
474 | setLastError("LLImageJ2C uninitialized"); | ||
475 | res = FALSE; | ||
476 | } | ||
477 | else | ||
478 | { | ||
479 | res = mImpl->getMetadata(*this); | ||
480 | } | ||
419 | } | 481 | } |
420 | 482 | ||
421 | // Check to make sure that this instance has been initialized with data | 483 | if (!mLastError.empty()) |
422 | if (!getData() || (0 == getDataSize())) | ||
423 | { | 484 | { |
424 | setLastError("LLImageJ2C uninitialized"); | 485 | LLImage::setLastError(mLastError); |
425 | return FALSE; | ||
426 | } | 486 | } |
427 | 487 | return res; | |
428 | return mImpl->getMetadata(*this); | ||
429 | } | 488 | } |
430 | 489 | ||
431 | void LLImageJ2C::decodeFailed() | 490 | void LLImageJ2C::decodeFailed() |
diff --git a/linden/indra/llimage/llimagej2c.h b/linden/indra/llimage/llimagej2c.h index 2b4a3ec..ad514eb 100644 --- a/linden/indra/llimage/llimagej2c.h +++ b/linden/indra/llimage/llimagej2c.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -54,6 +54,10 @@ public: | |||
54 | /*virtual*/ S32 calcDataSize(S32 discard_level = 0); | 54 | /*virtual*/ S32 calcDataSize(S32 discard_level = 0); |
55 | /*virtual*/ S32 calcDiscardLevelBytes(S32 bytes); | 55 | /*virtual*/ S32 calcDiscardLevelBytes(S32 bytes); |
56 | /*virtual*/ S8 getRawDiscardLevel(); | 56 | /*virtual*/ S8 getRawDiscardLevel(); |
57 | // Override these so that we don't try to set a global variable from a DLL | ||
58 | /*virtual*/ void resetLastError(); | ||
59 | /*virtual*/ void setLastError(const std::string& message, const std::string& filename = std::string()); | ||
60 | |||
57 | 61 | ||
58 | // Encode with comment text | 62 | // Encode with comment text |
59 | BOOL encode(const LLImageRaw *raw_imagep, const char* comment_text, F32 encode_time=0.0); | 63 | BOOL encode(const LLImageRaw *raw_imagep, const char* comment_text, F32 encode_time=0.0); |
@@ -86,6 +90,7 @@ protected: | |||
86 | F32 mRate; | 90 | F32 mRate; |
87 | BOOL mReversible; | 91 | BOOL mReversible; |
88 | LLImageJ2CImpl *mImpl; | 92 | LLImageJ2CImpl *mImpl; |
93 | std::string mLastError; | ||
89 | }; | 94 | }; |
90 | 95 | ||
91 | // Derive from this class to implement JPEG2000 decoding | 96 | // Derive from this class to implement JPEG2000 decoding |
diff --git a/linden/indra/llimage/llimagejpeg.cpp b/linden/indra/llimage/llimagejpeg.cpp index 68529b6..afb3368 100644 --- a/linden/indra/llimage/llimagejpeg.cpp +++ b/linden/indra/llimage/llimagejpeg.cpp | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2002&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2002-2008, Linden Research, Inc. | 6 | * Copyright (c) 2002-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -465,7 +465,8 @@ void LLImageJPEG::errorOutputMessage( j_common_ptr cinfo ) | |||
465 | char buffer[JMSG_LENGTH_MAX]; /* Flawfinder: ignore */ | 465 | char buffer[JMSG_LENGTH_MAX]; /* Flawfinder: ignore */ |
466 | (*cinfo->err->format_message) (cinfo, buffer); | 466 | (*cinfo->err->format_message) (cinfo, buffer); |
467 | 467 | ||
468 | ((LLImageJPEG*) cinfo->client_data)->setLastError( buffer ); | 468 | std::string error = buffer ; |
469 | LLImage::setLastError(error); | ||
469 | 470 | ||
470 | BOOL is_decode = (cinfo->is_decompressor != 0); | 471 | BOOL is_decode = (cinfo->is_decompressor != 0); |
471 | llwarns << "LLImageJPEG " << (is_decode ? "decode " : "encode ") << " failed: " << buffer << llendl; | 472 | llwarns << "LLImageJPEG " << (is_decode ? "decode " : "encode ") << " failed: " << buffer << llendl; |
diff --git a/linden/indra/llimage/llimagejpeg.h b/linden/indra/llimage/llimagejpeg.h index 79dc1a3..0914fd7 100644 --- a/linden/indra/llimage/llimagejpeg.h +++ b/linden/indra/llimage/llimagejpeg.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2002-2008, Linden Research, Inc. | 7 | * Copyright (c) 2002-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagepng.cpp b/linden/indra/llimage/llimagepng.cpp index 5108066..f2d6376 100644 --- a/linden/indra/llimage/llimagepng.cpp +++ b/linden/indra/llimage/llimagepng.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2007&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2007&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2007-2008, Linden Research, Inc. | 7 | * Copyright (c) 2007-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagepng.h b/linden/indra/llimage/llimagepng.h index 9d45fb0..0387982 100644 --- a/linden/indra/llimage/llimagepng.h +++ b/linden/indra/llimage/llimagepng.h | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2007&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2007&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2007-2008, Linden Research, Inc. | 6 | * Copyright (c) 2007-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagetga.cpp b/linden/indra/llimage/llimagetga.cpp index 21d0fd1..c72a1cd 100644 --- a/linden/indra/llimage/llimagetga.cpp +++ b/linden/indra/llimage/llimagetga.cpp | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2001-2008, Linden Research, Inc. | 6 | * Copyright (c) 2001-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimagetga.h b/linden/indra/llimage/llimagetga.h index 385e086..b522930 100644 --- a/linden/indra/llimage/llimagetga.h +++ b/linden/indra/llimage/llimagetga.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llimageworker.cpp b/linden/indra/llimage/llimageworker.cpp index dc6f2e4..d570ad1 100644 --- a/linden/indra/llimage/llimageworker.cpp +++ b/linden/indra/llimage/llimageworker.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -41,13 +41,13 @@ LLWorkerThread* LLImageWorker::sWorkerThread = NULL; | |||
41 | S32 LLImageWorker::sCount = 0; | 41 | S32 LLImageWorker::sCount = 0; |
42 | 42 | ||
43 | //static | 43 | //static |
44 | void LLImageWorker::initClass(LLWorkerThread* workerthread) | 44 | void LLImageWorker::initImageWorker(LLWorkerThread* workerthread) |
45 | { | 45 | { |
46 | sWorkerThread = workerthread; | 46 | sWorkerThread = workerthread; |
47 | } | 47 | } |
48 | 48 | ||
49 | //static | 49 | //static |
50 | void LLImageWorker::cleanupClass() | 50 | void LLImageWorker::cleanupImageWorker() |
51 | { | 51 | { |
52 | } | 52 | } |
53 | 53 | ||
diff --git a/linden/indra/llimage/llimageworker.h b/linden/indra/llimage/llimageworker.h index bf6c3f2..a133f77 100644 --- a/linden/indra/llimage/llimageworker.h +++ b/linden/indra/llimage/llimageworker.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2000&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2000&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2000-2008, Linden Research, Inc. | 7 | * Copyright (c) 2000-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -38,8 +38,10 @@ | |||
38 | class LLImageWorker : public LLWorkerClass | 38 | class LLImageWorker : public LLWorkerClass |
39 | { | 39 | { |
40 | public: | 40 | public: |
41 | static void initClass(LLWorkerThread* workerthread); | 41 | static void initImageWorker(LLWorkerThread* workerthread); |
42 | static void cleanupClass(); | 42 | static void cleanupImageWorker(); |
43 | |||
44 | public: | ||
43 | static LLWorkerThread* getWorkerThread() { return sWorkerThread; } | 45 | static LLWorkerThread* getWorkerThread() { return sWorkerThread; } |
44 | 46 | ||
45 | // LLWorkerThread | 47 | // LLWorkerThread |
diff --git a/linden/indra/llimage/llmapimagetype.h b/linden/indra/llimage/llmapimagetype.h index 156700f..0e17aaa 100644 --- a/linden/indra/llimage/llmapimagetype.h +++ b/linden/indra/llimage/llmapimagetype.h | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2003&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2003&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2003-2008, Linden Research, Inc. | 6 | * Copyright (c) 2003-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llpngwrapper.cpp b/linden/indra/llimage/llpngwrapper.cpp index 35b4ec3..2b0f7b6 100644 --- a/linden/indra/llimage/llpngwrapper.cpp +++ b/linden/indra/llimage/llpngwrapper.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2007&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2007&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2007-2008, Linden Research, Inc. | 7 | * Copyright (c) 2007-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimage/llpngwrapper.h b/linden/indra/llimage/llpngwrapper.h index bd603c3..87ddb9e 100644 --- a/linden/indra/llimage/llpngwrapper.h +++ b/linden/indra/llimage/llpngwrapper.h | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * $LicenseInfo:firstyear=2007&license=viewergpl$ | 4 | * $LicenseInfo:firstyear=2007&license=viewergpl$ |
5 | * | 5 | * |
6 | * Copyright (c) 2007-2008, Linden Research, Inc. | 6 | * Copyright (c) 2007-2009, Linden Research, Inc. |
7 | * | 7 | * |
8 | * Second Life Viewer Source Code | 8 | * Second Life Viewer Source Code |
9 | * The source code in this file ("Source Code") is provided by Linden Lab | 9 | * The source code in this file ("Source Code") is provided by Linden Lab |
diff --git a/linden/indra/llimagej2coj/CMakeLists.txt b/linden/indra/llimagej2coj/CMakeLists.txt index ed3ff3c..97d22cf 100644 --- a/linden/indra/llimagej2coj/CMakeLists.txt +++ b/linden/indra/llimagej2coj/CMakeLists.txt | |||
@@ -29,3 +29,7 @@ set_source_files_properties(${llimagej2coj_HEADER_FILES} | |||
29 | list(APPEND llimagej2coj_SOURCE_FILES ${llimagej2coj_HEADER_FILES}) | 29 | list(APPEND llimagej2coj_SOURCE_FILES ${llimagej2coj_HEADER_FILES}) |
30 | 30 | ||
31 | add_library (llimagej2coj ${llimagej2coj_SOURCE_FILES}) | 31 | add_library (llimagej2coj ${llimagej2coj_SOURCE_FILES}) |
32 | target_link_libraries( | ||
33 | llimagej2coj | ||
34 | ${OPENJPEG_LIBRARIES} | ||
35 | ) | ||
diff --git a/linden/indra/llimagej2coj/llimagej2coj.cpp b/linden/indra/llimagej2coj/llimagej2coj.cpp index a0c61d8..ef498db 100644 --- a/linden/indra/llimagej2coj/llimagej2coj.cpp +++ b/linden/indra/llimagej2coj/llimagej2coj.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2006&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2006&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2006-2008, Linden Research, Inc. | 7 | * Copyright (c) 2006-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -183,6 +183,17 @@ BOOL LLImageJ2COJ::decodeImpl(LLImageJ2C &base, LLImageRaw &raw_image, F32 decod | |||
183 | return TRUE; | 183 | return TRUE; |
184 | } | 184 | } |
185 | 185 | ||
186 | if(image->numcomps <= first_channel) | ||
187 | { | ||
188 | llwarns << "trying to decode more channels than are present in image: numcomps: " << image->numcomps << " first_channel: " << first_channel << llendl; | ||
189 | if (image) | ||
190 | { | ||
191 | opj_image_destroy(image); | ||
192 | } | ||
193 | |||
194 | return TRUE; | ||
195 | } | ||
196 | |||
186 | // Copy image data into our raw image format (instead of the separate channel format | 197 | // Copy image data into our raw image format (instead of the separate channel format |
187 | 198 | ||
188 | S32 img_components = image->numcomps; | 199 | S32 img_components = image->numcomps; |
diff --git a/linden/indra/llimagej2coj/llimagej2coj.h b/linden/indra/llimagej2coj/llimagej2coj.h index df061ea..05504d6 100644 --- a/linden/indra/llimagej2coj/llimagej2coj.h +++ b/linden/indra/llimagej2coj/llimagej2coj.h | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2006&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2006&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2006-2008, Linden Research, Inc. | 7 | * Copyright (c) 2006-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |