diff options
author | Jacek Antonelli | 2008-08-15 23:45:59 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:45:59 -0500 |
commit | 6e91a9cc3d5a610198cf526a76e2ab642f10ecd7 (patch) | |
tree | b023869f9daa7f61ea3ab27112d37524bdd88de4 /linden/indra/llimage | |
parent | Second Life viewer sources 1.20.12 (diff) | |
download | meta-impy-6e91a9cc3d5a610198cf526a76e2ab642f10ecd7.zip meta-impy-6e91a9cc3d5a610198cf526a76e2ab642f10ecd7.tar.gz meta-impy-6e91a9cc3d5a610198cf526a76e2ab642f10ecd7.tar.bz2 meta-impy-6e91a9cc3d5a610198cf526a76e2ab642f10ecd7.tar.xz |
Second Life viewer sources 1.20.13
Diffstat (limited to 'linden/indra/llimage')
-rw-r--r-- | linden/indra/llimage/llimage.cpp | 17 | ||||
-rw-r--r-- | linden/indra/llimage/llimage.h | 2 | ||||
-rw-r--r-- | linden/indra/llimage/llimagebmp.cpp | 5 |
3 files changed, 16 insertions, 8 deletions
diff --git a/linden/indra/llimage/llimage.cpp b/linden/indra/llimage/llimage.cpp index 508be01..52a210f 100644 --- a/linden/indra/llimage/llimage.cpp +++ b/linden/indra/llimage/llimage.cpp | |||
@@ -147,7 +147,6 @@ U8* LLImageBase::allocateData(S32 size) | |||
147 | mData = new U8[size]; | 147 | mData = new U8[size]; |
148 | if (!mData) | 148 | if (!mData) |
149 | { | 149 | { |
150 | //llerrs << "allocate image data: " << size << llendl; | ||
151 | llwarns << "allocate image data: " << size << llendl; | 150 | llwarns << "allocate image data: " << size << llendl; |
152 | size = 0 ; | 151 | size = 0 ; |
153 | mWidth = mHeight = 0 ; | 152 | mWidth = mHeight = 0 ; |
@@ -245,8 +244,10 @@ LLImageRaw::LLImageRaw(U8 *data, U16 width, U16 height, S8 components) | |||
245 | : LLImageBase() | 244 | : LLImageBase() |
246 | { | 245 | { |
247 | mMemType = LLMemType::MTYPE_IMAGERAW; | 246 | mMemType = LLMemType::MTYPE_IMAGERAW; |
248 | allocateDataSize(width, height, components); | 247 | if(allocateDataSize(width, height, components)) |
249 | memcpy(getData(), data, width*height*components); | 248 | { |
249 | memcpy(getData(), data, width*height*components); | ||
250 | } | ||
250 | ++sRawImageCount; | 251 | ++sRawImageCount; |
251 | } | 252 | } |
252 | 253 | ||
@@ -797,7 +798,7 @@ void LLImageRaw::copyScaled( LLImageRaw* src ) | |||
797 | } | 798 | } |
798 | 799 | ||
799 | 800 | ||
800 | void LLImageRaw::scale( S32 new_width, S32 new_height, BOOL scale_image_data ) | 801 | BOOL LLImageRaw::scale( S32 new_width, S32 new_height, BOOL scale_image_data ) |
801 | { | 802 | { |
802 | LLMemType mt1((LLMemType::EMemType)mMemType); | 803 | LLMemType mt1((LLMemType::EMemType)mMemType); |
803 | llassert((1 == getComponents()) || (3 == getComponents()) || (4 == getComponents()) ); | 804 | llassert((1 == getComponents()) || (3 == getComponents()) || (4 == getComponents()) ); |
@@ -807,7 +808,7 @@ void LLImageRaw::scale( S32 new_width, S32 new_height, BOOL scale_image_data ) | |||
807 | 808 | ||
808 | if( (old_width == new_width) && (old_height == new_height) ) | 809 | if( (old_width == new_width) && (old_height == new_height) ) |
809 | { | 810 | { |
810 | return; // Nothing to do. | 811 | return TRUE; // Nothing to do. |
811 | } | 812 | } |
812 | 813 | ||
813 | // Reallocate the data buffer. | 814 | // Reallocate the data buffer. |
@@ -842,8 +843,10 @@ void LLImageRaw::scale( S32 new_width, S32 new_height, BOOL scale_image_data ) | |||
842 | U8* temp_buffer = new U8[ temp_data_size ]; | 843 | U8* temp_buffer = new U8[ temp_data_size ]; |
843 | if (!temp_buffer) | 844 | if (!temp_buffer) |
844 | { | 845 | { |
845 | llerrs << "Out of memory in LLImageRaw::scale: old (w, h, c) = (" << old_width << ", " << old_height << ", " << (S32)getComponents() << | 846 | llwarns << "Out of memory in LLImageRaw::scale: old (w, h, c) = (" << old_width << ", " << old_height << ", " << (S32)getComponents() << |
846 | ") ; new (w, h, c) = (" << new_width << ", " << new_height << ", " << (S32)getComponents() << ")" << llendl; | 847 | ") ; new (w, h, c) = (" << new_width << ", " << new_height << ", " << (S32)getComponents() << ")" << llendl; |
848 | |||
849 | return FALSE ; | ||
847 | } | 850 | } |
848 | memcpy(temp_buffer, getData(), temp_data_size); /* Flawfinder: ignore */ | 851 | memcpy(temp_buffer, getData(), temp_data_size); /* Flawfinder: ignore */ |
849 | 852 | ||
@@ -871,6 +874,8 @@ void LLImageRaw::scale( S32 new_width, S32 new_height, BOOL scale_image_data ) | |||
871 | // Clean up | 874 | // Clean up |
872 | delete[] temp_buffer; | 875 | delete[] temp_buffer; |
873 | } | 876 | } |
877 | |||
878 | return TRUE ; | ||
874 | } | 879 | } |
875 | 880 | ||
876 | void LLImageRaw::copyLineScaled( U8* in, U8* out, S32 in_pixel_len, S32 out_pixel_len, S32 in_pixel_step, S32 out_pixel_step ) | 881 | void LLImageRaw::copyLineScaled( U8* in, U8* out, S32 in_pixel_len, S32 out_pixel_len, S32 in_pixel_step, S32 out_pixel_step ) |
diff --git a/linden/indra/llimage/llimage.h b/linden/indra/llimage/llimage.h index 0393d13..0d97595 100644 --- a/linden/indra/llimage/llimage.h +++ b/linden/indra/llimage/llimage.h | |||
@@ -176,7 +176,7 @@ public: | |||
176 | void expandToPowerOfTwo(S32 max_dim = MAX_IMAGE_SIZE, BOOL scale_image = TRUE); | 176 | void expandToPowerOfTwo(S32 max_dim = MAX_IMAGE_SIZE, BOOL scale_image = TRUE); |
177 | void contractToPowerOfTwo(S32 max_dim = MAX_IMAGE_SIZE, BOOL scale_image = TRUE); | 177 | void contractToPowerOfTwo(S32 max_dim = MAX_IMAGE_SIZE, BOOL scale_image = TRUE); |
178 | void biasedScaleToPowerOfTwo(S32 max_dim = MAX_IMAGE_SIZE); | 178 | void biasedScaleToPowerOfTwo(S32 max_dim = MAX_IMAGE_SIZE); |
179 | void scale( S32 new_width, S32 new_height, BOOL scale_image = TRUE ); | 179 | BOOL scale( S32 new_width, S32 new_height, BOOL scale_image = TRUE ); |
180 | 180 | ||
181 | // Fill the buffer with a constant color | 181 | // Fill the buffer with a constant color |
182 | void fill( const LLColor4U& color ); | 182 | void fill( const LLColor4U& color ); |
diff --git a/linden/indra/llimage/llimagebmp.cpp b/linden/indra/llimage/llimagebmp.cpp index 5d74c3e..8764dff 100644 --- a/linden/indra/llimage/llimagebmp.cpp +++ b/linden/indra/llimage/llimagebmp.cpp | |||
@@ -552,7 +552,10 @@ BOOL LLImageBMP::encode(const LLImageRaw* raw_image, F32 encode_time) | |||
552 | int file_bytes = line_bytes*getHeight() + header_bytes; | 552 | int file_bytes = line_bytes*getHeight() + header_bytes; |
553 | 553 | ||
554 | // Allocate the new buffer for the data. | 554 | // Allocate the new buffer for the data. |
555 | allocateData(file_bytes); | 555 | if(!allocateData(file_bytes)) //memory allocation failed |
556 | { | ||
557 | return FALSE ; | ||
558 | } | ||
556 | 559 | ||
557 | magic[0] = 'B'; magic[1] = 'M'; | 560 | magic[0] = 'B'; magic[1] = 'M'; |
558 | magic[2] = (U8) file_bytes; | 561 | magic[2] = (U8) file_bytes; |