Smartcard arguments now optional.
This commit is contained in:
parent
8f024d46cf
commit
513c963670
@ -332,8 +332,7 @@ int DeviceServiceEntry(PDEVICE_SERVICE_ENTRY_POINTS pEntryPoints)
|
|||||||
length = strlen(smartcard->device.name);
|
length = strlen(smartcard->device.name);
|
||||||
smartcard->device.data = Stream_New(NULL, length + 1);
|
smartcard->device.data = Stream_New(NULL, length + 1);
|
||||||
|
|
||||||
for (i = 0; i <= length; i++)
|
Stream_Write(smartcard->device.data, "SCARD", 6);
|
||||||
Stream_Write_UINT8(smartcard->device.data, name[i] < 0 ? '_' : name[i]);
|
|
||||||
|
|
||||||
smartcard->name = NULL;
|
smartcard->name = NULL;
|
||||||
smartcard->path = NULL;
|
smartcard->path = NULL;
|
||||||
@ -342,7 +341,7 @@ int DeviceServiceEntry(PDEVICE_SERVICE_ENTRY_POINTS pEntryPoints)
|
|||||||
smartcard->path = path;
|
smartcard->path = path;
|
||||||
smartcard->name = name;
|
smartcard->name = name;
|
||||||
}
|
}
|
||||||
else
|
else if (name)
|
||||||
{
|
{
|
||||||
if (1 == sscanf(name, "%d", &ck))
|
if (1 == sscanf(name, "%d", &ck))
|
||||||
smartcard->path = name;
|
smartcard->path = name;
|
||||||
|
@ -86,7 +86,7 @@ COMMAND_LINE_ARGUMENT_A args[] =
|
|||||||
{ "clipboard", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "Redirect clipboard" },
|
{ "clipboard", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "Redirect clipboard" },
|
||||||
{ "serial", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, "tty", "Redirect serial device" },
|
{ "serial", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, "tty", "Redirect serial device" },
|
||||||
{ "parallel", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, NULL, "Redirect parallel device" },
|
{ "parallel", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, NULL, "Redirect parallel device" },
|
||||||
{ "smartcard", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, NULL, "Redirect smartcard device" },
|
{ "smartcard", COMMAND_LINE_VALUE_OPTIONAL, NULL, NULL, NULL, -1, NULL, "Redirect smartcard device" },
|
||||||
{ "printer", COMMAND_LINE_VALUE_OPTIONAL, NULL, NULL, NULL, -1, NULL, "Redirect printer device" },
|
{ "printer", COMMAND_LINE_VALUE_OPTIONAL, NULL, NULL, NULL, -1, NULL, "Redirect printer device" },
|
||||||
{ "usb", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, NULL, "Redirect USB device" },
|
{ "usb", COMMAND_LINE_VALUE_REQUIRED, NULL, NULL, NULL, -1, NULL, "Redirect USB device" },
|
||||||
{ "multitouch", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "Redirect multitouch input" },
|
{ "multitouch", COMMAND_LINE_VALUE_BOOL, NULL, BoolValueFalse, NULL, -1, NULL, "Redirect multitouch input" },
|
||||||
@ -428,6 +428,9 @@ char** freerdp_command_line_parse_comma_separated_values(char* list, int* count)
|
|||||||
|
|
||||||
nArgs = nCommas = 0;
|
nArgs = nCommas = 0;
|
||||||
|
|
||||||
|
if (!list)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
for (index = 0; list[index]; index++)
|
for (index = 0; list[index]; index++)
|
||||||
nCommas += (list[index] == ',') ? 1 : 0;
|
nCommas += (list[index] == ',') ? 1 : 0;
|
||||||
|
|
||||||
@ -550,7 +553,6 @@ int freerdp_client_command_line_post_filter(void* context, COMMAND_LINE_ARGUMENT
|
|||||||
int count;
|
int count;
|
||||||
|
|
||||||
p = freerdp_command_line_parse_comma_separated_values_offset(arg->Value, &count);
|
p = freerdp_command_line_parse_comma_separated_values_offset(arg->Value, &count);
|
||||||
fprintf(stderr, "[%s] %d %s %s %s\n", __func__, count, p[0], p[1], arg->Value);
|
|
||||||
p[0] = "smartcard";
|
p[0] = "smartcard";
|
||||||
|
|
||||||
freerdp_client_add_device_channel(settings, count, p);
|
freerdp_client_add_device_channel(settings, count, p);
|
||||||
|
Loading…
Reference in New Issue
Block a user