mirror of https://github.com/FreeRDP/FreeRDP
libfreerdp-core: parsing of alternate secondary window orders
This commit is contained in:
parent
c42008ce80
commit
fbc033cd75
|
@ -84,6 +84,8 @@ set(LIBFREERDP_CORE_SRCS
|
|||
update.h
|
||||
vchan.c
|
||||
vchan.h
|
||||
window.c
|
||||
window.h
|
||||
)
|
||||
|
||||
add_library(freerdp-core SHARED ${LIBFREERDP_CORE_SRCS})
|
||||
|
|
|
@ -17,6 +17,8 @@
|
|||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "window.h"
|
||||
|
||||
#include "orders.h"
|
||||
|
||||
uint8 PRIMARY_DRAWING_ORDER_STRINGS[][20] =
|
||||
|
@ -1912,6 +1914,7 @@ void update_recv_altsec_order(rdpUpdate* update, STREAM* s, uint8 flags)
|
|||
break;
|
||||
|
||||
case ORDER_TYPE_WINDOW:
|
||||
update_recv_altsec_window_order(update, s);
|
||||
break;
|
||||
|
||||
case ORDER_TYPE_COMPDESK_FIRST:
|
||||
|
|
|
@ -0,0 +1,316 @@
|
|||
/**
|
||||
* FreeRDP: A Remote Desktop Protocol Client
|
||||
* Windowing Alternate Secondary Orders
|
||||
*
|
||||
* Copyright 2011 Marc-Andre Moreau <marcandre.moreau@gmail.com>
|
||||
* Copyright 2011 Roman Barabanov <romanbarabanov@gmail.com>
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <freerdp/utils/memory.h>
|
||||
|
||||
#include "window.h"
|
||||
|
||||
void update_read_unicode_string(STREAM* s, UNICODE_STRING* unicode_string)
|
||||
{
|
||||
stream_read_uint16(s, unicode_string->cbString); /* cbString (2 bytes) */
|
||||
|
||||
if (unicode_string->string == NULL)
|
||||
unicode_string->string = (uint8*) xmalloc(unicode_string->cbString);
|
||||
else
|
||||
unicode_string->string = (uint8*) xrealloc(unicode_string->string, unicode_string->cbString);
|
||||
|
||||
stream_read(s, unicode_string->string, unicode_string->cbString);
|
||||
}
|
||||
|
||||
void update_read_rectangle_16(STREAM* s, RECTANGLE_16* rectangle_16)
|
||||
{
|
||||
stream_read_uint16(s, rectangle_16->left); /* left (2 bytes) */
|
||||
stream_read_uint16(s, rectangle_16->top); /* top (2 bytes) */
|
||||
stream_read_uint16(s, rectangle_16->right); /* right (2 bytes) */
|
||||
stream_read_uint16(s, rectangle_16->bottom); /* bottom (2 bytes) */
|
||||
}
|
||||
|
||||
void update_read_icon_info(STREAM* s, ICON_INFO* icon_info)
|
||||
{
|
||||
stream_read_uint16(s, icon_info->cacheEntry); /* cacheEntry (2 bytes) */
|
||||
stream_read_uint8(s, icon_info->cacheId); /* cacheId (1 byte) */
|
||||
stream_read_uint8(s, icon_info->bpp); /* bpp (1 byte) */
|
||||
stream_read_uint16(s, icon_info->width); /* width (2 bytes) */
|
||||
stream_read_uint16(s, icon_info->height); /* height (2 bytes) */
|
||||
stream_read_uint16(s, icon_info->cbColorTable); /* cbColorTable (2 bytes) */
|
||||
stream_read_uint16(s, icon_info->cbBitsMask); /* cbBitsMask (2 bytes) */
|
||||
stream_read_uint16(s, icon_info->cbBitsColor); /* cbBitsColor (2 bytes) */
|
||||
|
||||
/* bitsMask */
|
||||
if (icon_info->bitsMask == NULL)
|
||||
icon_info->bitsMask = (uint8*) xmalloc(icon_info->cbBitsMask);
|
||||
else
|
||||
icon_info->bitsMask = (uint8*) xrealloc(icon_info->bitsMask, icon_info->cbBitsMask);
|
||||
stream_read(s, icon_info->bitsMask, icon_info->cbBitsMask);
|
||||
|
||||
/* colorTable */
|
||||
if (icon_info->colorTable == NULL)
|
||||
icon_info->colorTable = (uint8*) xmalloc(icon_info->cbColorTable);
|
||||
else
|
||||
icon_info->colorTable = (uint8*) xrealloc(icon_info->colorTable, icon_info->cbColorTable);
|
||||
stream_read(s, icon_info->colorTable, icon_info->cbColorTable);
|
||||
|
||||
/* bitsColor */
|
||||
if (icon_info->bitsColor == NULL)
|
||||
icon_info->bitsColor = (uint8*) xmalloc(icon_info->cbBitsColor);
|
||||
else
|
||||
icon_info->bitsColor = (uint8*) xrealloc(icon_info->bitsColor, icon_info->cbBitsColor);
|
||||
stream_read(s, icon_info->bitsColor, icon_info->cbBitsColor);
|
||||
}
|
||||
|
||||
void update_read_cached_icon_info(STREAM* s, CACHED_ICON_INFO* cached_icon_info)
|
||||
{
|
||||
stream_read_uint16(s, cached_icon_info->cacheEntry); /* cacheEntry (2 bytes) */
|
||||
stream_read_uint8(s, cached_icon_info->cacheId); /* cacheId (1 byte) */
|
||||
}
|
||||
|
||||
void update_read_notify_icon_infotip(STREAM* s, NOTIFY_ICON_INFOTIP* notify_icon_infotip)
|
||||
{
|
||||
stream_read_uint32(s, notify_icon_infotip->timeout); /* timeout (4 bytes) */
|
||||
stream_read_uint32(s, notify_icon_infotip->flags); /* infoFlags (4 bytes) */
|
||||
update_read_unicode_string(s, ¬ify_icon_infotip->text); /* infoTipText */
|
||||
update_read_unicode_string(s, ¬ify_icon_infotip->title); /* title */
|
||||
}
|
||||
|
||||
void update_read_window_state_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo, WINDOW_STATE_ORDER* window_state)
|
||||
{
|
||||
int i;
|
||||
int size;
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_OWNER)
|
||||
stream_read_uint32(s, window_state->ownerWindowId); /* ownerWindowId (4 bytes) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_STYLE)
|
||||
{
|
||||
stream_read_uint32(s, window_state->style); /* style (4 bytes) */
|
||||
stream_read_uint32(s, window_state->extendedStyle); /* extendedStyle (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_SHOW)
|
||||
stream_read_uint8(s, window_state->showState); /* showState (1 byte) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_TITLE)
|
||||
update_read_unicode_string(s, &window_state->titleInfo); /* titleInfo */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET)
|
||||
{
|
||||
stream_read_uint32(s, window_state->clientOffsetX); /* clientOffsetX (4 bytes) */
|
||||
stream_read_uint32(s, window_state->clientOffsetY); /* clientOffsetY (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE)
|
||||
{
|
||||
stream_read_uint32(s, window_state->clientAreaWidth); /* clientAreaWidth (4 bytes) */
|
||||
stream_read_uint32(s, window_state->clientAreaHeight); /* clientAreaHeight (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_RP_CONTENT)
|
||||
stream_read_uint8(s, window_state->RPContent); /* RPContent (1 byte) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_ROOT_PARENT)
|
||||
stream_read_uint32(s, window_state->rootParentHandle);/* rootParentHandle (4 bytes) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_WND_OFFSET)
|
||||
{
|
||||
stream_read_uint32(s, window_state->windowOffsetX); /* windowOffsetX (4 bytes) */
|
||||
stream_read_uint32(s, window_state->windowOffsetY); /* windowOffsetY (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_WND_CLIENT_DELTA)
|
||||
{
|
||||
stream_read_uint32(s, window_state->windowClientDeltaX); /* windowClientDeltaX (4 bytes) */
|
||||
stream_read_uint32(s, window_state->windowClientDeltaY); /* windowClientDeltaY (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_WND_SIZE)
|
||||
{
|
||||
stream_read_uint32(s, window_state->windowWidth); /* windowWidth (4 bytes) */
|
||||
stream_read_uint32(s, window_state->windowHeight); /* windowHeight (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_WND_RECTS)
|
||||
{
|
||||
stream_read_uint16(s, window_state->numWindowRects); /* numWindowRects (2 bytes) */
|
||||
|
||||
size = sizeof(RECTANGLE_16) * window_state->numWindowRects;
|
||||
|
||||
if (window_state->windowRects == NULL)
|
||||
window_state->windowRects = (RECTANGLE_16*) xmalloc(size);
|
||||
else
|
||||
window_state->windowRects = (RECTANGLE_16*) xrealloc(window_state->windowRects, size);
|
||||
|
||||
/* windowRects */
|
||||
for (i = 0; i < window_state->numWindowRects; i++)
|
||||
{
|
||||
update_read_rectangle_16(s, &window_state->windowRects[i]);
|
||||
}
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_VIS_OFFSET)
|
||||
{
|
||||
stream_read_uint32(s, window_state->visibleOffsetX); /* visibleOffsetX (4 bytes) */
|
||||
stream_read_uint32(s, window_state->visibleOffsetY); /* visibleOffsetY (4 bytes) */
|
||||
}
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_VISIBILITY)
|
||||
{
|
||||
stream_read_uint16(s, window_state->numVisibilityRects); /* numVisibilityRects (2 bytes) */
|
||||
|
||||
size = sizeof(RECTANGLE_16) * window_state->numVisibilityRects;
|
||||
|
||||
if (window_state->visibilityRects == NULL)
|
||||
window_state->visibilityRects = (RECTANGLE_16*) xmalloc(size);
|
||||
else
|
||||
window_state->visibilityRects = (RECTANGLE_16*) xrealloc(window_state->visibilityRects, size);
|
||||
|
||||
/* visibilityRects */
|
||||
for (i = 0; i < window_state->numVisibilityRects; i++)
|
||||
{
|
||||
update_read_rectangle_16(s, &window_state->visibilityRects[i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void update_read_window_icon_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo, WINDOW_ICON_ORDER* window_icon)
|
||||
{
|
||||
update_read_icon_info(s, &window_icon->iconInfo); /* iconInfo (ICON_INFO) */
|
||||
}
|
||||
|
||||
void update_read_window_cached_icon_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo, WINDOW_CACHED_ICON_ORDER* window_cached_icon)
|
||||
{
|
||||
update_read_cached_icon_info(s, &window_cached_icon->cachedIcon); /* cachedIcon (CACHED_ICON_INFO) */
|
||||
}
|
||||
|
||||
void update_read_window_deleted_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo)
|
||||
{
|
||||
/* window deletion event */
|
||||
}
|
||||
|
||||
void update_read_window_info_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo)
|
||||
{
|
||||
WINDOW_STATE_ORDER window_state;
|
||||
WINDOW_ICON_ORDER window_icon;
|
||||
WINDOW_CACHED_ICON_ORDER window_cached_icon;
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_ICON)
|
||||
update_read_window_icon_order(s, orderInfo, &window_icon);
|
||||
else if (orderInfo->fieldFlags & WINDOW_ORDER_CACHED_ICON)
|
||||
update_read_window_cached_icon_order(s, orderInfo, &window_cached_icon);
|
||||
else if (orderInfo->fieldFlags & WINDOW_ORDER_STATE_DELETED)
|
||||
update_read_window_deleted_order(s, orderInfo);
|
||||
else
|
||||
update_read_window_state_order(s, orderInfo, &window_state);
|
||||
}
|
||||
|
||||
void update_read_notification_icon_state_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo, NOTIFY_ICON_STATE_ORDER* notify_icon_state)
|
||||
{
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_NOTIFY_VERSION)
|
||||
stream_read_uint32(s, notify_icon_state->version); /* version (4 bytes) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_NOTIFY_TIP)
|
||||
update_read_unicode_string(s, ¬ify_icon_state->toolTip); /* toolTip (UNICODE_STRING) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP)
|
||||
update_read_notify_icon_infotip(s, ¬ify_icon_state->infoTip); /* infoTip (NOTIFY_ICON_INFOTIP) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_NOTIFY_STATE)
|
||||
stream_read_uint32(s, notify_icon_state->state); /* state (4 bytes) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_ICON)
|
||||
update_read_icon_info(s, ¬ify_icon_state->icon); /* icon (ICON_INFO) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_CACHED_ICON)
|
||||
update_read_cached_icon_info(s, ¬ify_icon_state->cachedIcon); /* cachedIcon (CACHED_ICON_INFO) */
|
||||
}
|
||||
|
||||
void update_read_notification_icon_deleted_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo)
|
||||
{
|
||||
/* notification icon deletion event */
|
||||
}
|
||||
|
||||
void update_read_notification_icon_info_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo)
|
||||
{
|
||||
NOTIFY_ICON_STATE_ORDER notify_icon_state_order;
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_STATE_DELETED)
|
||||
update_read_notification_icon_deleted_order(s, orderInfo);
|
||||
else
|
||||
update_read_notification_icon_state_order(s, orderInfo, ¬ify_icon_state_order);
|
||||
}
|
||||
|
||||
void update_read_desktop_actively_monitored_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo, MONITORED_DESKTOP_ORDER* monitored_desktop)
|
||||
{
|
||||
int i;
|
||||
int size;
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_DESKTOP_ACTIVE_WND)
|
||||
stream_read_uint32(s, monitored_desktop->activeWindowId); /* activeWindowId (4 bytes) */
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_DESKTOP_ZORDER)
|
||||
{
|
||||
stream_read_uint8(s, monitored_desktop->numWindowIds); /* numWindowIds (1 byte) */
|
||||
|
||||
size = sizeof(uint32) * monitored_desktop->numWindowIds;
|
||||
|
||||
if (monitored_desktop->windowIds == NULL)
|
||||
monitored_desktop->windowIds = (uint32*) xmalloc(size);
|
||||
else
|
||||
monitored_desktop->windowIds = (uint32*) xrealloc(monitored_desktop->windowIds, size);
|
||||
|
||||
/* windowIds */
|
||||
for (i = 0; i < monitored_desktop->numWindowIds; i++)
|
||||
{
|
||||
stream_read_uint32(s, monitored_desktop->windowIds[i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void update_read_desktop_non_monitored_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo)
|
||||
{
|
||||
/* non-monitored desktop notification event */
|
||||
}
|
||||
|
||||
void update_read_desktop_info_order(STREAM* s, WINDOW_ORDER_INFO* orderInfo)
|
||||
{
|
||||
MONITORED_DESKTOP_ORDER monitored_desktop_order;
|
||||
|
||||
if (orderInfo->fieldFlags & WINDOW_ORDER_FIELD_DESKTOP_NONE)
|
||||
update_read_desktop_non_monitored_order(s, orderInfo);
|
||||
else
|
||||
update_read_desktop_actively_monitored_order(s, orderInfo, &monitored_desktop_order);
|
||||
}
|
||||
|
||||
void update_recv_altsec_window_order(rdpUpdate* update, STREAM* s)
|
||||
{
|
||||
uint16 orderSize;
|
||||
WINDOW_ORDER_INFO windowOrderInfo;
|
||||
|
||||
stream_read_uint16(s, orderSize); /* orderSize (2 bytes) */
|
||||
stream_read_uint32(s, windowOrderInfo.fieldFlags); /* FieldsPresentFlags (4 bytes) */
|
||||
stream_read_uint32(s, windowOrderInfo.windowId); /* windowId (4 bytes) */
|
||||
|
||||
if (windowOrderInfo.fieldFlags & WINDOW_ORDER_TYPE_WINDOW)
|
||||
update_read_window_info_order(s, &windowOrderInfo);
|
||||
else if (windowOrderInfo.fieldFlags & WINDOW_ORDER_TYPE_NOTIFY)
|
||||
update_read_notification_icon_info_order(s, &windowOrderInfo);
|
||||
else if (windowOrderInfo.fieldFlags & WINDOW_ORDER_TYPE_DESKTOP)
|
||||
update_read_desktop_info_order(s, &windowOrderInfo);
|
||||
}
|
||||
|
|
@ -0,0 +1,179 @@
|
|||
/**
|
||||
* FreeRDP: A Remote Desktop Protocol Client
|
||||
* Windowing Alternate Secondary Orders
|
||||
*
|
||||
* Copyright 2011 Marc-Andre Moreau <marcandre.moreau@gmail.com>
|
||||
* Copyright 2011 Roman Barabanov <romanbarabanov@gmail.com>
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef __WINDOW_H
|
||||
#define __WINDOW_H
|
||||
|
||||
#include "update.h"
|
||||
|
||||
#include <freerdp/utils/stream.h>
|
||||
|
||||
/* Window Order Header Flags */
|
||||
#define WINDOW_ORDER_TYPE_WINDOW 0x01000000
|
||||
#define WINDOW_ORDER_TYPE_NOTIFY 0x02000000
|
||||
#define WINDOW_ORDER_TYPE_DESKTOP 0x04000000
|
||||
#define WINDOW_ORDER_STATE_NEW 0x10000000
|
||||
#define WINDOW_ORDER_STATE_DELETED 0x20000000
|
||||
#define WINDOW_ORDER_FIELD_OWNER 0x00000002
|
||||
#define WINDOW_ORDER_FIELD_STYLE 0x00000008
|
||||
#define WINDOW_ORDER_FIELD_SHOW 0x00000010
|
||||
#define WINDOW_ORDER_FIELD_TITLE 0x00000004
|
||||
#define WINDOW_ORDER_FIELD_CLIENT_AREA_OFFSET 0x00004000
|
||||
#define WINDOW_ORDER_FIELD_CLIENT_AREA_SIZE 0x00010000
|
||||
#define WINDOW_ORDER_FIELD_RP_CONTENT 0x00020000
|
||||
#define WINDOW_ORDER_FIELD_ROOT_PARENT 0x00040000
|
||||
#define WINDOW_ORDER_FIELD_WND_OFFSET 0x00000800
|
||||
#define WINDOW_ORDER_FIELD_WND_CLIENT_DELTA 0x00008000
|
||||
#define WINDOW_ORDER_FIELD_WND_SIZE 0x00000400
|
||||
#define WINDOW_ORDER_FIELD_WND_RECTS 0x00000100
|
||||
#define WINDOW_ORDER_FIELD_VIS_OFFSET 0x00001000
|
||||
#define WINDOW_ORDER_FIELD_VISIBILITY 0x00000200
|
||||
#define WINDOW_ORDER_FIELD_ICON_BIG 0x00002000
|
||||
#define WINDOW_ORDER_ICON 0x40000000
|
||||
#define WINDOW_ORDER_CACHED_ICON 0x80000000
|
||||
#define WINDOW_ORDER_FIELD_NOTIFY_VERSION 0x00000008
|
||||
#define WINDOW_ORDER_FIELD_NOTIFY_TIP 0x00000001
|
||||
#define WINDOW_ORDER_FIELD_NOTIFY_INFO_TIP 0x00000002
|
||||
#define WINDOW_ORDER_FIELD_NOTIFY_STATE 0x00000004
|
||||
#define WINDOW_ORDER_FIELD_DESKTOP_NONE 0x00000001
|
||||
#define WINDOW_ORDER_FIELD_DESKTOP_HOOKED 0x00000002
|
||||
#define WINDOW_ORDER_FIELD_DESKTOP_ARC_COMPLETED 0x00000004
|
||||
#define WINDOW_ORDER_FIELD_DESKTOP_ARC_BEGAN 0x00000008
|
||||
#define WINDOW_ORDER_FIELD_DESKTOP_ZORDER 0x00000010
|
||||
#define WINDOW_ORDER_FIELD_DESKTOP_ACTIVE_WND 0x00000020
|
||||
|
||||
struct _UNICODE_STRING
|
||||
{
|
||||
uint16 cbString;
|
||||
uint8* string;
|
||||
};
|
||||
typedef struct _UNICODE_STRING UNICODE_STRING;
|
||||
|
||||
struct _RECTANGLE_16
|
||||
{
|
||||
uint16 left;
|
||||
uint16 top;
|
||||
uint16 right;
|
||||
uint16 bottom;
|
||||
};
|
||||
typedef struct _RECTANGLE_16 RECTANGLE_16;
|
||||
|
||||
struct _ICON_INFO
|
||||
{
|
||||
uint16 cacheEntry;
|
||||
uint8 cacheId;
|
||||
uint8 bpp;
|
||||
uint16 width;
|
||||
uint16 height;
|
||||
uint16 cbColorTable;
|
||||
uint16 cbBitsMask;
|
||||
uint16 cbBitsColor;
|
||||
uint8* bitsMask;
|
||||
uint8* colorTable;
|
||||
uint8* bitsColor;
|
||||
};
|
||||
typedef struct _ICON_INFO ICON_INFO;
|
||||
|
||||
struct _CACHED_ICON_INFO
|
||||
{
|
||||
uint16 cacheEntry;
|
||||
uint8 cacheId;
|
||||
};
|
||||
typedef struct _CACHED_ICON_INFO CACHED_ICON_INFO;
|
||||
|
||||
struct _NOTIFY_ICON_INFOTIP
|
||||
{
|
||||
uint32 timeout;
|
||||
uint32 flags;
|
||||
UNICODE_STRING text;
|
||||
UNICODE_STRING title;
|
||||
};
|
||||
typedef struct _NOTIFY_ICON_INFOTIP NOTIFY_ICON_INFOTIP;
|
||||
|
||||
struct _WINDOW_ORDER_INFO
|
||||
{
|
||||
uint32 windowId;
|
||||
uint32 fieldFlags;
|
||||
uint32 notifyIconId;
|
||||
};
|
||||
typedef struct _WINDOW_ORDER_INFO WINDOW_ORDER_INFO;
|
||||
|
||||
struct _WINDOW_STATE_ORDER
|
||||
{
|
||||
uint32 ownerWindowId;
|
||||
uint32 style;
|
||||
uint32 extendedStyle;
|
||||
uint8 showState;
|
||||
UNICODE_STRING titleInfo;
|
||||
uint32 clientOffsetX;
|
||||
uint32 clientOffsetY;
|
||||
uint32 clientAreaWidth;
|
||||
uint32 clientAreaHeight;
|
||||
uint8 RPContent;
|
||||
uint32 rootParentHandle;
|
||||
uint32 windowOffsetX;
|
||||
uint32 windowOffsetY;
|
||||
uint32 windowClientDeltaX;
|
||||
uint32 windowClientDeltaY;
|
||||
uint32 windowWidth;
|
||||
uint32 windowHeight;
|
||||
uint16 numWindowRects;
|
||||
RECTANGLE_16* windowRects;
|
||||
uint32 visibleOffsetX;
|
||||
uint32 visibleOffsetY;
|
||||
uint16 numVisibilityRects;
|
||||
RECTANGLE_16* visibilityRects;
|
||||
};
|
||||
typedef struct _WINDOW_STATE_ORDER WINDOW_STATE_ORDER;
|
||||
|
||||
struct _WINDOW_ICON_ORDER
|
||||
{
|
||||
ICON_INFO iconInfo;
|
||||
};
|
||||
typedef struct _WINDOW_ICON_ORDER WINDOW_ICON_ORDER;
|
||||
|
||||
struct _WINDOW_CACHED_ICON_ORDER
|
||||
{
|
||||
CACHED_ICON_INFO cachedIcon;
|
||||
};
|
||||
typedef struct _WINDOW_CACHED_ICON_ORDER WINDOW_CACHED_ICON_ORDER;
|
||||
|
||||
struct _NOTIFY_ICON_STATE_ORDER
|
||||
{
|
||||
uint32 version;
|
||||
UNICODE_STRING toolTip;
|
||||
NOTIFY_ICON_INFOTIP infoTip;
|
||||
uint32 state;
|
||||
ICON_INFO icon;
|
||||
CACHED_ICON_INFO cachedIcon;
|
||||
};
|
||||
typedef struct _NOTIFY_ICON_STATE_ORDER NOTIFY_ICON_STATE_ORDER;
|
||||
|
||||
struct _MONITORED_DESKTOP_ORDER
|
||||
{
|
||||
uint32 activeWindowId;
|
||||
uint8 numWindowIds;
|
||||
uint32* windowIds;
|
||||
};
|
||||
typedef struct _MONITORED_DESKTOP_ORDER MONITORED_DESKTOP_ORDER;
|
||||
|
||||
void update_recv_altsec_window_order(rdpUpdate* update, STREAM* s);
|
||||
|
||||
#endif /* __WINDOW_H */
|
Loading…
Reference in New Issue