summaryrefslogtreecommitdiffstats
path: root/xrdp
diff options
context:
space:
mode:
Diffstat (limited to 'xrdp')
-rw-r--r--xrdp/constants.h13
-rw-r--r--xrdp/funcs.c39
-rw-r--r--xrdp/parse.h2
-rw-r--r--xrdp/xrdp.c4
-rw-r--r--xrdp/xrdp.h30
-rw-r--r--xrdp/xrdp_bitmap.c72
-rw-r--r--xrdp/xrdp_cache.c63
-rw-r--r--xrdp/xrdp_orders.c1
-rw-r--r--xrdp/xrdp_painter.c39
-rw-r--r--xrdp/xrdp_types.h9
-rw-r--r--xrdp/xrdp_wm.c109
11 files changed, 216 insertions, 165 deletions
diff --git a/xrdp/constants.h b/xrdp/constants.h
index ec531273..8fe8b2b7 100644
--- a/xrdp/constants.h
+++ b/xrdp/constants.h
@@ -397,3 +397,16 @@
#define RDP_ORDER_FONTCACHE 3
#define RDP_ORDER_RAW_BMPCACHE2 4
#define RDP_ORDER_BMPCACHE2 5
+
+/* drawable types */
+#define WND_TYPE_BITMAP 0
+#define WND_TYPE_WND 1
+#define WND_TYPE_SCREEN 2
+#define WND_TYPE_BUTTON 3
+#define WND_TYPE_IMAGE 4
+#define WND_TYPE_EDIT 5
+#define WND_TYPE_LABEL 6
+
+/* button states */
+#define BUTTON_STATE_UP 0
+#define BUTTON_STATE_DOWN 1
diff --git a/xrdp/funcs.c b/xrdp/funcs.c
index 4dcc7c06..dfa4abcd 100644
--- a/xrdp/funcs.c
+++ b/xrdp/funcs.c
@@ -62,15 +62,6 @@ int rect_intersect(struct xrdp_rect* in1, struct xrdp_rect* in2,
}
/*****************************************************************************/
-int color15(int r, int g, int b)
-{
- r = r >> 3;
- g = g >> 3;
- b = b >> 3;
- return (r << 10) | (g << 5) | b;
-}
-
-/*****************************************************************************/
int color16(int r, int g, int b)
{
r = r >> 3;
@@ -84,3 +75,33 @@ int color24(int r, int g, int b)
{
return r | (g << 8) | (b << 16);
}
+
+/*****************************************************************************/
+/* adjust the bounds to fit in the bitmap */
+/* return false if there is nothing to draw else return true */
+int check_bounds(struct xrdp_bitmap* b, int* x, int* y, int* cx, int* cy)
+{
+ if (*x >= b->width)
+ return 0;
+ if (*y >= b->height)
+ return 0;
+ if (*x < 0)
+ {
+ *cx += *x;
+ *x = 0;
+ }
+ if (*y < 0)
+ {
+ *cy += *y;
+ *y = 0;
+ }
+ if (*cx <= 0)
+ return 0;
+ if (*cy <= 0)
+ return 0;
+ if (*x + *cx > b->width)
+ *cx = b->width - *x;
+ if (*y + *cy > b->height)
+ *cy = b->height - *y;
+ return 1;
+}
diff --git a/xrdp/parse.h b/xrdp/parse.h
index 057ef002..477f35ab 100644
--- a/xrdp/parse.h
+++ b/xrdp/parse.h
@@ -56,7 +56,7 @@ struct stream
#define make_stream(s) \
{ \
s = (struct stream*)g_malloc(sizeof(struct stream), 1); \
-} \
+}
/******************************************************************************/
#define init_stream(s, v) \
diff --git a/xrdp/xrdp.c b/xrdp/xrdp.c
index 47434b35..5d10a2e9 100644
--- a/xrdp/xrdp.c
+++ b/xrdp/xrdp.c
@@ -29,9 +29,9 @@ static struct xrdp_listen* g_listen = 0;
void* xrdp_listen_run(void* in_val)
{
- DEBUG(("listener started\n"))
+ DEBUG(("listener started\n\r"));
xrdp_listen_main_loop(g_listen);
- DEBUG(("listener done\n"))
+ DEBUG(("listener done\n\r"));
return 0;
}
diff --git a/xrdp/xrdp.h b/xrdp/xrdp.h
index bc4f60bf..b3a63c11 100644
--- a/xrdp/xrdp.h
+++ b/xrdp/xrdp.h
@@ -43,36 +43,28 @@
#define DEBUG(args)
#endif
/* other macros */
-#undef MIN
#define MIN(x1, x2) ((x1) < (x2) ? (x1) : (x2))
-#undef MAX
#define MAX(x1, x2) ((x1) > (x2) ? (x1) : (x2))
-#undef HIWORD
#define HIWORD(in) (((in) & 0xffff0000) >> 16)
-#undef LOWORD
#define LOWORD(in) ((in) & 0x0000ffff)
-#undef MAKELONG
#define MAKELONG(hi, lo) ((((hi) & 0xffff) << 16) | ((lo) & 0xffff))
-#undef MAKERECT
#define MAKERECT(r, x, y, cx, cy) \
{ (r).left = x; (r).top = y; (r).right = (x) + (cx); (r).bottom = (y) + (cy); }
-#undef ISRECTEMPTY
#define ISRECTEMPTY(r) (((r).right <= (r).left) || ((r).bottom <= (r).top))
-#undef RECTOFFSET
#define RECTOFFSET(r, dx, dy) \
{ (r).left += dx; (r).top += dy; (r).right += dx; (r).bottom += dy; }
-#undef GETPIXEL8
#define GETPIXEL8(d, x, y, w) (*(((unsigned char*)d) + ((y) * (w) + (x))))
-#undef GETPIXEL16
#define GETPIXEL16(d, x, y, w) (*(((unsigned short*)d) + ((y) * (w) + (x))))
-#undef GETPIXEL32
#define GETPIXEL32(d, x, y, w) (*(((unsigned long*)d) + ((y) * (w) + (x))))
-#undef SETPIXEL8
-#define SETPIXEL8(d, x, y, w, v) (*(((unsigned char*)d) + ((y) * (w) + (x))) = (v))
-#undef SETPIXEL16
-#define SETPIXEL16(d, x, y, w, v) (*(((unsigned short*)d) + ((y) * (w) + (x))) = (v))
-#undef SETPIXEL32
-#define SETPIXEL32(d, x, y, w, v) (*(((unsigned long*)d) + ((y) * (w) + (x))) = (v))
+#define SETPIXEL8(d, x, y, w, v) \
+(*(((unsigned char*)d) + ((y) * (w) + (x))) = (v))
+#define SETPIXEL16(d, x, y, w, v) \
+(*(((unsigned short*)d) + ((y) * (w) + (x))) = (v))
+#define SETPIXEL32(d, x, y, w, v) \
+(*(((unsigned long*)d) + ((y) * (w) + (x))) = (v))
+#define COLOR15(r, g, b) ((((r) >> 3) << 10) | (((g) >> 3) << 5) | ((b) >> 3))
+#define COLOR16(r, g, b) ((((r) >> 3) << 11) | (((g) >> 2) << 5) | ((b) >> 3))
+#define COLOR24(r, g, b) ((r) | ((g) << 8) | ((b) << 16))
/* font macros */
#define FONT_DATASIZE(f) ((((f)->height * (((f)->width + 7) / 8)) + 3) & ~3);
@@ -322,6 +314,4 @@ int xrdp_font_item_compare(struct xrdp_font_item* font1,
int rect_contains_pt(struct xrdp_rect* in, int x, int y);
int rect_intersect(struct xrdp_rect* in1, struct xrdp_rect* in2,
struct xrdp_rect* out);
-int color15(int r, int g, int b);
-int color16(int r, int g, int b);
-int color24(int r, int g, int b);
+int check_bounds(struct xrdp_bitmap* b, int* x, int* y, int* cx, int* cy);
diff --git a/xrdp/xrdp_bitmap.c b/xrdp/xrdp_bitmap.c
index 597cd218..63547dca 100644
--- a/xrdp/xrdp_bitmap.c
+++ b/xrdp/xrdp_bitmap.c
@@ -1,4 +1,3 @@
-
/*
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -72,13 +71,15 @@ void xrdp_bitmap_delete(struct xrdp_bitmap* self)
}
/*****************************************************************************/
+/* if focused is true focus this window else unfocus it */
+/* returns error */
int xrdp_bitmap_set_focus(struct xrdp_bitmap* self, int focused)
{
struct xrdp_painter* painter;
if (self == 0)
return 0;
- if (self->type != 1)
+ if (self->type != WND_TYPE_WND) /* 1 */
return 0;
self->focused = focused;
painter = xrdp_painter_create(self->wm);
@@ -210,15 +211,15 @@ int xrdp_bitmap_load(struct xrdp_bitmap* self, char* filename, int* palette)
if (self->bpp == 8)
color = xrdp_bitmap_get_index(self, palette, color);
else if (self->bpp == 15)
- color = color15((color & 0xff0000) >> 16,
+ color = COLOR15((color & 0xff0000) >> 16,
(color & 0x00ff00) >> 8,
(color & 0x0000ff) >> 0);
else if (self->bpp == 16)
- color = color16((color & 0xff0000) >> 16,
+ color = COLOR16((color & 0xff0000) >> 16,
(color & 0x00ff00) >> 8,
(color & 0x0000ff) >> 0);
else if (self->bpp == 24)
- color = color24((color & 0xff0000) >> 16,
+ color = COLOR24((color & 0xff0000) >> 16,
(color & 0x00ff00) >> 8,
(color & 0x0000ff) >> 0);
xrdp_bitmap_set_pixel(self, j, i, color);
@@ -270,37 +271,55 @@ int xrdp_bitmap_set_pixel(struct xrdp_bitmap* self, int x, int y, int pixel)
}
/*****************************************************************************/
+/* copy part of self at x, y to 0, o in dest */
+/* returns error */
int xrdp_bitmap_copy_box(struct xrdp_bitmap* self, struct xrdp_bitmap* dest,
int x, int y, int cx, int cy)
{
int i;
int j;
+ int destx;
+ int desty;
if (self == 0)
- return 0;
+ return 1;
if (dest == 0)
- return 0;
+ return 1;
+ if (self->type != WND_TYPE_BITMAP && self->type != WND_TYPE_IMAGE)
+ return 1;
+ if (dest->type != WND_TYPE_BITMAP && dest->type != WND_TYPE_IMAGE)
+ return 1;
if (self->bpp != dest->bpp)
- return 0;
-
+ return 1;
+ destx = 0;
+ desty = 0;
+ if (!check_bounds(self, &x, &y, &cx, &cy))
+ return 1;
+ if (!check_bounds(dest, &destx, &desty, &cx, &cy))
+ return 1;
if (self->bpp == 24)
{
for (i = 0; i < cy; i++)
for (j = 0; j < cx; j++)
- SETPIXEL32(dest->data, j, i, dest->width,
+ SETPIXEL32(dest->data, j + destx, i + desty, dest->width,
GETPIXEL32(self->data, j + x, i + y, self->width));
}
- else
+ else if (self->bpp == 15 || self->bpp == 16)
{
for (i = 0; i < cy; i++)
- {
for (j = 0; j < cx; j++)
- {
- xrdp_bitmap_set_pixel(dest, j, i,
- xrdp_bitmap_get_pixel(self, j + x, i + y));
- }
- }
+ SETPIXEL16(dest->data, j + destx, i + desty, dest->width,
+ GETPIXEL16(self->data, j + x, i + y, self->width));
}
+ else if (self->bpp == 8)
+ {
+ for (i = 0; i < cy; i++)
+ for (j = 0; j < cx; j++)
+ SETPIXEL8(dest->data, j + destx, i + desty, dest->width,
+ GETPIXEL8(self->data, j + x, i + y, self->width));
+ }
+ else
+ return 1;
return 0;
}
@@ -325,6 +344,7 @@ int xrdp_bitmap_compare(struct xrdp_bitmap* self, struct xrdp_bitmap* b)
/*****************************************************************************/
/* nil for rect means the whole thing */
+/* returns error */
int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
{
int i;
@@ -337,7 +357,7 @@ int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
if (self == 0) /* if no bitmap */
return 0;
- if (self->type == 0) /* if bitmap, leave */
+ if (self->type == WND_TYPE_BITMAP) /* if 0, bitmap, leave */
return 0;
painter = xrdp_painter_create(self->wm);
painter->rop = 0xcc; /* copy */
@@ -354,7 +374,7 @@ int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
painter->use_clip = 1;
}
xrdp_painter_begin_update(painter);
- if (self->type == 1) /* normal window */
+ if (self->type == WND_TYPE_WND) /* 1 */
{
/* draw grey background */
painter->fg_color = self->bg_color;
@@ -397,14 +417,14 @@ int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
}
xrdp_painter_draw_text(painter, self, 4, 4, self->title);
}
- else if (self->type == 2) /* screen */
+ else if (self->type == WND_TYPE_SCREEN) /* 2 */
{
painter->fg_color = self->bg_color;
xrdp_painter_fill_rect(painter, self, 0, 0, self->width, self->height);
}
- else if (self->type == 3) /* button */
+ else if (self->type == WND_TYPE_BUTTON) /* 3 */
{
- if (self->state == 0) /* button up */
+ if (self->state == BUTTON_STATE_UP) /* 0 */
{
/* gray box */
painter->fg_color = self->wm->grey;
@@ -435,7 +455,7 @@ int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
xrdp_painter_draw_text(painter, self, self->width / 2 - w / 2,
self->height / 2 - h / 2, self->title);
}
- else if (self->state == 1) /* button down */
+ else if (self->state == BUTTON_STATE_DOWN) /* 1 */
{
/* gray box */
painter->fg_color = self->wm->grey;
@@ -473,12 +493,12 @@ int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
(self->height / 2 - h / 2) + 1, self->title);
}
}
- else if (self->type == 4) /* image */
+ else if (self->type == WND_TYPE_IMAGE) /* 4 */
{
xrdp_painter_draw_bitmap(painter, self, self, 0, 0, self->width,
self->height);
}
- else if (self->type == 5) /* edit */
+ else if (self->type == WND_TYPE_EDIT) /* 5 */
{
/* draw gray box */
painter->fg_color = self->wm->grey;
@@ -506,7 +526,7 @@ int xrdp_bitmap_invalidate(struct xrdp_bitmap* self, struct xrdp_rect* rect)
painter->fg_color = self->wm->black;
xrdp_painter_fill_rect(painter, self, 1, 1, self->width - 2, 1);
}
- else if (self->type == 6) /* label */
+ else if (self->type == WND_TYPE_LABEL) /* 6 */
{
painter->font->color = self->wm->black;
xrdp_painter_draw_text(painter, self, 0, 0, self->title);
diff --git a/xrdp/xrdp_cache.c b/xrdp/xrdp_cache.c
index 20445b63..f9df7ad5 100644
--- a/xrdp/xrdp_cache.c
+++ b/xrdp/xrdp_cache.c
@@ -1,4 +1,3 @@
-
/*
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -60,11 +59,12 @@ int xrdp_cache_add_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap)
{
int i;
int j;
- int min_use;
+ int oldest;
int cache_id;
int cache_idx;
struct xrdp_bitmap* b;
+ self->bitmap_stamp++;
/* look for match */
for (i = 0; i < 3; i++)
{
@@ -72,35 +72,35 @@ int xrdp_cache_add_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap)
{
if (xrdp_bitmap_compare(self->bitmap_items[i][j].bitmap, bitmap))
{
- self->bitmap_items[i][j].use_count++;
- DEBUG(("found bitmap at %d %d\n", i, j));
+ self->bitmap_items[i][j].stamp = self->bitmap_stamp;
+ DEBUG(("found bitmap at %d %d\n\r", i, j));
return MAKELONG(i, j);
}
}
}
- /* look for least used */
+ /* look for oldest */
cache_id = 0;
cache_idx = 0;
- min_use = 999999;
+ oldest = 0x7fffffff;
for (i = 0; i < 3; i++)
{
for (j = 0; j < 600; j++)
{
- if (self->bitmap_items[i][j].use_count < min_use)
+ if (self->bitmap_items[i][j].stamp < oldest)
{
- min_use = self->bitmap_items[i][j].use_count;
+ oldest = self->bitmap_items[i][j].stamp;
cache_id = i;
cache_idx = j;
}
}
}
- DEBUG(("adding bitmap at %d %d\n", cache_id, cache_idx));
+ DEBUG(("adding bitmap at %d %d\n\r", cache_id, cache_idx));
/* set, send bitmap and return */
xrdp_bitmap_delete(self->bitmap_items[cache_id][cache_idx].bitmap);
b = xrdp_bitmap_create(bitmap->width, bitmap->height, bitmap->bpp, 0);
xrdp_bitmap_copy_box(bitmap, b, 0, 0, bitmap->width, bitmap->height);
self->bitmap_items[cache_id][cache_idx].bitmap = b;
- self->bitmap_items[cache_id][cache_idx].use_count++;
+ self->bitmap_items[cache_id][cache_idx].stamp = self->bitmap_stamp;
xrdp_orders_send_raw_bitmap(self->orders, b, cache_id, cache_idx);
return MAKELONG(cache_id, cache_idx);
}
@@ -109,8 +109,8 @@ int xrdp_cache_add_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap)
int xrdp_cache_add_palette(struct xrdp_cache* self, int* palette)
{
int i;
- int min_use;
- int min_use_index;
+ int oldest;
+ int index;
if (self == 0)
return 0;
@@ -118,33 +118,33 @@ int xrdp_cache_add_palette(struct xrdp_cache* self, int* palette)
return 0;
if (self->wm->screen->bpp > 8)
return 0;
+ self->palette_stamp++;
/* look for match */
for (i = 0; i < 6; i++)
{
if (g_memcmp(palette, self->palette_items[i].palette,
256 * sizeof(int)) == 0)
{
- self->palette_items[i].use_count++;
+ self->palette_items[i].stamp = self->palette_stamp;
return i;
}
}
- /* look for least used */
- min_use_index = 0;
- min_use = 999999;
+ /* look for oldest */
+ index = 0;
+ oldest = 0x7fffffff;
for (i = 0; i < 6; i++)
{
- if (self->palette_items[i].use_count < min_use)
+ if (self->palette_items[i].stamp < oldest)
{
- min_use = self->palette_items[i].use_count;
- min_use_index = i;
+ oldest = self->palette_items[i].stamp;
+ index = i;
}
}
/* set, send palette and return */
- g_memcpy(self->palette_items[min_use_index].palette, palette,
- 256 * sizeof(int));
- self->palette_items[min_use_index].use_count++;
- xrdp_orders_send_palette(self->orders, palette, min_use_index);
- return min_use_index;
+ g_memcpy(self->palette_items[index].palette, palette, 256 * sizeof(int));
+ self->palette_items[index].stamp = self->palette_stamp;
+ xrdp_orders_send_palette(self->orders, palette, index);
+ return index;
}
/*****************************************************************************/
@@ -153,12 +153,13 @@ int xrdp_cache_add_char(struct xrdp_cache* self,
{
int i;
int j;
- int min_use;
+ int oldest;
int f;
int c;
int datasize;
struct xrdp_font_item* fi;
+ self->char_stamp++;
/* look for match */
for (i = 7; i < 12; i++)
{
@@ -166,23 +167,23 @@ int xrdp_cache_add_char(struct xrdp_cache* self,
{
if (xrdp_font_item_compare(&self->char_items[i][j].font_item, font_item))
{
- self->char_items[i][j].use_count++;
+ self->char_items[i][j].stamp = self->char_stamp;
DEBUG(("found font at %d %d\n\r", i, j));
return MAKELONG(i, j);
}
}
}
- /* look for least used */
+ /* look for oldest */
f = 0;
c = 0;
- min_use = 999999;
+ oldest = 0x7fffffff;
for (i = 7; i < 12; i++)
{
for (j = 0; j < 250; j++)
{
- if (self->char_items[i][j].use_count < min_use)
+ if (self->char_items[i][j].stamp < oldest)
{
- min_use = self->char_items[i][j].use_count;
+ oldest = self->char_items[i][j].stamp;
f = i;
c = j;
}
@@ -199,7 +200,7 @@ int xrdp_cache_add_char(struct xrdp_cache* self,
fi->baseline = font_item->baseline;
fi->width = font_item->width;
fi->height = font_item->height;
- self->char_items[f][c].use_count++;
+ self->char_items[f][c].stamp = self->char_stamp;
xrdp_orders_send_font(self->orders, fi, f, c);
return MAKELONG(f, c);
}
diff --git a/xrdp/xrdp_orders.c b/xrdp/xrdp_orders.c
index 7e76e48b..ab363ec7 100644
--- a/xrdp/xrdp_orders.c
+++ b/xrdp/xrdp_orders.c
@@ -1,4 +1,3 @@
-
/*
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
diff --git a/xrdp/xrdp_painter.c b/xrdp/xrdp_painter.c
index 020f7771..c54d5730 100644
--- a/xrdp/xrdp_painter.c
+++ b/xrdp/xrdp_painter.c
@@ -1,4 +1,3 @@
-
/*
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -60,6 +59,7 @@ int xrdp_painter_end_update(struct xrdp_painter* self)
}
/*****************************************************************************/
+/* returns boolean, true if there is something to draw */
int xrdp_painter_clip_adj(struct xrdp_painter* self, int* x, int* y,
int* cx, int* cy)
{
@@ -145,19 +145,14 @@ int xrdp_painter_fill_rect(struct xrdp_painter* self,
struct xrdp_region* region;
struct xrdp_rect rect;
- if (x >= bitmap->width) return 0;
- if (y >= bitmap->height) return 0;
- if (x < 0) { cx += x; x = 0; }
- if (y < 0) { cy += y; y = 0; }
- if (cx <= 0) return 0;
- if (cy <= 0) return 0;
- if (x + cx > bitmap->width) cx = bitmap->width - x;
- if (y + cy > bitmap->height) cy = bitmap->height - y;
-
+ if (!check_bounds(bitmap, &x, &y, &cx, &cy))
+ return 0;
if (!xrdp_painter_clip_adj(self, &x, &y, &cx, &cy))
return 0;
- if (bitmap->type == 0)
+ /* todo data */
+
+ if (bitmap->type == WND_TYPE_BITMAP) /* 0 */
return 0;
region = xrdp_region_create(self->wm);
xrdp_wm_get_vis_region(self->wm, bitmap, x, y, cx, cy, region);
@@ -187,26 +182,21 @@ int xrdp_painter_fill_rect2(struct xrdp_painter* self,
struct xrdp_region* region;
struct xrdp_rect rect;
- if (x >= bitmap->width) return 0;
- if (y >= bitmap->height) return 0;
- if (x < 0) { cx += x; x = 0; }
- if (y < 0) { cy += y; y = 0; }
- if (cx <= 0) return 0;
- if (cy <= 0) return 0;
- if (x + cx > bitmap->width) cx = bitmap->width - x;
- if (y + cy > bitmap->height) cy = bitmap->height - y;
-
+ if (!check_bounds(bitmap, &x, &y, &cx, &cy))
+ return 0;
if (!xrdp_painter_clip_adj(self, &x, &y, &cx, &cy))
return 0;
- if (bitmap->type == 0) /* bitmap */
+ /* todo data */
+
+ if (bitmap->type == WND_TYPE_BITMAP) /* 0 */
return 0;
region = xrdp_region_create(self->wm);
xrdp_wm_get_vis_region(self->wm, bitmap, x, y, cx, cy, region);
i = 0;
while (xrdp_region_get_rect(region, i, &rect) == 0)
{
- DEBUG(("sending rect order %d %d %d %d\n\r", rect.left, rect.top,
+ DEBUG(("sending rect2 order %d %d %d %d\n\r", rect.left, rect.top,
rect.right, rect.bottom));
xrdp_orders_pat_blt(self->orders, rect.left, rect.top,
rect.right - rect.left,
@@ -216,7 +206,6 @@ int xrdp_painter_fill_rect2(struct xrdp_painter* self,
i++;
}
xrdp_region_delete(region);
-
return 0;
}
@@ -250,7 +239,7 @@ int xrdp_painter_draw_bitmap(struct xrdp_painter* self,
/* todo data */
- if (bitmap->type == 0)
+ if (bitmap->type == WND_TYPE_BITMAP)
return 0;
region = xrdp_region_create(self->wm);
xrdp_wm_get_vis_region(self->wm, bitmap, x, y, cx, cy, region);
@@ -435,7 +424,9 @@ int xrdp_painter_draw_text(struct xrdp_painter* self,
if (self->use_clip)
clip_rect = self->clip;
else
+ {
MAKERECT(clip_rect, 0, 0, bitmap->width, bitmap->height);
+ }
b = bitmap;
while (b != 0)
{
diff --git a/xrdp/xrdp_types.h b/xrdp/xrdp_types.h
index 383bc3b3..c1ec3d91 100644
--- a/xrdp/xrdp_types.h
+++ b/xrdp/xrdp_types.h
@@ -239,13 +239,13 @@ struct xrdp_orders
struct xrdp_palette_item
{
- int use_count;
+ int stamp;
int palette[256];
};
struct xrdp_bitmap_item
{
- int use_count;
+ int stamp;
struct xrdp_bitmap* bitmap;
};
@@ -261,7 +261,7 @@ struct xrdp_font_item
struct xrdp_char_item
{
- int use_count;
+ int stamp;
struct xrdp_font_item font_item;
};
@@ -270,8 +270,11 @@ struct xrdp_cache
{
struct xrdp_wm* wm; /* owner */
struct xrdp_orders* orders;
+ int palette_stamp;
struct xrdp_palette_item palette_items[6];
+ int bitmap_stamp;
struct xrdp_bitmap_item bitmap_items[3][600];
+ int char_stamp;
struct xrdp_char_item char_items[12][256];
};
diff --git a/xrdp/xrdp_wm.c b/xrdp/xrdp_wm.c
index 29949984..6e755ce2 100644
--- a/xrdp/xrdp_wm.c
+++ b/xrdp/xrdp_wm.c
@@ -1,4 +1,3 @@
-
/*
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -211,6 +210,8 @@ int xrdp_wm_login_notify(struct xrdp_bitmap* wnd,
struct xrdp_rect rect;
int i;
+ if (wnd->modal_dialog != 0 && msg != 100)
+ return 0;
if (msg == 1) /* click */
{
if (sender->id == 1) /* help button */
@@ -427,33 +428,33 @@ int xrdp_wm_init(struct xrdp_wm* self)
}
else if (self->screen->bpp == 15)
{
- self->black = color15(0, 0, 0);
- self->grey = color15(0xc0, 0xc0, 0xc0);
- self->dark_grey = color15(0x80, 0x80, 0x80);
- self->blue = color15(0x00, 0x00, 0xff);
- self->white = color15(0xff, 0xff, 0xff);
- self->red = color15(0xff, 0x00, 0x00);
- self->green = color15(0x00, 0xff, 0x00);
+ self->black = COLOR15(0, 0, 0);
+ self->grey = COLOR15(0xc0, 0xc0, 0xc0);
+ self->dark_grey = COLOR15(0x80, 0x80, 0x80);
+ self->blue = COLOR15(0x00, 0x00, 0xff);
+ self->white = COLOR15(0xff, 0xff, 0xff);
+ self->red = COLOR15(0xff, 0x00, 0x00);
+ self->green = COLOR15(0x00, 0xff, 0x00);
}
else if (self->screen->bpp == 16)
{
- self->black = color16(0, 0, 0);
- self->grey = color16(0xc0, 0xc0, 0xc0);
- self->dark_grey = color16(0x80, 0x80, 0x80);
- self->blue = color16(0x00, 0x00, 0xff);
- self->white = color16(0xff, 0xff, 0xff);
- self->red = color16(0xff, 0x00, 0x00);
- self->green = color16(0x00, 0xff, 0x00);
+ self->black = COLOR16(0, 0, 0);
+ self->grey = COLOR16(0xc0, 0xc0, 0xc0);
+ self->dark_grey = COLOR16(0x80, 0x80, 0x80);
+ self->blue = COLOR16(0x00, 0x00, 0xff);
+ self->white = COLOR16(0xff, 0xff, 0xff);
+ self->red = COLOR16(0xff, 0x00, 0x00);
+ self->green = COLOR16(0x00, 0xff, 0x00);
}
else if (self->screen->bpp == 24)
{
- self->black = color24(0, 0, 0);
- self->grey = color24(0xc0, 0xc0, 0xc0);
- self->dark_grey = color24(0x80, 0x80, 0x80);
- self->blue = color24(0x00, 0x00, 0xff);
- self->white = color24(0xff, 0xff, 0xff);
- self->red = color24(0xff, 0x00, 0x00);
- self->green = color24(0x00, 0xff, 0x00);
+ self->black = COLOR24(0, 0, 0);
+ self->grey = COLOR24(0xc0, 0xc0, 0xc0);
+ self->dark_grey = COLOR24(0x80, 0x80, 0x80);
+ self->blue = COLOR24(0x00, 0x00, 0xff);
+ self->white = COLOR24(0xff, 0xff, 0xff);
+ self->red = COLOR24(0xff, 0x00, 0x00);
+ self->green = COLOR24(0x00, 0xff, 0x00);
}
/* draw login window */
self->login_window = xrdp_bitmap_create(400, 200, self->screen->bpp, 1);
@@ -489,6 +490,7 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->top = 30;
xrdp_list_add_item(self->login_window->child_list, (int)but);
+ /* button */
but = xrdp_bitmap_create(60, 25, self->screen->bpp, 3);
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
@@ -499,6 +501,7 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->id = 1;
g_strcpy(but->title, "Help");
+ /* button */
but = xrdp_bitmap_create(60, 25, self->screen->bpp, 3);
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
@@ -509,6 +512,7 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->id = 2;
g_strcpy(but->title, "Cancel");
+ /* button */
but = xrdp_bitmap_create(60, 25, self->screen->bpp, 3);
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
@@ -519,7 +523,8 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->id = 3;
g_strcpy(but->title, "OK");
- but = xrdp_bitmap_create(50, 20, self->screen->bpp, 6); /* label */
+ /* label */
+ but = xrdp_bitmap_create(60, 20, self->screen->bpp, 6); /* label */
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
but->owner = self->login_window;
@@ -528,6 +533,7 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->top = 50;
g_strcpy(but->title, "Username");
+ /* edit */
but = xrdp_bitmap_create(140, 20, self->screen->bpp, 5);
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
@@ -538,7 +544,8 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->id = 4;
but->cursor = 1;
- but = xrdp_bitmap_create(50, 20, self->screen->bpp, 6); /* label */
+ /* label */
+ but = xrdp_bitmap_create(60, 20, self->screen->bpp, 6); /* label */
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
but->owner = self->login_window;
@@ -547,6 +554,7 @@ int xrdp_wm_init(struct xrdp_wm* self)
but->top = 80;
g_strcpy(but->title, "Password");
+ /* edit */
but = xrdp_bitmap_create(140, 20, self->screen->bpp, 5);
xrdp_list_add_item(self->login_window->child_list, (int)but);
but->parent = self->login_window;
@@ -846,8 +854,8 @@ int xrdp_wm_mouse_move(struct xrdp_wm* self, int x, int y)
/*****************************************************************************/
int xrdp_wm_mouse_click(struct xrdp_wm* self, int x, int y, int but, int down)
{
- struct xrdp_bitmap* b;
- struct xrdp_bitmap* b1;
+ struct xrdp_bitmap* control;
+ struct xrdp_bitmap* wnd;
int newx;
int newy;
int oldx;
@@ -880,29 +888,34 @@ int xrdp_wm_mouse_click(struct xrdp_wm* self, int x, int y, int but, int down)
self->dragging_window = 0;
self->dragging = 0;
}
- b = xrdp_wm_at_pos(self->screen, x, y, &b1);
- if (b != 0)
+ wnd = 0;
+ control = xrdp_wm_at_pos(self->screen, x, y, &wnd);
+ if (control != 0)
{
- if (b->type == 3 && but == 1 && !down && self->button_down == b)
+ if (wnd != 0)
+ if (wnd->modal_dialog != 0) /* if window has a modal dialog */
+ return 0;
+ if (control->type == 3 && but == 1 &&
+ !down && self->button_down == control)
{ /* if clicking up on a button that was clicked down */
self->button_down = 0;
- b->state = 0;
- xrdp_bitmap_invalidate(b, 0);
- if (b->parent != 0)
- if (b->parent->notify != 0)
- /* b can be invalid after this */
- b->parent->notify(b->owner, b, 1, x, y);
+ control->state = 0;
+ xrdp_bitmap_invalidate(control, 0);
+ if (control->parent != 0)
+ if (control->parent->notify != 0)
+ /* control can be invalid after this */
+ control->parent->notify(control->owner, control, 1, x, y);
}
- else if (b->type == 3 && but == 1 && down)
+ else if (control->type == 3 && but == 1 && down)
{ /* if clicking down on a button */
- self->button_down = b;
- b->state = 1;
- xrdp_bitmap_invalidate(b, 0);
+ self->button_down = control;
+ control->state = 1;
+ xrdp_bitmap_invalidate(control, 0);
}
else if (but == 1 && down)
{
- xrdp_wm_set_focused(self, b1);
- if (b->type == 1 && y < (b->top + 21))
+ xrdp_wm_set_focused(self, wnd);
+ if (control->type == 1 && y < (control->top + 21))
{ /* if dragging */
if (self->dragging) /* rarely happens */
{
@@ -914,15 +927,15 @@ int xrdp_wm_mouse_click(struct xrdp_wm* self, int x, int y, int but, int down)
self->draggingxorstate = 0;
}
self->dragging = 1;
- self->dragging_window = b;
- self->draggingorgx = b->left;
- self->draggingorgy = b->top;
+ self->dragging_window = control;
+ self->draggingorgx = control->left;
+ self->draggingorgy = control->top;
self->draggingx = x;
self->draggingy = y;
- self->draggingdx = x - b->left;
- self->draggingdy = y - b->top;
- self->draggingcx = b->width;
- self->draggingcy = b->height;
+ self->draggingdx = x - control->left;
+ self->draggingdy = y - control->top;
+ self->draggingcx = control->width;
+ self->draggingcy = control->height;
}
}
}