Added flag to silence command line parser logging during detection.
This commit is contained in:
parent
89f3f7d837
commit
fc9e88d64f
@ -1191,7 +1191,7 @@ static int freerdp_detect_windows_style_command_line_syntax(int argc, char** arg
|
|||||||
DWORD flags;
|
DWORD flags;
|
||||||
int detect_status;
|
int detect_status;
|
||||||
COMMAND_LINE_ARGUMENT_A* arg;
|
COMMAND_LINE_ARGUMENT_A* arg;
|
||||||
flags = COMMAND_LINE_SEPARATOR_COLON;
|
flags = COMMAND_LINE_SEPARATOR_COLON | COMMAND_LINE_SILENCE_PARSER;
|
||||||
flags |= COMMAND_LINE_SIGIL_SLASH | COMMAND_LINE_SIGIL_PLUS_MINUS;
|
flags |= COMMAND_LINE_SIGIL_SLASH | COMMAND_LINE_SIGIL_PLUS_MINUS;
|
||||||
|
|
||||||
if (ignoreUnknown)
|
if (ignoreUnknown)
|
||||||
@ -1232,7 +1232,7 @@ int freerdp_detect_posix_style_command_line_syntax(int argc, char** argv,
|
|||||||
DWORD flags;
|
DWORD flags;
|
||||||
int detect_status;
|
int detect_status;
|
||||||
COMMAND_LINE_ARGUMENT_A* arg;
|
COMMAND_LINE_ARGUMENT_A* arg;
|
||||||
flags = COMMAND_LINE_SEPARATOR_SPACE;
|
flags = COMMAND_LINE_SEPARATOR_SPACE | COMMAND_LINE_SILENCE_PARSER;
|
||||||
flags |= COMMAND_LINE_SIGIL_DASH | COMMAND_LINE_SIGIL_DOUBLE_DASH;
|
flags |= COMMAND_LINE_SIGIL_DASH | COMMAND_LINE_SIGIL_DOUBLE_DASH;
|
||||||
flags |= COMMAND_LINE_SIGIL_ENABLE_DISABLE;
|
flags |= COMMAND_LINE_SIGIL_ENABLE_DISABLE;
|
||||||
|
|
||||||
|
@ -413,7 +413,7 @@ int freerdp_detect_old_command_line_syntax(int argc, char** argv, int* count)
|
|||||||
COMMAND_LINE_ARGUMENT_A* arg;
|
COMMAND_LINE_ARGUMENT_A* arg;
|
||||||
*count = 0;
|
*count = 0;
|
||||||
detect_status = 0;
|
detect_status = 0;
|
||||||
flags = COMMAND_LINE_SEPARATOR_SPACE;
|
flags = COMMAND_LINE_SEPARATOR_SPACE | COMMAND_LINE_SILENCE_PARSER;
|
||||||
flags |= COMMAND_LINE_SIGIL_DASH | COMMAND_LINE_SIGIL_DOUBLE_DASH;
|
flags |= COMMAND_LINE_SIGIL_DASH | COMMAND_LINE_SIGIL_DOUBLE_DASH;
|
||||||
flags |= COMMAND_LINE_SIGIL_NOT_ESCAPED;
|
flags |= COMMAND_LINE_SIGIL_NOT_ESCAPED;
|
||||||
settings = (rdpSettings*) calloc(1, sizeof(rdpSettings));
|
settings = (rdpSettings*) calloc(1, sizeof(rdpSettings));
|
||||||
|
@ -62,6 +62,7 @@
|
|||||||
|
|
||||||
/* Supress COMMAND_LINE_ERROR_NO_KEYWORD return. */
|
/* Supress COMMAND_LINE_ERROR_NO_KEYWORD return. */
|
||||||
#define COMMAND_LINE_IGN_UNKNOWN_KEYWORD 0x00001000
|
#define COMMAND_LINE_IGN_UNKNOWN_KEYWORD 0x00001000
|
||||||
|
#define COMMAND_LINE_SILENCE_PARSER 0x00002000
|
||||||
|
|
||||||
/* Command-Line Parsing Error Codes */
|
/* Command-Line Parsing Error Codes */
|
||||||
|
|
||||||
|
@ -49,6 +49,12 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
static void log_error(DWORD flags, LPCSTR message, int index, LPCSTR argv)
|
||||||
|
{
|
||||||
|
if ((flags & COMMAND_LINE_SILENCE_PARSER) == 0)
|
||||||
|
WLog_ERR(TAG, message, index, argv);
|
||||||
|
}
|
||||||
|
|
||||||
int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* options,
|
int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* options,
|
||||||
DWORD flags,
|
DWORD flags,
|
||||||
void* context, COMMAND_LINE_PRE_FILTER_FN_A preFilter, COMMAND_LINE_POST_FILTER_FN_A postFilter)
|
void* context, COMMAND_LINE_PRE_FILTER_FN_A preFilter, COMMAND_LINE_POST_FILTER_FN_A postFilter)
|
||||||
@ -93,7 +99,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
|
|
||||||
if (count < 0)
|
if (count < 0)
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed for index %d [%s]: PreFilter rule could not be applied", i, argv[i]);
|
log_error(flags, "Failed for index %d [%s]: PreFilter rule could not be applied", i, argv[i]);
|
||||||
status = COMMAND_LINE_ERROR;
|
status = COMMAND_LINE_ERROR;
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -138,7 +144,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
{
|
{
|
||||||
if (notescaped)
|
if (notescaped)
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Unescaped sigil", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Unescaped sigil", i, argv[i]);
|
||||||
return COMMAND_LINE_ERROR;
|
return COMMAND_LINE_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -148,7 +154,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Invalid sigil", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Invalid sigil", i, argv[i]);
|
||||||
return COMMAND_LINE_ERROR;
|
return COMMAND_LINE_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -272,7 +278,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
}
|
}
|
||||||
else if (!value_present && argument)
|
else if (!value_present && argument)
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Argument required", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Argument required", i, argv[i]);
|
||||||
return COMMAND_LINE_ERROR;
|
return COMMAND_LINE_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -281,7 +287,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
{
|
{
|
||||||
if (value && (options[j].Flags & COMMAND_LINE_VALUE_FLAG))
|
if (value && (options[j].Flags & COMMAND_LINE_VALUE_FLAG))
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Unexpected value", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Unexpected value", i, argv[i]);
|
||||||
return COMMAND_LINE_ERROR_UNEXPECTED_VALUE;
|
return COMMAND_LINE_ERROR_UNEXPECTED_VALUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -296,7 +302,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
|
|
||||||
if (!value && (options[j].Flags & COMMAND_LINE_VALUE_REQUIRED))
|
if (!value && (options[j].Flags & COMMAND_LINE_VALUE_REQUIRED))
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Missing value", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Missing value", i, argv[i]);
|
||||||
status = COMMAND_LINE_ERROR_MISSING_VALUE;
|
status = COMMAND_LINE_ERROR_MISSING_VALUE;
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -307,7 +313,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
{
|
{
|
||||||
if (options[j].Flags & (COMMAND_LINE_VALUE_FLAG | COMMAND_LINE_VALUE_BOOL))
|
if (options[j].Flags & (COMMAND_LINE_VALUE_FLAG | COMMAND_LINE_VALUE_BOOL))
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Unexpected value", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Unexpected value", i, argv[i]);
|
||||||
return COMMAND_LINE_ERROR_UNEXPECTED_VALUE;
|
return COMMAND_LINE_ERROR_UNEXPECTED_VALUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -352,7 +358,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
|
|
||||||
if (count < 0)
|
if (count < 0)
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: PostFilter rule could not be applied", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: PostFilter rule could not be applied", i, argv[i]);
|
||||||
status = COMMAND_LINE_ERROR;
|
status = COMMAND_LINE_ERROR;
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
@ -370,7 +376,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
|||||||
|
|
||||||
if (!found && (flags & COMMAND_LINE_IGN_UNKNOWN_KEYWORD) == 0)
|
if (!found && (flags & COMMAND_LINE_IGN_UNKNOWN_KEYWORD) == 0)
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "Failed at index %d [%s]: Unexpected keyword", i, argv[i]);
|
log_error(flags, "Failed at index %d [%s]: Unexpected keyword", i, argv[i]);
|
||||||
return COMMAND_LINE_ERROR_NO_KEYWORD;
|
return COMMAND_LINE_ERROR_NO_KEYWORD;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user