mirror of
https://github.com/mariadb-corporation/mariadb-connector-cpp.git
synced 2025-08-08 08:24:13 +00:00
226 lines
6.1 KiB
C++
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
|
|
|