/* Copyright (c) 2014, 2015 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 as published by the Free Software Foundation; version 2 of the License. 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 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 */ #ifndef ABSTRACT_STRING_OPTION_INCLUDED #define ABSTRACT_STRING_OPTION_INCLUDED #include #include "my_getopt.h" #include "abstract_value_option.h" #include "nullable.h" #include "instance_callback.h" namespace Mysql{ namespace Tools{ namespace Base{ namespace Options{ /** Abstract option to handle options accepting string value argument. */ template class Abstract_string_option : public Abstract_value_option { public: /** Sets value for this option. If it is specified before handling commandline options then supplied value is used as default value of this option. */ T_type* set_value(std::string value); protected: /** Constructs new string option. @param value Pointer to string object to receive option value. @param var_type my_getopt internal option type. @param name Name of option. It is used in command line option name as --name. @param desription Description of option to be printed in --help. */ Abstract_string_option( Nullable* value, ulong var_type, std::string name, std::string description); Nullable* m_destination_value; private: void string_callback(char* argument); const char* m_original_value; }; template Abstract_string_option::Abstract_string_option( Nullable* value, ulong var_type, std::string name, std::string description) : Abstract_value_option( &this->m_original_value, var_type, name, description, (uint64)NULL), m_destination_value(value) { *value= Nullable(); this->m_original_value= NULL; this->add_callback(new Instance_callback >( this, &Abstract_string_option::string_callback)); } template T_type* Abstract_string_option::set_value( std::string value) { *this->m_destination_value= Nullable(value); this->m_original_value= this->m_destination_value->value().c_str(); this->m_option_structure.def_value= (uint64)this->m_destination_value ->value().c_str(); return (T_type*)this; } template void Abstract_string_option::string_callback( char* argument) { if (argument != NULL) { // Copy argument value from char* to destination string. *this->m_destination_value= Nullable(this->m_original_value); } else { // There is no argument supplied, we shouldn't change default value. } } } } } } #endif