summaryrefslogtreecommitdiffstats
path: root/xrdp/xrdp_bitmap.c
diff options
context:
space:
mode:
authorjsorg71 <jsorg71>2008-08-25 07:55:41 +0000
committerjsorg71 <jsorg71>2008-08-25 07:55:41 +0000
commita7df159ce9ccdb98cea6597a888392f62035c7d1 (patch)
treecd3bf671ff16876bb3cc4ee66ee17053ca7d19aa /xrdp/xrdp_bitmap.c
parentab57eb73fc2da494cd68a7d6746312d45adc636f (diff)
downloadxrdp-proprietary-a7df159ce9ccdb98cea6597a888392f62035c7d1.tar.gz
xrdp-proprietary-a7df159ce9ccdb98cea6597a888392f62035c7d1.zip
log errors and minor fix
Diffstat (limited to 'xrdp/xrdp_bitmap.c')
-rw-r--r--xrdp/xrdp_bitmap.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/xrdp/xrdp_bitmap.c b/xrdp/xrdp_bitmap.c
index 21a83b5e..b3d7162b 100644
--- a/xrdp/xrdp_bitmap.c
+++ b/xrdp/xrdp_bitmap.c
@@ -298,15 +298,20 @@ xrdp_bitmap_get_index(struct xrdp_bitmap* self, int* palette, int color)
}
/*****************************************************************************/
+/* returns error */
int APP_CC
xrdp_bitmap_resize(struct xrdp_bitmap* self, int width, int height)
{
int Bpp;
- if (width == self->width && height == self->height)
+ if ((width == self->width) && (height == self->height))
{
return 0;
}
+ if (self->do_not_free_data)
+ {
+ return 1;
+ }
self->width = width;
self->height = height;
Bpp = 4;
@@ -316,11 +321,8 @@ xrdp_bitmap_resize(struct xrdp_bitmap* self, int width, int height)
case 15: Bpp = 2; break;
case 16: Bpp = 2; break;
}
- if (self->data != 0)
- {
- g_free(self->data);
- self->data = (char*)g_malloc(width * height * Bpp, 1);
- }
+ g_free(self->data);
+ self->data = (char*)g_malloc(width * height * Bpp, 0);
self->line_size = width * Bpp;
return 0;
}
@@ -344,6 +346,12 @@ xrdp_bitmap_load(struct xrdp_bitmap* self, const char* filename, int* palette)
struct xrdp_bmp_header header;
struct stream* s;
+ if (!g_file_exist(filename))
+ {
+ g_writeln("xrdp_bitmap_load: error bitmap file [%s] does not exist",
+ filename);
+ return 1;
+ }
s = 0;
fd = g_file_open(filename);
if (fd != -1)