summaryrefslogtreecommitdiffstats
path: root/libxrdp
diff options
context:
space:
mode:
authorjsorg71 <jsorg71>2007-01-20 05:14:11 +0000
committerjsorg71 <jsorg71>2007-01-20 05:14:11 +0000
commit06186b0b75d9fa2b87e278b74b43ccff181230c8 (patch)
tree6f44750815ad374ec330e758d49376c68df58c11 /libxrdp
parentaefa66e3a2f537baf2e952142e4554260f6c7e6f (diff)
downloadxrdp-proprietary-06186b0b75d9fa2b87e278b74b43ccff181230c8.tar.gz
xrdp-proprietary-06186b0b75d9fa2b87e278b74b43ccff181230c8.zip
moved orders state to one struct
Diffstat (limited to 'libxrdp')
-rw-r--r--libxrdp/libxrdp.h27
-rw-r--r--libxrdp/xrdp_orders.c494
2 files changed, 260 insertions, 261 deletions
diff --git a/libxrdp/libxrdp.h b/libxrdp/libxrdp.h
index a4a4a299..12d3c944 100644
--- a/libxrdp/libxrdp.h
+++ b/libxrdp/libxrdp.h
@@ -116,18 +116,9 @@ struct xrdp_rdp
struct xrdp_client_info client_info;
};
-/* orders */
-struct xrdp_orders
+/* state */
+struct xrdp_orders_state
{
- struct stream* out_s;
- struct xrdp_rdp* rdp_layer;
- struct xrdp_session* session;
- struct xrdp_wm* wm;
-
- char* order_count_ptr; /* pointer to count, set when sending */
- int order_count;
- int order_level; /* inc for every call to xrdp_orders_init */
-
int last_order; /* last order sent */
int clip_left; /* RDP_ORDER_BOUNDS, RDP_ORDER_LASTBOUNDS */
@@ -204,6 +195,20 @@ struct xrdp_orders
char* text_data;
};
+/* orders */
+struct xrdp_orders
+{
+ struct stream* out_s;
+ struct xrdp_rdp* rdp_layer;
+ struct xrdp_session* session;
+ struct xrdp_wm* wm;
+
+ char* order_count_ptr; /* pointer to count, set when sending */
+ int order_count;
+ int order_level; /* inc for every call to xrdp_orders_init */
+ struct xrdp_orders_state orders_state;
+};
+
/* xrdp_tcp.c */
struct xrdp_tcp* APP_CC
xrdp_tcp_create(struct xrdp_iso* owner, int sck);
diff --git a/libxrdp/xrdp_orders.c b/libxrdp/xrdp_orders.c
index 7b2994b0..daad906e 100644
--- a/libxrdp/xrdp_orders.c
+++ b/libxrdp/xrdp_orders.c
@@ -33,8 +33,8 @@ xrdp_orders_create(struct xrdp_session* session, struct xrdp_rdp* rdp_layer)
self->rdp_layer = rdp_layer;
make_stream(self->out_s);
init_stream(self->out_s, 16384);
- self->clip_right = 1; /* silly rdp right clip */
- self->clip_bottom = 1; /* silly rdp bottom clip */
+ self->orders_state.clip_right = 1; /* silly rdp right clip */
+ self->orders_state.clip_bottom = 1; /* silly rdp bottom clip */
return self;
}
@@ -47,6 +47,7 @@ xrdp_orders_delete(struct xrdp_orders* self)
return;
}
free_stream(self->out_s);
+ g_free(self->orders_state.text_data);
g_free(self);
}
@@ -56,29 +57,17 @@ xrdp_orders_delete(struct xrdp_orders* self)
int APP_CC
xrdp_orders_reset(struct xrdp_orders* self)
{
- struct stream* out_s;
- struct xrdp_rdp* rdp_layer;
- struct xrdp_session* session;
- struct xrdp_wm* wm;
-
if (xrdp_orders_force_send(self) != 0)
{
return 1;
}
- /* save these */
- out_s = self->out_s;
- rdp_layer = self->rdp_layer;
- session = self->session;
- wm = self->wm;
- /* set whole struct to zero */
- g_memset(self, 0, sizeof(struct xrdp_orders));
- /* set some stuff back */
- self->out_s = out_s;
- self->rdp_layer = rdp_layer;
- self->session = session;
- self->wm = wm;
- self->clip_right = 1; /* silly rdp right clip */
- self->clip_bottom = 1; /* silly rdp bottom clip */
+ g_free(self->orders_state.text_data);
+ g_memset(&(self->orders_state), 0, sizeof(self->orders_state));
+ self->order_count_ptr = 0;
+ self->order_count = 0;
+ self->order_level = 0;
+ self->orders_state.clip_right = 1; /* silly rdp right clip */
+ self->orders_state.clip_bottom = 1; /* silly rdp bottom clip */
return 0;
}
@@ -207,10 +196,10 @@ xrdp_orders_last_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
{
return 0;
}
- if (rect->left == self->clip_left &&
- rect->top == self->clip_top &&
- rect->right == self->clip_right &&
- rect->bottom == self->clip_bottom)
+ if (rect->left == self->orders_state.clip_left &&
+ rect->top == self->orders_state.clip_top &&
+ rect->right == self->orders_state.clip_right &&
+ rect->bottom == self->orders_state.clip_bottom)
{
return 1;
}
@@ -247,10 +236,10 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
bounds_flags_ptr = self->out_s->p;
out_uint8s(self->out_s, 1);
/* left */
- if (rect->left == self->clip_left)
+ if (rect->left == self->orders_state.clip_left)
{
}
- else if (g_abs(rect->left - self->clip_left) < 128)
+ else if (g_abs(rect->left - self->orders_state.clip_left) < 128)
{
bounds_flags |= 0x10;
}
@@ -259,10 +248,10 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
bounds_flags |= 0x01;
}
/* top */
- if (rect->top == self->clip_top)
+ if (rect->top == self->orders_state.clip_top)
{
}
- else if (g_abs(rect->top - self->clip_top) < 128)
+ else if (g_abs(rect->top - self->orders_state.clip_top) < 128)
{
bounds_flags |= 0x20;
}
@@ -271,10 +260,10 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
bounds_flags |= 0x02;
}
/* right */
- if (rect->right == self->clip_right)
+ if (rect->right == self->orders_state.clip_right)
{
}
- else if (g_abs(rect->right - self->clip_right) < 128)
+ else if (g_abs(rect->right - self->orders_state.clip_right) < 128)
{
bounds_flags |= 0x40;
}
@@ -283,10 +272,10 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
bounds_flags |= 0x04;
}
/* bottom */
- if (rect->bottom == self->clip_bottom)
+ if (rect->bottom == self->orders_state.clip_bottom)
{
}
- else if (g_abs(rect->bottom - self->clip_bottom) < 128)
+ else if (g_abs(rect->bottom - self->orders_state.clip_bottom) < 128)
{
bounds_flags |= 0x80;
}
@@ -301,9 +290,9 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
}
else if (bounds_flags & 0x10)
{
- out_uint8(self->out_s, rect->left - self->clip_left);
+ out_uint8(self->out_s, rect->left - self->orders_state.clip_left);
}
- self->clip_left = rect->left;
+ self->orders_state.clip_left = rect->left;
/* top */
if (bounds_flags & 0x02)
{
@@ -311,9 +300,9 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
}
else if (bounds_flags & 0x20)
{
- out_uint8(self->out_s, rect->top - self->clip_top);
+ out_uint8(self->out_s, rect->top - self->orders_state.clip_top);
}
- self->clip_top = rect->top;
+ self->orders_state.clip_top = rect->top;
/* right */
if (bounds_flags & 0x04)
{
@@ -321,9 +310,9 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
}
else if (bounds_flags & 0x40)
{
- out_uint8(self->out_s, rect->right - self->clip_right);
+ out_uint8(self->out_s, rect->right - self->orders_state.clip_right);
}
- self->clip_right = rect->right;
+ self->orders_state.clip_right = rect->right;
/* bottom */
if (bounds_flags & 0x08)
{
@@ -331,9 +320,9 @@ xrdp_orders_out_bounds(struct xrdp_orders* self, struct xrdp_rect* rect)
}
else if (bounds_flags & 0x80)
{
- out_uint8(self->out_s, rect->bottom - self->clip_bottom);
+ out_uint8(self->out_s, rect->bottom - self->orders_state.clip_bottom);
}
- self->clip_bottom = rect->bottom;
+ self->orders_state.clip_bottom = rect->bottom;
/* set flags */
*bounds_flags_ptr = bounds_flags;
return 0;
@@ -355,11 +344,11 @@ xrdp_orders_rect(struct xrdp_orders* self, int x, int y, int cx, int cy,
xrdp_orders_check(self, 23);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_RECT)
+ if (self->orders_state.last_order != RDP_ORDER_RECT)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_RECT;
+ self->orders_state.last_order = RDP_ORDER_RECT;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -374,13 +363,13 @@ xrdp_orders_rect(struct xrdp_orders* self, int x, int y, int cx, int cy,
}
}
vals[0] = x;
- vals[1] = self->rect_x;
+ vals[1] = self->orders_state.rect_x;
vals[2] = y;
- vals[3] = self->rect_y;
+ vals[3] = self->orders_state.rect_y;
vals[4] = cx;
- vals[5] = self->rect_cx;
+ vals[5] = self->orders_state.rect_cx;
vals[6] = cy;
- vals[7] = self->rect_cy;
+ vals[7] = self->orders_state.rect_cy;
if (xrdp_orders_send_delta(self, vals, 8))
{
order_flags |= RDP_ORDER_DELTA;
@@ -388,7 +377,7 @@ xrdp_orders_rect(struct xrdp_orders* self, int x, int y, int cx, int cy,
out_uint8(self->out_s, order_flags)
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order);
+ out_uint8(self->out_s, self->orders_state.last_order);
}
present = 0;
present_ptr = self->out_s->p; /* hold 1 byte present pointer */
@@ -398,74 +387,77 @@ xrdp_orders_rect(struct xrdp_orders* self, int x, int y, int cx, int cy,
{
xrdp_orders_out_bounds(self, rect);
}
- if (x != self->rect_x)
+ if (x != self->orders_state.rect_x)
{
present |= 0x01;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, x - self->rect_x);
+ out_uint8(self->out_s, x - self->orders_state.rect_x);
}
else
{
out_uint16_le(self->out_s, x);
}
- self->rect_x = x;
+ self->orders_state.rect_x = x;
}
- if (y != self->rect_y)
+ if (y != self->orders_state.rect_y)
{
present |= 0x02;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, y - self->rect_y);
+ out_uint8(self->out_s, y - self->orders_state.rect_y);
}
else
{
out_uint16_le(self->out_s, y);
}
- self->rect_y = y;
+ self->orders_state.rect_y = y;
}
- if (cx != self->rect_cx)
+ if (cx != self->orders_state.rect_cx)
{
present |= 0x04;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cx - self->rect_cx);
+ out_uint8(self->out_s, cx - self->orders_state.rect_cx);
}
else
{
out_uint16_le(self->out_s, cx);
}
- self->rect_cx = cx;
+ self->orders_state.rect_cx = cx;
}
- if (cy != self->rect_cy)
+ if (cy != self->orders_state.rect_cy)
{
present |= 0x08;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cy - self->rect_cy);
+ out_uint8(self->out_s, cy - self->orders_state.rect_cy);
}
else
{
out_uint16_le(self->out_s, cy);
}
- self->rect_cy = cy;
+ self->orders_state.rect_cy = cy;
}
- if ((color & 0xff) != (self->rect_color & 0xff))
+ if ((color & 0xff) != (self->orders_state.rect_color & 0xff))
{
present |= 0x10;
- self->rect_color = (self->rect_color & 0xffff00) | (color & 0xff);
+ self->orders_state.rect_color =
+ (self->orders_state.rect_color & 0xffff00) | (color & 0xff);
out_uint8(self->out_s, color);
}
- if ((color & 0xff00) != (self->rect_color & 0xff00))
+ if ((color & 0xff00) != (self->orders_state.rect_color & 0xff00))
{
present |= 0x20;
- self->rect_color = (self->rect_color & 0xff00ff) | (color & 0xff00);
+ self->orders_state.rect_color =
+ (self->orders_state.rect_color & 0xff00ff) | (color & 0xff00);
out_uint8(self->out_s, color >> 8);
}
- if ((color & 0xff0000) != (self->rect_color & 0xff0000))
+ if ((color & 0xff0000) != (self->orders_state.rect_color & 0xff0000))
{
present |= 0x40;
- self->rect_color = (self->rect_color & 0x00ffff) | (color & 0xff0000);
+ self->orders_state.rect_color =
+ (self->orders_state.rect_color & 0x00ffff) | (color & 0xff0000);
out_uint8(self->out_s, color >> 16);
}
present_ptr[0] = present;
@@ -489,11 +481,11 @@ xrdp_orders_screen_blt(struct xrdp_orders* self, int x, int y,
xrdp_orders_check(self, 25);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_SCREENBLT)
+ if (self->orders_state.last_order != RDP_ORDER_SCREENBLT)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_SCREENBLT;
+ self->orders_state.last_order = RDP_ORDER_SCREENBLT;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -508,17 +500,17 @@ xrdp_orders_screen_blt(struct xrdp_orders* self, int x, int y,
}
}
vals[0] = x;
- vals[1] = self->scr_blt_x;
+ vals[1] = self->orders_state.scr_blt_x;
vals[2] = y;
- vals[3] = self->scr_blt_y;
+ vals[3] = self->orders_state.scr_blt_y;
vals[4] = cx;
- vals[5] = self->scr_blt_cx;
+ vals[5] = self->orders_state.scr_blt_cx;
vals[6] = cy;
- vals[7] = self->scr_blt_cy;
+ vals[7] = self->orders_state.scr_blt_cy;
vals[8] = srcx;
- vals[9] = self->scr_blt_srcx;
+ vals[9] = self->orders_state.scr_blt_srcx;
vals[10] = srcy;
- vals[11] = self->scr_blt_srcy;
+ vals[11] = self->orders_state.scr_blt_srcy;
if (xrdp_orders_send_delta(self, vals, 12))
{
order_flags |= RDP_ORDER_DELTA;
@@ -526,7 +518,7 @@ xrdp_orders_screen_blt(struct xrdp_orders* self, int x, int y,
out_uint8(self->out_s, order_flags);
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order);
+ out_uint8(self->out_s, self->orders_state.last_order);
}
present = 0;
present_ptr = self->out_s->p; /* hold 1 byte present pointer */
@@ -536,89 +528,89 @@ xrdp_orders_screen_blt(struct xrdp_orders* self, int x, int y,
{
xrdp_orders_out_bounds(self, rect);
}
- if (x != self->scr_blt_x)
+ if (x != self->orders_state.scr_blt_x)
{
present |= 0x01;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, x - self->scr_blt_x);
+ out_uint8(self->out_s, x - self->orders_state.scr_blt_x);
}
else
{
out_uint16_le(self->out_s, x);
}
- self->scr_blt_x = x;
+ self->orders_state.scr_blt_x = x;
}
- if (y != self->scr_blt_y)
+ if (y != self->orders_state.scr_blt_y)
{
present |= 0x02;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, y - self->scr_blt_y);
+ out_uint8(self->out_s, y - self->orders_state.scr_blt_y);
}
else
{
out_uint16_le(self->out_s, y);
}
- self->scr_blt_y = y;
+ self->orders_state.scr_blt_y = y;
}
- if (cx != self->scr_blt_cx)
+ if (cx != self->orders_state.scr_blt_cx)
{
present |= 0x04;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cx - self->scr_blt_cx);
+ out_uint8(self->out_s, cx - self->orders_state.scr_blt_cx);
}
else
{
out_uint16_le(self->out_s, cx);
}
- self->scr_blt_cx = cx;
+ self->orders_state.scr_blt_cx = cx;
}
- if (cy != self->scr_blt_cy)
+ if (cy != self->orders_state.scr_blt_cy)
{
present |= 0x08;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cy - self->scr_blt_cy);
+ out_uint8(self->out_s, cy - self->orders_state.scr_blt_cy);
}
else
{
out_uint16_le(self->out_s, cy);
}
- self->scr_blt_cy = cy;
+ self->orders_state.scr_blt_cy = cy;
}
- if (rop != self->scr_blt_rop)
+ if (rop != self->orders_state.scr_blt_rop)
{
present |= 0x10;
out_uint8(self->out_s, rop);
- self->scr_blt_rop = rop;
+ self->orders_state.scr_blt_rop = rop;
}
- if (srcx != self->scr_blt_srcx)
+ if (srcx != self->orders_state.scr_blt_srcx)
{
present |= 0x20;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, srcx - self->scr_blt_srcx);
+ out_uint8(self->out_s, srcx - self->orders_state.scr_blt_srcx);
}
else
{
out_uint16_le(self->out_s, srcx);
}
- self->scr_blt_srcx = srcx;
+ self->orders_state.scr_blt_srcx = srcx;
}
- if (srcy != self->scr_blt_srcy)
+ if (srcy != self->orders_state.scr_blt_srcy)
{
present |= 0x40;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, srcy - self->scr_blt_srcy)
+ out_uint8(self->out_s, srcy - self->orders_state.scr_blt_srcy)
}
else
{
out_uint16_le(self->out_s, srcy)
}
- self->scr_blt_srcy = srcy;
+ self->orders_state.scr_blt_srcy = srcy;
}
present_ptr[0] = present;
return 0;
@@ -643,11 +635,11 @@ xrdp_orders_pat_blt(struct xrdp_orders* self, int x, int y,
xrdp_orders_check(self, 39);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_PATBLT)
+ if (self->orders_state.last_order != RDP_ORDER_PATBLT)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_PATBLT;
+ self->orders_state.last_order = RDP_ORDER_PATBLT;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -662,13 +654,13 @@ xrdp_orders_pat_blt(struct xrdp_orders* self, int x, int y,
}
}
vals[0] = x;
- vals[1] = self->pat_blt_x;
+ vals[1] = self->orders_state.pat_blt_x;
vals[2] = y;
- vals[3] = self->pat_blt_y;
+ vals[3] = self->orders_state.pat_blt_y;
vals[4] = cx;
- vals[5] = self->pat_blt_cx;
+ vals[5] = self->orders_state.pat_blt_cx;
vals[6] = cy;
- vals[7] = self->pat_blt_cy;
+ vals[7] = self->orders_state.pat_blt_cy;
if (xrdp_orders_send_delta(self, vals, 8))
{
order_flags |= RDP_ORDER_DELTA;
@@ -676,7 +668,7 @@ xrdp_orders_pat_blt(struct xrdp_orders* self, int x, int y,
out_uint8(self->out_s, order_flags);
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order);
+ out_uint8(self->out_s, self->orders_state.last_order);
}
present = 0;
present_ptr = self->out_s->p; /* hold 2 byte present pointer, todo */
@@ -687,115 +679,117 @@ xrdp_orders_pat_blt(struct xrdp_orders* self, int x, int y,
{
xrdp_orders_out_bounds(self, rect);
}
- if (x != self->pat_blt_x)
+ if (x != self->orders_state.pat_blt_x)
{
present |= 0x0001;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, x - self->pat_blt_x);
+ out_uint8(self->out_s, x - self->orders_state.pat_blt_x);
}
else
{
out_uint16_le(self->out_s, x);
}
- self->pat_blt_x = x;
+ self->orders_state.pat_blt_x = x;
}
- if (y != self->pat_blt_y)
+ if (y != self->orders_state.pat_blt_y)
{
present |= 0x0002;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, y - self->pat_blt_y);
+ out_uint8(self->out_s, y - self->orders_state.pat_blt_y);
}
else
{
out_uint16_le(self->out_s, y);
}
- self->pat_blt_y = y;
+ self->orders_state.pat_blt_y = y;
}
- if (cx != self->pat_blt_cx)
+ if (cx != self->orders_state.pat_blt_cx)
{
present |= 0x0004;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cx - self->pat_blt_cx);
+ out_uint8(self->out_s, cx - self->orders_state.pat_blt_cx);
}
else
{
out_uint16_le(self->out_s, cx);
}
- self->pat_blt_cx = cx;
+ self->orders_state.pat_blt_cx = cx;
}
- if (cy != self->pat_blt_cy)
+ if (cy != self->orders_state.pat_blt_cy)
{
present |= 0x0008;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cy - self->pat_blt_cy);
+ out_uint8(self->out_s, cy - self->orders_state.pat_blt_cy);
}
else
{
out_uint16_le(self->out_s, cy);
}
- self->pat_blt_cy = cy;
+ self->orders_state.pat_blt_cy = cy;
}
- if (rop != self->pat_blt_rop)
+ if (rop != self->orders_state.pat_blt_rop)
{
present |= 0x0010;
/* PATCOPY PATPAINT PATINVERT DSTINVERT BLACKNESS WHITENESS */
out_uint8(self->out_s, rop);
- self->pat_blt_rop = rop;
+ self->orders_state.pat_blt_rop = rop;
}
- if (bg_color != self->pat_blt_bg_color)
+ if (bg_color != self->orders_state.pat_blt_bg_color)
{
present |= 0x0020;
out_uint8(self->out_s, bg_color);
out_uint8(self->out_s, bg_color >> 8);
out_uint8(self->out_s, bg_color >> 16);
- self->pat_blt_bg_color = bg_color;
+ self->orders_state.pat_blt_bg_color = bg_color;
}
- if (fg_color != self->pat_blt_fg_color)
+ if (fg_color != self->orders_state.pat_blt_fg_color)
{
present |= 0x0040;
out_uint8(self->out_s, fg_color);
out_uint8(self->out_s, fg_color >> 8);
out_uint8(self->out_s, fg_color >> 16);
- self->pat_blt_fg_color = fg_color;
+ self->orders_state.pat_blt_fg_color = fg_color;
}
if (brush == 0) /* if nil use blank one */
{ /* todo can we just set style to zero */
g_memset(&blank_brush, 0, sizeof(struct xrdp_brush));
brush = &blank_brush;
}
- if (brush->x_orgin != self->pat_blt_brush.x_orgin)
+ if (brush->x_orgin != self->orders_state.pat_blt_brush.x_orgin)
{
present |= 0x0080;
out_uint8(self->out_s, brush->x_orgin);
- self->pat_blt_brush.x_orgin = brush->x_orgin;
+ self->orders_state.pat_blt_brush.x_orgin = brush->x_orgin;
}
- if (brush->y_orgin != self->pat_blt_brush.y_orgin)
+ if (brush->y_orgin != self->orders_state.pat_blt_brush.y_orgin)
{
present |= 0x0100;
out_uint8(self->out_s, brush->y_orgin);
- self->pat_blt_brush.y_orgin = brush->y_orgin;
+ self->orders_state.pat_blt_brush.y_orgin = brush->y_orgin;
}
- if (brush->style != self->pat_blt_brush.style)
+ if (brush->style != self->orders_state.pat_blt_brush.style)
{
present |= 0x0200;
out_uint8(self->out_s, brush->style);
- self->pat_blt_brush.style = brush->style;
+ self->orders_state.pat_blt_brush.style = brush->style;
}
- if (brush->pattern[0] != self->pat_blt_brush.pattern[0])
+ if (brush->pattern[0] != self->orders_state.pat_blt_brush.pattern[0])
{
present |= 0x0400;
out_uint8(self->out_s, brush->pattern[0]);
- self->pat_blt_brush.pattern[0] = brush->pattern[0];
+ self->orders_state.pat_blt_brush.pattern[0] = brush->pattern[0];
}
- if (g_memcmp(brush->pattern + 1, self->pat_blt_brush.pattern + 1, 7) != 0)
+ if (g_memcmp(brush->pattern + 1,
+ self->orders_state.pat_blt_brush.pattern + 1, 7) != 0)
{
present |= 0x0800;
out_uint8a(self->out_s, brush->pattern + 1, 7);
- g_memcpy(self->pat_blt_brush.pattern + 1, brush->pattern + 1, 7);
+ g_memcpy(self->orders_state.pat_blt_brush.pattern + 1,
+ brush->pattern + 1, 7);
}
present_ptr[0] = present;
present_ptr[1] = present >> 8;
@@ -819,11 +813,11 @@ xrdp_orders_dest_blt(struct xrdp_orders* self, int x, int y,
xrdp_orders_check(self, 21);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_DESTBLT)
+ if (self->orders_state.last_order != RDP_ORDER_DESTBLT)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_DESTBLT;
+ self->orders_state.last_order = RDP_ORDER_DESTBLT;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -838,13 +832,13 @@ xrdp_orders_dest_blt(struct xrdp_orders* self, int x, int y,
}
}
vals[0] = x;
- vals[1] = self->dest_blt_x;
+ vals[1] = self->orders_state.dest_blt_x;
vals[2] = y;
- vals[3] = self->dest_blt_y;
+ vals[3] = self->orders_state.dest_blt_y;
vals[4] = cx;
- vals[5] = self->dest_blt_cx;
+ vals[5] = self->orders_state.dest_blt_cx;
vals[6] = cy;
- vals[7] = self->dest_blt_cy;
+ vals[7] = self->orders_state.dest_blt_cy;
if (xrdp_orders_send_delta(self, vals, 8))
{
order_flags |= RDP_ORDER_DELTA;
@@ -852,7 +846,7 @@ xrdp_orders_dest_blt(struct xrdp_orders* self, int x, int y,
out_uint8(self->out_s, order_flags);
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order)
+ out_uint8(self->out_s, self->orders_state.last_order)
}
present = 0;
present_ptr = self->out_s->p; /* hold 1 byte present pointer */
@@ -862,63 +856,63 @@ xrdp_orders_dest_blt(struct xrdp_orders* self, int x, int y,
{
xrdp_orders_out_bounds(self, rect);
}
- if (x != self->dest_blt_x)
+ if (x != self->orders_state.dest_blt_x)
{
present |= 0x01;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, x - self->dest_blt_x);
+ out_uint8(self->out_s, x - self->orders_state.dest_blt_x);
}
else
{
out_uint16_le(self->out_s, x);
}
- self->dest_blt_x = x;
+ self->orders_state.dest_blt_x = x;
}
- if (y != self->dest_blt_y)
+ if (y != self->orders_state.dest_blt_y)
{
present |= 0x02;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, y - self->dest_blt_y);
+ out_uint8(self->out_s, y - self->orders_state.dest_blt_y);
}
else
{
out_uint16_le(self->out_s, y);
}
- self->dest_blt_y = y;
+ self->orders_state.dest_blt_y = y;
}
- if (cx != self->dest_blt_cx)
+ if (cx != self->orders_state.dest_blt_cx)
{
present |= 0x04;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cx - self->dest_blt_cx);
+ out_uint8(self->out_s, cx - self->orders_state.dest_blt_cx);
}
else
{
out_uint16_le(self->out_s, cx);
}
- self->dest_blt_cx = cx;
+ self->orders_state.dest_blt_cx = cx;
}
- if (cy != self->dest_blt_cy)
+ if (cy != self->orders_state.dest_blt_cy)
{
present |= 0x08;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cy - self->dest_blt_cy);
+ out_uint8(self->out_s, cy - self->orders_state.dest_blt_cy);
}
else
{
out_uint16_le(self->out_s, cy);
}
- self->dest_blt_cy = cy;
+ self->orders_state.dest_blt_cy = cy;
}
- if (rop != self->dest_blt_rop)
+ if (rop != self->orders_state.dest_blt_rop)
{
present |= 0x10;
out_uint8(self->out_s, rop);
- self->dest_blt_rop = rop;
+ self->orders_state.dest_blt_rop = rop;
}
present_ptr[0] = present;
return 0;
@@ -944,11 +938,11 @@ xrdp_orders_line(struct xrdp_orders* self, int mix_mode,
xrdp_orders_check(self, 32);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_LINE)
+ if (self->orders_state.last_order != RDP_ORDER_LINE)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_LINE;
+ self->orders_state.last_order = RDP_ORDER_LINE;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -965,13 +959,13 @@ xrdp_orders_line(struct xrdp_orders* self, int mix_mode,
}
}
vals[0] = startx;
- vals[1] = self->line_startx;
+ vals[1] = self->orders_state.line_startx;
vals[2] = starty;
- vals[3] = self->line_starty;
+ vals[3] = self->orders_state.line_starty;
vals[4] = endx;
- vals[5] = self->line_endx;
+ vals[5] = self->orders_state.line_endx;
vals[6] = endy;
- vals[7] = self->line_endy;
+ vals[7] = self->orders_state.line_endy;
if (xrdp_orders_send_delta(self, vals, 8))
{
order_flags |= RDP_ORDER_DELTA;
@@ -979,7 +973,7 @@ xrdp_orders_line(struct xrdp_orders* self, int mix_mode,
out_uint8(self->out_s, order_flags);
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order);
+ out_uint8(self->out_s, self->orders_state.last_order);
}
present = 0;
present_ptr = self->out_s->p; /* hold 2 byte present pointer */
@@ -989,102 +983,102 @@ xrdp_orders_line(struct xrdp_orders* self, int mix_mode,
{
xrdp_orders_out_bounds(self, rect);
}
- if (mix_mode != self->line_mix_mode)
+ if (mix_mode != self->orders_state.line_mix_mode)
{
present |= 0x0001;
out_uint16_le(self->out_s, mix_mode)
- self->line_mix_mode = mix_mode;
+ self->orders_state.line_mix_mode = mix_mode;
}
- if (startx != self->line_startx)
+ if (startx != self->orders_state.line_startx)
{
present |= 0x0002;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, startx - self->line_startx);
+ out_uint8(self->out_s, startx - self->orders_state.line_startx);
}
else
{
out_uint16_le(self->out_s, startx);
}
- self->line_startx = startx;
+ self->orders_state.line_startx = startx;
}
- if (starty != self->line_starty)
+ if (starty != self->orders_state.line_starty)
{
present |= 0x0004;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, starty - self->line_starty);
+ out_uint8(self->out_s, starty - self->orders_state.line_starty);
}
else
{
out_uint16_le(self->out_s, starty);
}
- self->line_starty = starty;
+ self->orders_state.line_starty = starty;
}
- if (endx != self->line_endx)
+ if (endx != self->orders_state.line_endx)
{
present |= 0x0008;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, endx - self->line_endx);
+ out_uint8(self->out_s, endx - self->orders_state.line_endx);
}
else
{
out_uint16_le(self->out_s, endx);
}
- self->line_endx = endx;
+ self->orders_state.line_endx = endx;
}
- if (endy != self->line_endy)
+ if (endy != self->orders_state.line_endy)
{
present |= 0x0010;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, endy - self->line_endy);
+ out_uint8(self->out_s, endy - self->orders_state.line_endy);
}
else
{
out_uint16_le(self->out_s, endy);
}
- self->line_endy = endy;
+ self->orders_state.line_endy = endy;
}
- if (bg_color != self->line_bg_color)
+ if (bg_color != self->orders_state.line_bg_color)
{
present |= 0x0020;
out_uint8(self->out_s, bg_color)
out_uint8(self->out_s, bg_color >> 8)
out_uint8(self->out_s, bg_color >> 16)
- self->line_bg_color = bg_color;
+ self->orders_state.line_bg_color = bg_color;
}
- if (rop != self->line_rop)
+ if (rop != self->orders_state.line_rop)
{
present |= 0x0040;
out_uint8(self->out_s, rop)
- self->line_rop = rop;
+ self->orders_state.line_rop = rop;
}
if (pen == 0)
{
g_memset(&blank_pen, 0, sizeof(struct xrdp_pen));
pen = &blank_pen;
}
- if (pen->style != self->line_pen.style)
+ if (pen->style != self->orders_state.line_pen.style)
{
present |= 0x0080;
out_uint8(self->out_s, pen->style)
- self->line_pen.style = pen->style;
+ self->orders_state.line_pen.style = pen->style;
}
- if (pen->width != self->line_pen.width)
+ if (pen->width != self->orders_state.line_pen.width)
{
present |= 0x0100;
out_uint8(self->out_s, pen->width)
- self->line_pen.width = pen->width;
+ self->orders_state.line_pen.width = pen->width;
}
- if (pen->color != self->line_pen.color)
+ if (pen->color != self->orders_state.line_pen.color)
{
present |= 0x0200;
out_uint8(self->out_s, pen->color)
out_uint8(self->out_s, pen->color >> 8)
out_uint8(self->out_s, pen->color >> 16)
- self->line_pen.color = pen->color;
+ self->orders_state.line_pen.color = pen->color;
}
present_ptr[0] = present;
present_ptr[1] = present >> 8;
@@ -1109,11 +1103,11 @@ xrdp_orders_mem_blt(struct xrdp_orders* self, int cache_id,
xrdp_orders_check(self, 30);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_MEMBLT)
+ if (self->orders_state.last_order != RDP_ORDER_MEMBLT)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_MEMBLT;
+ self->orders_state.last_order = RDP_ORDER_MEMBLT;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -1128,17 +1122,17 @@ xrdp_orders_mem_blt(struct xrdp_orders* self, int cache_id,
}
}
vals[0] = x;
- vals[1] = self->mem_blt_x;
+ vals[1] = self->orders_state.mem_blt_x;
vals[2] = y;
- vals[3] = self->mem_blt_y;
+ vals[3] = self->orders_state.mem_blt_y;
vals[4] = cx;
- vals[5] = self->mem_blt_cx;
+ vals[5] = self->orders_state.mem_blt_cx;
vals[6] = cy;
- vals[7] = self->mem_blt_cy;
+ vals[7] = self->orders_state.mem_blt_cy;
vals[8] = srcx;
- vals[9] = self->mem_blt_srcx;
+ vals[9] = self->orders_state.mem_blt_srcx;
vals[10] = srcy;
- vals[11] = self->mem_blt_srcy;
+ vals[11] = self->orders_state.mem_blt_srcy;
if (xrdp_orders_send_delta(self, vals, 12))
{
order_flags |= RDP_ORDER_DELTA;
@@ -1146,7 +1140,7 @@ xrdp_orders_mem_blt(struct xrdp_orders* self, int cache_id,
out_uint8(self->out_s, order_flags);
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order)
+ out_uint8(self->out_s, self->orders_state.last_order)
}
present = 0;
present_ptr = self->out_s->p; /* hold 2 byte present pointer, todo */
@@ -1157,104 +1151,104 @@ xrdp_orders_mem_blt(struct xrdp_orders* self, int cache_id,
{
xrdp_orders_out_bounds(self, rect);
}
- if (cache_id != self->mem_blt_cache_id ||
- color_table != self->mem_blt_color_table)
+ if (cache_id != self->orders_state.mem_blt_cache_id ||
+ color_table != self->orders_state.mem_blt_color_table)
{
present |= 0x0001;
out_uint8(self->out_s, cache_id);
out_uint8(self->out_s, color_table);
- self->mem_blt_cache_id = cache_id;
- self->mem_blt_color_table = color_table;
+ self->orders_state.mem_blt_cache_id = cache_id;
+ self->orders_state.mem_blt_color_table = color_table;
}
- if (x != self->mem_blt_x)
+ if (x != self->orders_state.mem_blt_x)
{
present |= 0x0002;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, x - self->mem_blt_x);
+ out_uint8(self->out_s, x - self->orders_state.mem_blt_x);
}
else
{
out_uint16_le(self->out_s, x);
}
- self->mem_blt_x = x;
+ self->orders_state.mem_blt_x = x;
}
- if (y != self->mem_blt_y)
+ if (y != self->orders_state.mem_blt_y)
{
present |= 0x0004;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, y - self->mem_blt_y);
+ out_uint8(self->out_s, y - self->orders_state.mem_blt_y);
}
else
{
out_uint16_le(self->out_s, y);
}
- self->mem_blt_y = y;
+ self->orders_state.mem_blt_y = y;
}
- if (cx != self->mem_blt_cx)
+ if (cx != self->orders_state.mem_blt_cx)
{
present |= 0x0008;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cx - self->mem_blt_cx);
+ out_uint8(self->out_s, cx - self->orders_state.mem_blt_cx);
}
else
{
out_uint16_le(self->out_s, cx);
}
- self->mem_blt_cx = cx;
+ self->orders_state.mem_blt_cx = cx;
}
- if (cy != self->mem_blt_cy)
+ if (cy != self->orders_state.mem_blt_cy)
{
present |= 0x0010;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, cy - self->mem_blt_cy);
+ out_uint8(self->out_s, cy - self->orders_state.mem_blt_cy);
}
else
{
out_uint16_le(self->out_s, cy);
}
- self->mem_blt_cy = cy;
+ self->orders_state.mem_blt_cy = cy;
}
- if (rop != self->mem_blt_rop)
+ if (rop != self->orders_state.mem_blt_rop)
{
present |= 0x0020;
out_uint8(self->out_s, rop);
- self->mem_blt_rop = rop;
+ self->orders_state.mem_blt_rop = rop;
}
- if (srcx != self->mem_blt_srcx)
+ if (srcx != self->orders_state.mem_blt_srcx)
{
present |= 0x0040;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, srcx - self->mem_blt_srcx);
+ out_uint8(self->out_s, srcx - self->orders_state.mem_blt_srcx);
}
else
{
out_uint16_le(self->out_s, srcx);
}
- self->mem_blt_srcx = srcx;
+ self->orders_state.mem_blt_srcx = srcx;
}
- if (srcy != self->mem_blt_srcy)
+ if (srcy != self->orders_state.mem_blt_srcy)
{
present |= 0x0080;
if (order_flags & RDP_ORDER_DELTA)
{
- out_uint8(self->out_s, srcy - self->mem_blt_srcy);
+ out_uint8(self->out_s, srcy - self->orders_state.mem_blt_srcy);
}
else
{
out_uint16_le(self->out_s, srcy);
}
- self->mem_blt_srcy = srcy;
+ self->orders_state.mem_blt_srcy = srcy;
}
- if (cache_idx != self->mem_blt_cache_idx)
+ if (cache_idx != self->orders_state.mem_blt_cache_idx)
{
present |= 0x0100;
out_uint16_le(self->out_s, cache_idx);
- self->mem_blt_cache_idx = cache_idx;
+ self->orders_state.mem_blt_cache_idx = cache_idx;
}
present_ptr[0] = present;
present_ptr[1] = present >> 8;
@@ -1281,11 +1275,11 @@ xrdp_orders_text(struct xrdp_orders* self,
xrdp_orders_check(self, 100);
self->order_count++;
order_flags = RDP_ORDER_STANDARD;
- if (self->last_order != RDP_ORDER_TEXT2)
+ if (self->orders_state.last_order != RDP_ORDER_TEXT2)
{
order_flags |= RDP_ORDER_CHANGE;
}
- self->last_order = RDP_ORDER_TEXT2;
+ self->orders_state.last_order = RDP_ORDER_TEXT2;
if (rect != 0)
{
/* if clip is present, still check if its needed */
@@ -1309,7 +1303,7 @@ xrdp_orders_text(struct xrdp_orders* self,
out_uint8(self->out_s, order_flags);
if (order_flags & RDP_ORDER_CHANGE)
{
- out_uint8(self->out_s, self->last_order);
+ out_uint8(self->out_s, self->orders_state.last_order);
}
present = 0;
present_ptr = self->out_s->p; /* hold 3 byte present pointer, todo */
@@ -1320,100 +1314,100 @@ xrdp_orders_text(struct xrdp_orders* self,
{
xrdp_orders_out_bounds(self, rect);
}
- if (font != self->text_font)
+ if (font != self->orders_state.text_font)
{
present |= 0x000001;
out_uint8(self->out_s, font);
- self->text_font = font;
+ self->orders_state.text_font = font;
}
- if (flags != self->text_flags)
+ if (flags != self->orders_state.text_flags)
{
present |= 0x000002;
out_uint8(self->out_s, flags);
- self->text_flags = flags;
+ self->orders_state.text_flags = flags;
}
/* unknown */
- if (mixmode != self->text_mixmode)
+ if (mixmode != self->orders_state.text_mixmode)
{
present |= 0x000008;
out_uint8(self->out_s, mixmode);
- self->text_mixmode = mixmode;
+ self->orders_state.text_mixmode = mixmode;
}
- if (fg_color != self->text_fg_color)
+ if (fg_color != self->orders_state.text_fg_color)
{
present |= 0x000010;
out_uint8(self->out_s, fg_color)
out_uint8(self->out_s, fg_color >> 8)
out_uint8(self->out_s, fg_color >> 16)
- self->text_fg_color = fg_color;
+ self->orders_state.text_fg_color = fg_color;
}
- if (bg_color != self->text_bg_color)
+ if (bg_color != self->orders_state.text_bg_color)
{
present |= 0x000020;
out_uint8(self->out_s, bg_color)
out_uint8(self->out_s, bg_color >> 8)
out_uint8(self->out_s, bg_color >> 16)
- self->text_bg_color = bg_color;
+ self->orders_state.text_bg_color = bg_color;
}
- if (clip_left != self->text_clip_left)
+ if (clip_left != self->orders_state.text_clip_left)
{
present |= 0x000040;
out_uint16_le(self->out_s, clip_left);
- self->text_clip_left = clip_left;
+ self->orders_state.text_clip_left = clip_left;
}
- if (clip_top != self->text_clip_top)
+ if (clip_top != self->orders_state.text_clip_top)
{
present |= 0x000080;
out_uint16_le(self->out_s, clip_top);
- self->text_clip_top = clip_top;
+ self->orders_state.text_clip_top = clip_top;
}
- if (clip_right != self->text_clip_right)
+ if (clip_right != self->orders_state.text_clip_right)
{
present |= 0x000100;
out_uint16_le(self->out_s, clip_right);
- self->text_clip_right = clip_right;
+ self->orders_state.text_clip_right = clip_right;
}
- if (clip_bottom != self->text_clip_bottom)
+ if (clip_bottom != self->orders_state.text_clip_bottom)
{
present |= 0x000200;
out_uint16_le(self->out_s, clip_bottom);
- self->text_clip_bottom = clip_bottom;
+ self->orders_state.text_clip_bottom = clip_bottom;
}
- if (box_left != self->text_box_left)
+ if (box_left != self->orders_state.text_box_left)
{
present |= 0x000400;
out_uint16_le(self->out_s, box_left);
- self->text_box_left = box_left;
+ self->orders_state.text_box_left = box_left;
}
- if (box_top != self->text_box_top)
+ if (box_top != self->orders_state.text_box_top)
{
present |= 0x000800;
out_uint16_le(self->out_s, box_top);
- self->text_box_top = box_top;
+ self->orders_state.text_box_top = box_top;
}
- if (box_right != self->text_box_right)
+ if (box_right != self->orders_state.text_box_right)
{
present |= 0x001000;
out_uint16_le(self->out_s, box_right);
- self->text_box_right = box_right;
+ self->orders_state.text_box_right = box_right;
}
- if (box_bottom != self->text_box_bottom)
+ if (box_bottom != self->orders_state.text_box_bottom)
{
present |= 0x002000;
out_uint16_le(self->out_s, box_bottom);
- self->text_box_bottom = box_bottom;
+ self->orders_state.text_box_bottom = box_bottom;
}
- if (x != self->text_x)
+ if (x != self->orders_state.text_x)
{
present |= 0x080000;
out_uint16_le(self->out_s, x);
- self->text_x = x;
+ self->orders_state.text_x = x;
}
- if (y != self->text_y)
+ if (y != self->orders_state.text_y)
{
present |= 0x100000;
out_uint16_le(self->out_s, y);
- self->text_y = y;
+ self->orders_state.text_y = y;
}
{
/* always send text */