@ -33,7 +33,7 @@ namespace
std : : vector < std : : string > result ;
std : : vector < std : : string > result ;
( result . emplace_back ( makeString ( args ) ) , . . . ) ;
( result . emplace_back ( makeString ( args ) ) , . . . ) ;
for ( int i = 1 ; i < = std : : numeric_limits < char > : : max ( ) ; + + i )
for ( int i = 1 ; i < = std : : numeric_limits < char > : : max ( ) ; + + i )
if ( i ! = ' \\ ' & & i ! = ' " ' & & i ! = ' ' & & i ! = ' \n ' )
if ( i ! = ' & ' & & i ! = ' " ' & & i ! = ' ' & & i ! = ' \n ' )
result . push_back ( std : : string ( 1 , i ) ) ;
result . push_back ( std : : string ( 1 , i ) ) ;
return result ;
return result ;
}
}
@ -127,22 +127,22 @@ namespace
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save) " ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save) " ) ;
}
}
TEST ( OpenMWOptionsFromArguments , should_support_quoted_load_savegame_path_with_escaped_quote )
TEST ( OpenMWOptionsFromArguments , should_support_quoted_load_savegame_path_with_escaped_quote _by_ampersand )
{
{
bpo : : options_description description = makeOptionsDescription ( ) ;
bpo : : options_description description = makeOptionsDescription ( ) ;
const std : : array arguments { " openmw " , " --load-savegame " , R " ( " save \ " .omwsave " ) " };
const std : : array arguments { " openmw " , " --load-savegame " , R " ( " save & " .omwsave " ) " };
bpo : : variables_map variables ;
bpo : : variables_map variables ;
parseArgs ( arguments , variables , description ) ;
parseArgs ( arguments , variables , description ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save " . omwsave ) " );
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save " . omwsave ) " );
}
}
TEST ( OpenMWOptionsFromArguments , should_support_quoted_load_savegame_path_with_escaped_ backslash )
TEST ( OpenMWOptionsFromArguments , should_support_quoted_load_savegame_path_with_escaped_ ampersand )
{
{
bpo : : options_description description = makeOptionsDescription ( ) ;
bpo : : options_description description = makeOptionsDescription ( ) ;
const std : : array arguments { " openmw " , " --load-savegame " , R " ( " save . omwsave \ \ " ) " } ;
const std : : array arguments { " openmw " , " --load-savegame " , R " ( " save . omwsave & & " ) " } ;
bpo : : variables_map variables ;
bpo : : variables_map variables ;
parseArgs ( arguments , variables , description ) ;
parseArgs ( arguments , variables , description ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save.omwsave \ ) " ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , " save.omwsave& " ) ;
}
}
TEST ( OpenMWOptionsFromArguments , should_support_load_savegame_path_with_ampersand )
TEST ( OpenMWOptionsFromArguments , should_support_load_savegame_path_with_ampersand )
@ -274,7 +274,7 @@ namespace
TEST ( OpenMWOptionsFromConfig , should_support_confusing_savegame_path_with_lots_going_on )
TEST ( OpenMWOptionsFromConfig , should_support_confusing_savegame_path_with_lots_going_on )
{
{
bpo : : options_description description = makeOptionsDescription ( ) ;
bpo : : options_description description = makeOptionsDescription ( ) ;
std : : istringstream stream ( R " (load-savegame= " one \ " two " three " .omwsave " ) " );
std : : istringstream stream ( R " (load-savegame= " one & " two " three " .omwsave " ) " );
bpo : : variables_map variables ;
bpo : : variables_map variables ;
Files : : parseConfig ( stream , variables , description ) ;
Files : : parseConfig ( stream , variables , description ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (one " two ) " );
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (one " two ) " );
@ -283,7 +283,7 @@ namespace
TEST ( OpenMWOptionsFromConfig , should_support_confusing_savegame_path_with_even_more_going_on )
TEST ( OpenMWOptionsFromConfig , should_support_confusing_savegame_path_with_even_more_going_on )
{
{
bpo : : options_description description = makeOptionsDescription ( ) ;
bpo : : options_description description = makeOptionsDescription ( ) ;
std : : istringstream stream ( R " (load-savegame= " one \ " two " three " .omwsave " ) " );
std : : istringstream stream ( R " (load-savegame= " one & " two " three " .omwsave " ) " );
bpo : : variables_map variables ;
bpo : : variables_map variables ;
Files : : parseConfig ( stream , variables , description ) ;
Files : : parseConfig ( stream , variables , description ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (one " two ) " );
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (one " two ) " );
@ -351,22 +351,22 @@ namespace
EXPECT_THAT ( variables [ " data " ] . as < Files : : MaybeQuotedPathContainer > ( ) , ElementsAre ( IsPath ( " 1 " ) , IsPath ( " 2 " ) ) ) ;
EXPECT_THAT ( variables [ " data " ] . as < Files : : MaybeQuotedPathContainer > ( ) , ElementsAre ( IsPath ( " 1 " ) , IsPath ( " 2 " ) ) ) ;
}
}
TEST ( OpenMWOptionsFromConfig , should_support_quoted_load_savegame_path_with_escaped_quote )
TEST ( OpenMWOptionsFromConfig , should_support_quoted_load_savegame_path_with_escaped_quote _by_ampersand )
{
{
bpo : : options_description description = makeOptionsDescription ( ) ;
bpo : : options_description description = makeOptionsDescription ( ) ;
std : : istringstream stream ( R " (load-savegame= " save \ " .omwsave " ) " );
std : : istringstream stream ( R " (load-savegame= " save & " .omwsave " ) " );
bpo : : variables_map variables ;
bpo : : variables_map variables ;
Files : : parseConfig ( stream , variables , description ) ;
Files : : parseConfig ( stream , variables , description ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save " . omwsave ) " );
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save " . omwsave ) " );
}
}
TEST ( OpenMWOptionsFromConfig , should_support_quoted_load_savegame_path_with_escaped_ backslash )
TEST ( OpenMWOptionsFromConfig , should_support_quoted_load_savegame_path_with_escaped_ ampersand )
{
{
bpo : : options_description description = makeOptionsDescription ( ) ;
bpo : : options_description description = makeOptionsDescription ( ) ;
std : : istringstream stream ( R " (load-savegame= " save . omwsave \ \ " ) " ) ;
std : : istringstream stream ( R " (load-savegame= " save . omwsave & & " ) " ) ;
bpo : : variables_map variables ;
bpo : : variables_map variables ;
Files : : parseConfig ( stream , variables , description ) ;
Files : : parseConfig ( stream , variables , description ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , R " (save.omwsave \ ) " ) ;
EXPECT_EQ ( variables [ " load-savegame " ] . as < Files : : MaybeQuotedPath > ( ) . string ( ) , " save.omwsave& " ) ;
}
}
TEST ( OpenMWOptionsFromConfig , should_support_load_savegame_path_with_ampersand )
TEST ( OpenMWOptionsFromConfig , should_support_load_savegame_path_with_ampersand )