⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 orders.c

📁 Linux环境下的远程登陆客户端软件,其采用RDP协议
💻 C
📖 第 1 页 / 共 2 页
字号:
	{		xfrom = x;		yfrom = y;		if (line % 4 == 0)			flags = os->data[index++];		if ((flags & 0xc0) == 0)			flags |= 0xc0;	/* none = both */		if (flags & 0x40)			x += parse_delta(os->data, &data);		if (flags & 0x80)			y += parse_delta(os->data, &data);		ui_line(opcode, xfrom, yfrom, x, y, &pen);		flags <<= 2;	}}/* Process a text order */static voidprocess_text2(STREAM s, TEXT2_ORDER * os, uint32 present, BOOL delta){	int i;	if (present & 0x000001)		in_uint8(s, os->font);	if (present & 0x000002)		in_uint8(s, os->flags);	if (present & 0x000004)		in_uint8(s, os->unknown);	if (present & 0x000008)		in_uint8(s, os->mixmode);	if (present & 0x000010)		rdp_in_colour(s, &os->fgcolour);	if (present & 0x000020)		rdp_in_colour(s, &os->bgcolour);	if (present & 0x000040)		in_uint16_le(s, os->clipleft);	if (present & 0x000080)		in_uint16_le(s, os->cliptop);	if (present & 0x000100)		in_uint16_le(s, os->clipright);	if (present & 0x000200)		in_uint16_le(s, os->clipbottom);	if (present & 0x000400)		in_uint16_le(s, os->boxleft);	if (present & 0x000800)		in_uint16_le(s, os->boxtop);	if (present & 0x001000)		in_uint16_le(s, os->boxright);	if (present & 0x002000)		in_uint16_le(s, os->boxbottom);	/*	 * Unknown members, seen when connecting to a session that was disconnected with	 * mstsc and with wintach's spreadsheet test.	 */	if (present & 0x004000)		in_uint8s(s, 1);	if (present & 0x008000)		in_uint8s(s, 1);	if (present & 0x010000)	{		in_uint8s(s, 1);	/* guessing the length here */		warning("Unknown order state member (0x010000) in text2 order.\n");	}	if (present & 0x020000)		in_uint8s(s, 4);	if (present & 0x040000)		in_uint8s(s, 4);	if (present & 0x080000)		in_uint16_le(s, os->x);	if (present & 0x100000)		in_uint16_le(s, os->y);	if (present & 0x200000)	{		in_uint8(s, os->length);		in_uint8a(s, os->text, os->length);	}	DEBUG(("TEXT2(x=%d,y=%d,cl=%d,ct=%d,cr=%d,cb=%d,bl=%d,bt=%d,bb=%d,br=%d,fg=0x%x,bg=0x%x,font=%d,fl=0x%x,mix=%d,unk=0x%x,n=%d)\n", os->x, os->y, os->clipleft, os->cliptop, os->clipright, os->clipbottom, os->boxleft, os->boxtop, os->boxright, os->boxbottom, os->fgcolour, os->bgcolour, os->font, os->flags, os->mixmode, os->unknown, os->length));	DEBUG(("Text: "));	for (i = 0; i < os->length; i++)		DEBUG(("%02x ", os->text[i]));	DEBUG(("\n"));	ui_draw_text(os->font, os->flags, os->mixmode, os->x, os->y,		     os->clipleft, os->cliptop,		     os->clipright - os->clipleft,		     os->clipbottom - os->cliptop,		     os->boxleft, os->boxtop,		     os->boxright - os->boxleft,		     os->boxbottom - os->boxtop, os->bgcolour, os->fgcolour, os->text, os->length);}/* Process a raw bitmap cache order */static voidprocess_raw_bmpcache(STREAM s){	HBITMAP bitmap;	uint16 cache_idx, bufsize;	uint8 cache_id, width, height, bpp, Bpp;	uint8 *data, *inverted;	int y;	in_uint8(s, cache_id);	in_uint8s(s, 1);	/* pad */	in_uint8(s, width);	in_uint8(s, height);	in_uint8(s, bpp);	Bpp = (bpp + 7) / 8;	in_uint16_le(s, bufsize);	in_uint16_le(s, cache_idx);	in_uint8p(s, data, bufsize);	DEBUG(("RAW_BMPCACHE(cx=%d,cy=%d,id=%d,idx=%d)\n", width, height, cache_id, cache_idx));	inverted = (uint8 *) xmalloc(width * height * Bpp);	for (y = 0; y < height; y++)	{		memcpy(&inverted[(height - y - 1) * (width * Bpp)], &data[y * (width * Bpp)],		       width * Bpp);	}	bitmap = ui_create_bitmap(width, height, inverted);	xfree(inverted);	cache_put_bitmap(cache_id, cache_idx, bitmap, 0);}/* Process a bitmap cache order */static voidprocess_bmpcache(STREAM s){	HBITMAP bitmap;	uint16 cache_idx, size;	uint8 cache_id, width, height, bpp, Bpp;	uint8 *data, *bmpdata;	uint16 bufsize, pad2, row_size, final_size;	uint8 pad1;	pad2 = row_size = final_size = 0xffff;	/* Shut the compiler up */	in_uint8(s, cache_id);	in_uint8(s, pad1);	/* pad */	in_uint8(s, width);	in_uint8(s, height);	in_uint8(s, bpp);	Bpp = (bpp + 7) / 8;	in_uint16_le(s, bufsize);	/* bufsize */	in_uint16_le(s, cache_idx);	if (g_use_rdp5)	{		size = bufsize;	}	else	{		/* Begin compressedBitmapData */		in_uint16_le(s, pad2);	/* pad */		in_uint16_le(s, size);		/*      in_uint8s(s, 4);  *//* row_size, final_size */		in_uint16_le(s, row_size);		in_uint16_le(s, final_size);	}	in_uint8p(s, data, size);	DEBUG(("BMPCACHE(cx=%d,cy=%d,id=%d,idx=%d,bpp=%d,size=%d,pad1=%d,bufsize=%d,pad2=%d,rs=%d,fs=%d)\n", width, height, cache_id, cache_idx, bpp, size, pad1, bufsize, pad2, row_size, final_size));	bmpdata = (uint8 *) xmalloc(width * height * Bpp);	if (bitmap_decompress(bmpdata, width, height, data, size, Bpp))	{		bitmap = ui_create_bitmap(width, height, bmpdata);		cache_put_bitmap(cache_id, cache_idx, bitmap, 0);	}	else	{		DEBUG(("Failed to decompress bitmap data\n"));	}	xfree(bmpdata);}/* Process a bitmap cache v2 order */static voidprocess_bmpcache2(STREAM s, uint16 flags, BOOL compressed){	HBITMAP bitmap;	int y;	uint8 cache_id, cache_idx_low, width, height, Bpp;	uint16 cache_idx, bufsize;	uint8 *data, *bmpdata, *bitmap_id;	bitmap_id = NULL;	/* prevent compiler warning */	cache_id = flags & ID_MASK;	Bpp = ((flags & MODE_MASK) >> MODE_SHIFT) - 2;	if (flags & PERSIST)	{		in_uint8p(s, bitmap_id, 8);	}	if (flags & SQUARE)	{		in_uint8(s, width);		height = width;	}	else	{		in_uint8(s, width);		in_uint8(s, height);	}	in_uint16_be(s, bufsize);	bufsize &= BUFSIZE_MASK;	in_uint8(s, cache_idx);	if (cache_idx & LONG_FORMAT)	{		in_uint8(s, cache_idx_low);		cache_idx = ((cache_idx ^ LONG_FORMAT) << 8) + cache_idx_low;	}	in_uint8p(s, data, bufsize);	DEBUG(("BMPCACHE2(compr=%d,flags=%x,cx=%d,cy=%d,id=%d,idx=%d,Bpp=%d,bs=%d)\n",	       compressed, flags, width, height, cache_id, cache_idx, Bpp, bufsize));	bmpdata = (uint8 *) xmalloc(width * height * Bpp);	if (compressed)	{		if (!bitmap_decompress(bmpdata, width, height, data, bufsize, Bpp))		{			DEBUG(("Failed to decompress bitmap data\n"));			xfree(bmpdata);			return;		}	}	else	{		for (y = 0; y < height; y++)			memcpy(&bmpdata[(height - y - 1) * (width * Bpp)],			       &data[y * (width * Bpp)], width * Bpp);	}	bitmap = ui_create_bitmap(width, height, bmpdata);	if (bitmap)	{		cache_put_bitmap(cache_id, cache_idx, bitmap, 0);		if (flags & PERSIST)			pstcache_put_bitmap(cache_id, cache_idx, bitmap_id, width, height,					    width * height * Bpp, bmpdata);	}	else	{		DEBUG(("process_bmpcache2: ui_create_bitmap failed\n"));	}	xfree(bmpdata);}/* Process a colourmap cache order */static voidprocess_colcache(STREAM s){	COLOURENTRY *entry;	COLOURMAP map;	HCOLOURMAP hmap;	uint8 cache_id;	int i;	in_uint8(s, cache_id);	in_uint16_le(s, map.ncolours);	map.colours = (COLOURENTRY *) xmalloc(sizeof(COLOURENTRY) * map.ncolours);	for (i = 0; i < map.ncolours; i++)	{		entry = &map.colours[i];		in_uint8(s, entry->blue);		in_uint8(s, entry->green);		in_uint8(s, entry->red);		in_uint8s(s, 1);	/* pad */	}	DEBUG(("COLCACHE(id=%d,n=%d)\n", cache_id, map.ncolours));	hmap = ui_create_colourmap(&map);	ui_set_colourmap(hmap);	xfree(map.colours);}/* Process a font cache order */static voidprocess_fontcache(STREAM s){	HGLYPH bitmap;	uint8 font, nglyphs;	uint16 character, offset, baseline, width, height;	int i, datasize;	uint8 *data;	in_uint8(s, font);	in_uint8(s, nglyphs);	DEBUG(("FONTCACHE(font=%d,n=%d)\n", font, nglyphs));	for (i = 0; i < nglyphs; i++)	{		in_uint16_le(s, character);		in_uint16_le(s, offset);		in_uint16_le(s, baseline);		in_uint16_le(s, width);		in_uint16_le(s, height);		datasize = (height * ((width + 7) / 8) + 3) & ~3;		in_uint8p(s, data, datasize);		bitmap = ui_create_glyph(width, height, data);		cache_put_font(font, character, offset, baseline, width, height, bitmap);	}}/* Process a secondary order */static voidprocess_secondary_order(STREAM s){	/* The length isn't calculated correctly by the server.	 * For very compact orders the length becomes negative	 * so a signed integer must be used. */	uint16 length;	uint16 flags;	uint8 type;	uint8 *next_order;	in_uint16_le(s, length);	in_uint16_le(s, flags);	/* used by bmpcache2 */	in_uint8(s, type);	next_order = s->p + (sint16) length + 7;	switch (type)	{		case RDP_ORDER_RAW_BMPCACHE:			process_raw_bmpcache(s);			break;		case RDP_ORDER_COLCACHE:			process_colcache(s);			break;		case RDP_ORDER_BMPCACHE:			process_bmpcache(s);			break;		case RDP_ORDER_FONTCACHE:			process_fontcache(s);			break;		case RDP_ORDER_RAW_BMPCACHE2:			process_bmpcache2(s, flags, False);	/* uncompressed */			break;		case RDP_ORDER_BMPCACHE2:			process_bmpcache2(s, flags, True);	/* compressed */			break;		default:			unimpl("secondary order %d\n", type);	}	s->p = next_order;}/* Process an order PDU */voidprocess_orders(STREAM s, uint16 num_orders){	RDP_ORDER_STATE *os = &g_order_state;	uint32 present;	uint8 order_flags;	int size, processed = 0;	BOOL delta;	while (processed < num_orders)	{		in_uint8(s, order_flags);		if (!(order_flags & RDP_ORDER_STANDARD))		{			error("order parsing failed\n");			break;		}		if (order_flags & RDP_ORDER_SECONDARY)		{			process_secondary_order(s);		}		else		{			if (order_flags & RDP_ORDER_CHANGE)			{				in_uint8(s, os->order_type);			}			switch (os->order_type)			{				case RDP_ORDER_TRIBLT:				case RDP_ORDER_TEXT2:					size = 3;					break;				case RDP_ORDER_PATBLT:				case RDP_ORDER_MEMBLT:				case RDP_ORDER_LINE:					size = 2;					break;				default:					size = 1;			}			rdp_in_present(s, &present, order_flags, size);			if (order_flags & RDP_ORDER_BOUNDS)			{				if (!(order_flags & RDP_ORDER_LASTBOUNDS))					rdp_parse_bounds(s, &os->bounds);				ui_set_clip(os->bounds.left,					    os->bounds.top,					    os->bounds.right -					    os->bounds.left + 1,					    os->bounds.bottom - os->bounds.top + 1);			}			delta = order_flags & RDP_ORDER_DELTA;			switch (os->order_type)			{				case RDP_ORDER_DESTBLT:					process_destblt(s, &os->destblt, present, delta);					break;				case RDP_ORDER_PATBLT:					process_patblt(s, &os->patblt, present, delta);					break;				case RDP_ORDER_SCREENBLT:					process_screenblt(s, &os->screenblt, present, delta);					break;				case RDP_ORDER_LINE:					process_line(s, &os->line, present, delta);					break;				case RDP_ORDER_RECT:					process_rect(s, &os->rect, present, delta);					break;				case RDP_ORDER_DESKSAVE:					process_desksave(s, &os->desksave, present, delta);					break;				case RDP_ORDER_MEMBLT:					process_memblt(s, &os->memblt, present, delta);					break;				case RDP_ORDER_TRIBLT:					process_triblt(s, &os->triblt, present, delta);					break;				case RDP_ORDER_POLYLINE:					process_polyline(s, &os->polyline, present, delta);					break;				case RDP_ORDER_TEXT2:					process_text2(s, &os->text2, present, delta);					break;				default:					unimpl("order %d\n", os->order_type);					return;			}			if (order_flags & RDP_ORDER_BOUNDS)				ui_reset_clip();		}		processed++;	}#if 0	/* not true when RDP_COMPRESSION is set */	if (s->p != g_next_packet)		error("%d bytes remaining\n", (int) (g_next_packet - s->p));#endif}/* Reset order state */voidreset_order_state(void){	memset(&g_order_state, 0, sizeof(g_order_state));	g_order_state.order_type = RDP_ORDER_PATBLT;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -