Files
mariadb-connector-cpp/test/framework/start_options.cpp
2020-03-17 15:05:27 +02:00

226 lines
6.1 KiB
C++

/*
* Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License, version 2.0, as
* published by the Free Software Foundation.
*
* This program is also distributed with certain software (including
* but not limited to OpenSSL) that is licensed under separate terms,
* as designated in a particular file or component or in included license
* documentation. The authors of MySQL hereby grant you an
* additional permission to link the program and your derivative works
* with the separately licensed software that they have included with
* MySQL.
*
* Without limiting anything contained in the foregoing, this file,
* which is part of MySQL Connector/C++, is also subject to the
* Universal FOSS Exception, version 1.0, a copy of which can be found at
* http://oss.oracle.com/licenses/universal-foss-exception.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License, version 2.0, for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "start_options.h"
namespace testsuite
{
/*** TODO figure out will i need it
* static const String::value_type * defaultUnnamedParam[]= { "dbUrl"
, "dbUser"
, "dbPasswd"
, "dbSchema" }; */
static const String::value_type * trueStrings[]= {"y", "yes", "true", "t", "1"
, NULL};
static const String::value_type * falseStrings[]= {"n", "no", "false", "f", "0"
, NULL};
bool equal2any(const ciString & val, const String::value_type * arr[])
{
while( *arr != NULL )
{
if ( val == *arr )
return true;
++arr;
}
return false;
}
StartOptions::StartOptions()
{
}
/* Last orderedParams array member must be NULL */
StartOptions::StartOptions( const String::value_type * orderedParams[]
, const Properties * defStrVals
, const std::map<String, bool>* defBoolVals )
{
while ( *orderedParams != NULL )
{
unnamedParams.push_back( *orderedParams );
++orderedParams;
}
if ( defStrVals != NULL )
defStringValues= *defStrVals;
if ( defBoolVals != NULL )
defBoolValues= *defBoolVals;
}
StartOptions::StartOptions( const List & orderedParams
, const Properties * defStrVals
, const std::map<String, bool>* defBoolVals )
{
for ( List::const_iterator cit= orderedParams.begin();
cit != orderedParams.end();
++cit )
{
unnamedParams.push_back( *cit );
}
if ( defStrVals != NULL )
defStringValues= *defStrVals;
if ( defBoolVals != NULL )
defBoolValues= *defBoolVals;
}
bool StartOptions::paramAsBool( const ciString & param ) const
{
// not actually needed. since true is default
if ( equal2any( param, trueStrings ) )
return true;
if ( equal2any( param, falseStrings ) )
return false;
return true;
}
bool StartOptions::parseParams(int paramsNumber, char** paramsValues)
{
List paramPair;
if (paramsNumber > 1)
{
List::const_iterator curParam= unnamedParams.begin();
while (--paramsNumber)
{
ciString param(*(++paramsValues));
if (param.substr(0, 2) == "--")
{
paramPair.clear();
StringUtils::split( paramPair, param.substr(2).c_str(), "=" );
// Latter shouldn't really ever happen
if ( paramPair.size() > 2 || paramPair.size() == 0 )
{
std::cerr << "Can't parse. Wrong start parameter: " << *paramsValues
<< std::endl;
return false;
}
if ( paramPair.size() == 2 )
{
sOptions[paramPair[0]]= paramPair[1];
bOptions[paramPair[0]]= paramAsBool( ciString( paramPair[1].c_str() ) );
}
else
{
BoolParamsType::const_iterator cit= defBoolValues.find( paramPair[0] );
if ( cit != defBoolValues.end() )
bOptions[paramPair[0]]= cit->second;
else
bOptions[paramPair[0]]= true;
}
}
else if ( curParam != unnamedParams.end() )
{
sOptions[ *curParam ]= String(param.c_str());
++curParam;
}
}
}
return true;
}
bool StartOptions::defaultBoolValue( const String & name ) const
{
BoolParamsType::const_iterator cit= defBoolValues.find( name );
if ( (cit) != defBoolValues.end() )
return cit->second;
return false;
}
// false is default bool value
bool StartOptions::getBool( const String & name ) const
{
BoolParamsType::const_iterator cit= bOptions.find( name );
if ( cit != bOptions.end() )
return cit->second;
return defaultBoolValue( name );
}
const String & StartOptions::defaultStringValue( const String & name ) const
{
static String empty;
Properties::const_iterator cit= defStringValues.find( name );
if ( cit != defStringValues.end() )
return cit->second;
return empty;
}
const String & StartOptions::getString( const String & param) const
{
Properties::const_iterator cit= sOptions.find( param );
if ( cit != sOptions.end() )
return cit->second;
return defaultStringValue( param );
}
int StartOptions::getInt( const String & param) const
{
return StringUtils::toInt( getString( param ) );
}
} // namespace testsuite