summaryrefslogtreecommitdiffstats
path: root/xrdp
diff options
context:
space:
mode:
authorJay Sorg <jay.sorg@gmail.com>2012-05-13 14:40:14 -0700
committerJay Sorg <jay.sorg@gmail.com>2012-05-13 14:40:14 -0700
commit76e070e4f141c868fd4a4432985028c6a67bc643 (patch)
tree6cc4d9c9b9e1cc5f41e7ac453672d45f2cf692ac /xrdp
parente8d2e4b6ad7538fc8f87bbe285d7d2a2413a734e (diff)
downloadxrdp-proprietary-76e070e4f141c868fd4a4432985028c6a67bc643.tar.gz
xrdp-proprietary-76e070e4f141c868fd4a4432985028c6a67bc643.zip
started work on off screen bitmap support
Diffstat (limited to 'xrdp')
-rw-r--r--xrdp/xrdp.h7
-rw-r--r--xrdp/xrdp_cache.c80
-rw-r--r--xrdp/xrdp_types.h7
3 files changed, 94 insertions, 0 deletions
diff --git a/xrdp/xrdp.h b/xrdp/xrdp.h
index 2bc3c8b0..14be3767 100644
--- a/xrdp/xrdp.h
+++ b/xrdp/xrdp.h
@@ -80,6 +80,13 @@ xrdp_cache_add_pointer_static(struct xrdp_cache* self,
int APP_CC
xrdp_cache_add_brush(struct xrdp_cache* self,
char* brush_item_data);
+int APP_CC
+xrdp_cache_add_os_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap,
+ int id);
+int APP_CC
+xrdp_cache_remove_os_bitmap(struct xrdp_cache* self, int id);
+struct xrdp_os_bitmap_item* APP_CC
+xrdp_cache_get_os_bitmap(struct xrdp_cache* self, int id);
/* xrdp_wm.c */
struct xrdp_wm* APP_CC
diff --git a/xrdp/xrdp_cache.c b/xrdp/xrdp_cache.c
index 83e91ed9..88180491 100644
--- a/xrdp/xrdp_cache.c
+++ b/xrdp/xrdp_cache.c
@@ -73,6 +73,11 @@ xrdp_cache_delete(struct xrdp_cache* self)
g_free(self->char_items[i][j].font_item.data);
}
}
+ for (i = 0; i < 2000; i++)
+ {
+ xrdp_bitmap_delete(self->os_bitmap_items[i].bitmap);
+ }
+
g_free(self);
}
@@ -532,3 +537,78 @@ xrdp_cache_add_brush(struct xrdp_cache* self,
DEBUG(("adding brush at %d", index));
return index;
}
+
+/*****************************************************************************/
+/* returns index */
+int APP_CC
+xrdp_cache_add_os_bitmap(struct xrdp_cache* self, struct xrdp_bitmap* bitmap,
+ int id)
+{
+ int index;
+ struct xrdp_os_bitmap_item* bi;
+
+ if (id < 1)
+ {
+ return -1;
+ }
+ index = 0;
+ for (index = 0; index < 2000; index++)
+ {
+ bi = self->os_bitmap_items + index;
+ if (bi->bitmap == 0)
+ {
+ bi->id = id;
+ bi->bitmap = bitmap;
+ //g_writeln("xrdp_cache_add_os_bitmap: bitmap id 0x%x added at index %d", id, index);
+ return index;
+ }
+ }
+ g_writeln("xrdp_cache_add_os_bitmap: bitmap id 0x%x not added, full", id);
+ return -1;
+}
+
+/*****************************************************************************/
+/* returns index */
+int APP_CC
+xrdp_cache_remove_os_bitmap(struct xrdp_cache* self, int id)
+{
+ int index;
+ struct xrdp_os_bitmap_item* bi;
+
+ if (id < 1)
+ {
+ return -1;
+ }
+ for (index = 0; index < 2000; index++)
+ {
+ bi = self->os_bitmap_items + index;
+ if (bi->id == id)
+ {
+ xrdp_bitmap_delete(bi->bitmap);
+ g_memset(bi, 0, sizeof(struct xrdp_os_bitmap_item));
+ //g_writeln("xrdp_cache_remove_os_bitmap: bitmap id 0x%x removed from index %d", id, index);
+ return index;
+ }
+ }
+ return -1;
+}
+
+/*****************************************************************************/
+struct xrdp_os_bitmap_item* APP_CC
+xrdp_cache_get_os_bitmap(struct xrdp_cache* self, int id)
+{
+ int index;
+ struct xrdp_os_bitmap_item* bi;
+
+ for (index = 0; index < 2000; index++)
+ {
+ bi = self->os_bitmap_items + index;
+ if (bi->id == id)
+ {
+ //g_writeln("xrdp_cache_get_os_bitmap: bitmap id 0x%x found at index %d", id, index);
+ return bi;
+ }
+ }
+ g_writeln("xrdp_cache_get_os_bitmap: bitmap id 0x%x not found", id);
+ return 0;
+}
diff --git a/xrdp/xrdp_types.h b/xrdp/xrdp_types.h
index 79ca7acb..3c5decf6 100644
--- a/xrdp/xrdp_types.h
+++ b/xrdp/xrdp_types.h
@@ -117,6 +117,12 @@ struct xrdp_bitmap_item
struct xrdp_bitmap* bitmap;
};
+struct xrdp_os_bitmap_item
+{
+ int id;
+ struct xrdp_bitmap* bitmap;
+};
+
struct xrdp_char_item
{
int stamp;
@@ -169,6 +175,7 @@ struct xrdp_cache
int pointer_cache_entries;
int brush_stamp;
struct xrdp_brush_item brush_items[64];
+ struct xrdp_os_bitmap_item os_bitmap_items[2000];
};
struct xrdp_mm