xfreerdp, wfreerdp: Add -T option to set window title
This commit is contained in:
parent
c900284014
commit
a40f5c1718
@ -253,12 +253,12 @@ boolean wf_post_connect(freerdp* instance)
|
|||||||
wfi->hdc->hwnd->ninvalid = 0;
|
wfi->hdc->hwnd->ninvalid = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strlen(wfi->window_title) > 0)
|
if (strlen(settings->window_title) > 0)
|
||||||
_snwprintf(win_title, sizeof(win_title), L"%S", wfi->window_title);
|
_snwprintf(win_title, sizeof(win_title), L"%S", settings->window_title);
|
||||||
else if (settings->port == 3389)
|
else if (settings->port == 3389)
|
||||||
_snwprintf(win_title, sizeof(win_title) / sizeof(win_title[0]), L"%S - FreeRDP", settings->hostname);
|
_snwprintf(win_title, sizeof(win_title) / sizeof(win_title[0]), L"FreeRDP: %S", settings->hostname);
|
||||||
else
|
else
|
||||||
_snwprintf(win_title, sizeof(win_title) / sizeof(win_title[0]), L"%S:%d - FreeRDP", settings->hostname, settings->port);
|
_snwprintf(win_title, sizeof(win_title) / sizeof(win_title[0]), L"FreeRDP: %S:%d", settings->hostname, settings->port);
|
||||||
|
|
||||||
if (wfi->hwnd == 0)
|
if (wfi->hwnd == 0)
|
||||||
{
|
{
|
||||||
|
@ -91,6 +91,14 @@
|
|||||||
</para>
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
<varlistentry>
|
||||||
|
<term>-T <replaceable class="parameter">text</replaceable></term>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
Sets the window title to <replaceable class="parameter">text</replaceable>.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term>-g <replaceable class="parameter">geometry</replaceable></term>
|
<term>-g <replaceable class="parameter">geometry</replaceable></term>
|
||||||
<listitem>
|
<listitem>
|
||||||
|
@ -277,8 +277,7 @@ boolean xf_check_fds(freerdp* instance, fd_set* set)
|
|||||||
void xf_create_window(xfInfo* xfi)
|
void xf_create_window(xfInfo* xfi)
|
||||||
{
|
{
|
||||||
XEvent xevent;
|
XEvent xevent;
|
||||||
char* title;
|
char* win_title;
|
||||||
char* hostname;
|
|
||||||
int width, height;
|
int width, height;
|
||||||
|
|
||||||
width = xfi->width;
|
width = xfi->width;
|
||||||
@ -298,12 +297,19 @@ void xf_create_window(xfInfo* xfi)
|
|||||||
height = xfi->fullscreen ? HeightOfScreen(xfi->screen) : xfi->height;
|
height = xfi->fullscreen ? HeightOfScreen(xfi->screen) : xfi->height;
|
||||||
}
|
}
|
||||||
|
|
||||||
hostname = xfi->instance->settings->hostname;
|
if (strlen(xfi->instance->settings->window_title) > 0) {
|
||||||
title = xmalloc(sizeof("FreeRDP: ") + strlen(hostname));
|
win_title = xmalloc(sizeof(xfi->instance->settings->window_title));
|
||||||
sprintf(title, "FreeRDP: %s", hostname);
|
sprintf(win_title, "%s", xfi->instance->settings->window_title);
|
||||||
|
} else if (xfi->instance->settings->port == 3389) {
|
||||||
|
win_title = xmalloc(sizeof("FreeRDP: ") + strlen(xfi->instance->settings->hostname));
|
||||||
|
sprintf(win_title, "FreeRDP: %s", xfi->instance->settings->hostname);
|
||||||
|
} else {
|
||||||
|
win_title = xmalloc(sizeof("FreeRDP: ") + strlen(xfi->instance->settings->hostname) + sizeof(":00000"));
|
||||||
|
sprintf(win_title, "FreeRDP: %s:%i", xfi->instance->settings->hostname, xfi->instance->settings->port);
|
||||||
|
}
|
||||||
|
|
||||||
xfi->window = xf_CreateDesktopWindow(xfi, title, width, height, xfi->decorations);
|
xfi->window = xf_CreateDesktopWindow(xfi, win_title, width, height, xfi->decorations);
|
||||||
xfree(title);
|
xfree(win_title);
|
||||||
|
|
||||||
if (xfi->fullscreen)
|
if (xfi->fullscreen)
|
||||||
xf_SetWindowFullscreen(xfi, xfi->window, xfi->fullscreen);
|
xf_SetWindowFullscreen(xfi, xfi->window, xfi->fullscreen);
|
||||||
|
@ -227,6 +227,7 @@ struct rdp_settings
|
|||||||
uint32 percent_screen; /* 85 */
|
uint32 percent_screen; /* 85 */
|
||||||
boolean mouse_motion; /* 86 */
|
boolean mouse_motion; /* 86 */
|
||||||
uint32 paddingD[112 - 87]; /* 87 */
|
uint32 paddingD[112 - 87]; /* 87 */
|
||||||
|
char window_title[64];
|
||||||
|
|
||||||
/* Internal Parameters */
|
/* Internal Parameters */
|
||||||
char* home_path; /* 112 */
|
char* home_path; /* 112 */
|
||||||
|
@ -62,6 +62,7 @@ int freerdp_parse_args(rdpSettings* settings, int argc, char** argv,
|
|||||||
" -a: set color depth in bit, default is 16\n"
|
" -a: set color depth in bit, default is 16\n"
|
||||||
" -c: initial working directory\n"
|
" -c: initial working directory\n"
|
||||||
" -D: hide window decorations\n"
|
" -D: hide window decorations\n"
|
||||||
|
" -T: window title\n"
|
||||||
" -d: domain\n"
|
" -d: domain\n"
|
||||||
" -f: fullscreen mode\n"
|
" -f: fullscreen mode\n"
|
||||||
" -g: set geometry, using format WxH or X%% or 'workarea', default is 1024x768\n"
|
" -g: set geometry, using format WxH or X%% or 'workarea', default is 1024x768\n"
|
||||||
@ -209,6 +210,17 @@ int freerdp_parse_args(rdpSettings* settings, int argc, char** argv,
|
|||||||
{
|
{
|
||||||
settings->decorations = false;
|
settings->decorations = false;
|
||||||
}
|
}
|
||||||
|
else if (strcmp("-T", argv[index]) == 0)
|
||||||
|
{
|
||||||
|
index++;
|
||||||
|
if (index == argc)
|
||||||
|
{
|
||||||
|
printf("missing window title\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
strncpy(settings->window_title, argv[index], sizeof(settings->window_title) - 1);
|
||||||
|
settings->window_title[sizeof(settings->window_title) - 1] = 0;
|
||||||
|
}
|
||||||
else if (strcmp("-t", argv[index]) == 0)
|
else if (strcmp("-t", argv[index]) == 0)
|
||||||
{
|
{
|
||||||
index++;
|
index++;
|
||||||
|
Loading…
Reference in New Issue
Block a user