diff --git a/alib2cli/src/command/AlgorithmsIntrospectionCommand.h b/alib2cli/src/command/AlgorithmsIntrospectionCommand.h index 7fb1c2f9794a4111c459b261f7767f1a946d7fc9..1f6220c104253748fc50a6f0f2f62a05acc6a622 100644 --- a/alib2cli/src/command/AlgorithmsIntrospectionCommand.h +++ b/alib2cli/src/command/AlgorithmsIntrospectionCommand.h @@ -7,19 +7,23 @@ namespace cli { class AlgorithmsIntrospectionCommand : public Command { - std::string m_param; + std::unique_ptr < cli::Arg > m_param; public: - AlgorithmsIntrospectionCommand ( std::string param ) : m_param ( std::move ( param ) ) { + AlgorithmsIntrospectionCommand ( std::unique_ptr < cli::Arg > param ) : m_param ( std::move ( param ) ) { } - virtual Command::Result run ( Environment & ) const override { - if ( m_param == "" ) { + virtual Command::Result run ( Environment & environment ) const override { + std::string param; + if ( m_param != nullptr ) + param = m_param->eval ( environment ); + + if ( param == "" ) { abstraction::Registry::listAlgorithms ( ); - } else if ( m_param.find ( "::", m_param.size ( ) - 2 ) != std::string::npos ) { - abstraction::Registry::listAlgorithmGroup ( m_param ); + } else if ( param.find ( "::", param.size ( ) - 2 ) != std::string::npos ) { + abstraction::Registry::listAlgorithmGroup ( param ); } else { - abstraction::Registry::listAlgorithmOverloads ( m_param ); + throw exception::CommonException ( "Invalid Algorithm introspection param" ); } return Command::Result::OK; } diff --git a/alib2cli/src/command/CastsIntrospectionCommand.h b/alib2cli/src/command/CastsIntrospectionCommand.h index 72fee3f740a045f062dab48a076358231717a8e6..190bd60bcd229144422ef9a831481772333830b1 100644 --- a/alib2cli/src/command/CastsIntrospectionCommand.h +++ b/alib2cli/src/command/CastsIntrospectionCommand.h @@ -7,20 +7,22 @@ namespace cli { class CastsIntrospectionCommand : public Command { - std::string m_param; + std::unique_ptr < cli::Arg > m_param; bool m_from; bool m_to; public: - CastsIntrospectionCommand ( std::string param, bool from, bool to ) : m_param ( std::move ( param ) ), m_from ( from ), m_to ( to ) { + CastsIntrospectionCommand (std::unique_ptr < cli::Arg > param, bool from, bool to ) : m_param ( std::move ( param ) ), m_from ( from ), m_to ( to ) { } - virtual Command::Result run ( Environment & ) const override { + virtual Command::Result run ( Environment & environment ) const override { + std::string param = m_param->eval ( environment ); + if ( m_from ) - abstraction::Registry::listCastsFrom ( m_param ); + abstraction::Registry::listCastsFrom ( param ); if ( m_to ) - abstraction::Registry::listCastsTo ( m_param ); + abstraction::Registry::listCastsTo ( param ); return Command::Result::OK; } diff --git a/alib2cli/src/command/DataTypesIntrospectionCommand.h b/alib2cli/src/command/DataTypesIntrospectionCommand.h index 0eb6686fee74e8dcb4608f5f6ac63c2d5b1605b8..a520c4dd3dc2d83173f6c7ada2f13e2794d8c74e 100644 --- a/alib2cli/src/command/DataTypesIntrospectionCommand.h +++ b/alib2cli/src/command/DataTypesIntrospectionCommand.h @@ -7,17 +7,21 @@ namespace cli { class DataTypesIntrospectionCommand : public Command { - std::string m_param; + std::unique_ptr < cli::Arg > m_param; public: - DataTypesIntrospectionCommand ( std::string param ) : m_param ( std::move ( param ) ) { + DataTypesIntrospectionCommand ( std::unique_ptr < cli::Arg > param ) : m_param ( std::move ( param ) ) { } - virtual Command::Result run ( Environment & ) const override { - if ( m_param == "" ) { + virtual Command::Result run ( Environment & environment ) const override { + std::string param; + if ( m_param != nullptr ) + param = m_param->eval ( environment ); + + if ( param == "" ) { abstraction::Registry::listDataTypes ( ); - } else if ( m_param.find ( "::", m_param.size ( ) - 2 ) != std::string::npos ) { - abstraction::Registry::listDataTypeGroup ( m_param ); + } else if ( param.find ( "::", param.size ( ) - 2 ) != std::string::npos ) { + abstraction::Registry::listDataTypeGroup ( param ); } else { throw exception::CommonException ( "Invalid DataType introspection param" ); } diff --git a/alib2cli/src/command/HelpCommand.h b/alib2cli/src/command/HelpCommand.h index b88e3f835d3f10a789bf46c46f219784d6876776..1b9bbb0876ee00720c86de00e021ea083ca89717 100644 --- a/alib2cli/src/command/HelpCommand.h +++ b/alib2cli/src/command/HelpCommand.h @@ -7,14 +7,18 @@ namespace cli { class HelpCommand : public Command { - std::string m_command; + std::unique_ptr < cli::Arg > m_command; public: - HelpCommand ( std::string command ) : m_command ( std::move ( command ) ) { + HelpCommand ( std::unique_ptr < cli::Arg > command ) : m_command ( std::move ( command ) ) { } - virtual Command::Result run ( Environment & ) const override { - if ( m_command == "execute" ) { + virtual Command::Result run ( Environment & environment ) const override { + std::string command; + if ( m_command != nullptr ) + command = m_command->eval ( environment ); + + if ( command == "execute" ) { std::cout << "Execute command executes statements and either prints the result or writes the result to a file" << std::endl; std::cout << "statement_list:" << std::endl; std::cout << "statement ( | statement )* - at least one statement followed by a pipe separated sequence of other statements" << std::endl; @@ -53,7 +57,7 @@ public: std::cout << ">$:identifier - a value to a variable, identified by an environment variable (ResultVariableStatement)" << std::endl; std::cout << "> - a value is discarded" << std::endl; std::cout << " - an empty output specifier prints the result to the stdout (ResultPrintStatement)" << std::endl; - } else if ( m_command == "" ) { + } else if ( command == "" ) { std::cout << "Simple help for the query language" << std::endl; std::cout << "" << std::endl; std::cout << "command quit: quits the processor." << std::endl; @@ -63,7 +67,7 @@ public: std::cout << "" << std::endl; std::cout << "for details use help of individual command" << std::endl; } else { - std::cout << "The command " << m_command << " either does not exist or does not have a help entry." << std::endl; + std::cout << "The command " << command << " either does not exist or does not have a help entry." << std::endl; } return Command::Result::OK; } diff --git a/alib2cli/src/command/OverloadsIntrospectionCommand.h b/alib2cli/src/command/OverloadsIntrospectionCommand.h new file mode 100644 index 0000000000000000000000000000000000000000..a7b783aa2489e2e2772aa757232402c443907aa0 --- /dev/null +++ b/alib2cli/src/command/OverloadsIntrospectionCommand.h @@ -0,0 +1,26 @@ +#ifndef _CLI_OVERLOADS_INTROSPECTION_COMMAND_H_ +#define _CLI_OVERLOADS_INTROSPECTION_COMMAND_H_ + +#include <command/Command.h> +#include <environment/Environment.h> + +namespace cli { + +class OverloadsIntrospectionCommand : public Command { + std::unique_ptr < cli::Arg > m_param; + +public: + OverloadsIntrospectionCommand ( std::unique_ptr < cli::Arg > param ) : m_param ( std::move ( param ) ) { + } + + virtual Command::Result run ( Environment & environment ) const override { + std::string param = m_param->eval ( environment ); + + abstraction::Registry::listOverloads ( param ); + return Command::Result::OK; + } +}; + +} /* namespace cli */ + +#endif /* _CLI_OVERLOADS_INTROSPECTION_COMMAND_H_ */ diff --git a/alib2cli/src/parser/Parser.cpp b/alib2cli/src/parser/Parser.cpp index 1645afcea00750b2c14a61e07d8343d8a855386b..dd0be7d238d06aec7ae22d3c083526de65d3644b 100644 --- a/alib2cli/src/parser/Parser.cpp +++ b/alib2cli/src/parser/Parser.cpp @@ -24,6 +24,7 @@ #include <command/QuitCommand.h> #include <command/HelpCommand.h> #include <command/AlgorithmsIntrospectionCommand.h> +#include <command/OverloadsIntrospectionCommand.h> #include <command/DataTypesIntrospectionCommand.h> #include <command/CastsIntrospectionCommand.h> #include <command/SetCommand.h> @@ -57,6 +58,20 @@ std::unique_ptr < Arg > Parser::arg ( ) { } } +std::unique_ptr < Arg > Parser::optional_arg ( ) { + if ( check ( cli::Lexer::TokenType::HASH_SIGN ) ) { + match ( cli::Lexer::TokenType::HASH_SIGN ); + std::string value = getTokenValue ( ); + match ( cli::Lexer::TokenType::INTEGER, cli::Lexer::TokenType::IDENTIFIER ); + return std::make_unique < BindedArg > ( std::move ( value ) ); + } else if ( check ( cli::Lexer::TokenType::IDENTIFIER ) ) { + std::string value = matchIdentifier ( ); + return std::make_unique < ImmediateArg > ( value ); + } else { + return nullptr; + } +} + std::unique_ptr < Param > Parser::in_redirect_param ( ) { if ( check ( cli::Lexer::TokenType::LEFT_PAREN ) ) { match ( cli::Lexer::TokenType::LEFT_PAREN ); @@ -178,14 +193,6 @@ void Parser::result ( std::shared_ptr < StatementList > & list ) { } } -std::string Parser::optional_identifier ( ) { - if ( check ( cli::Lexer::TokenType::IDENTIFIER ) ) { - return matchIdentifier ( ); - } else { - return ""; - } -} - std::pair < bool, bool > Parser::introspect_cast_from_to ( ) { bool from; bool to; @@ -207,18 +214,23 @@ std::pair < bool, bool > Parser::introspect_cast_from_to ( ) { std::unique_ptr < Command > Parser::introspect_command ( ) { if ( check_nonreserved_kw ( "algorithms" ) ) { match_nonreserved_kw ( "algorithms" ); - std::string param = optional_identifier ( ); + std::unique_ptr < cli::Arg > param = optional_arg ( ); match ( cli::Lexer::TokenType::END ); return std::make_unique < AlgorithmsIntrospectionCommand > ( std::move ( param ) ); + } else if ( check_nonreserved_kw ( "overloads" ) ) { + match_nonreserved_kw ( "overloads" ); + std::unique_ptr < cli::Arg > param = arg ( ); + match ( cli::Lexer::TokenType::END ); + return std::make_unique < OverloadsIntrospectionCommand > ( std::move ( param ) ); } else if ( check_nonreserved_kw ( "datatypes" ) ) { match_nonreserved_kw ( "datatypes" ); - std::string param = optional_identifier ( ); + std::unique_ptr < cli::Arg > param = optional_arg ( ); match ( cli::Lexer::TokenType::END ); return std::make_unique < DataTypesIntrospectionCommand > ( std::move ( param ) ); } else if ( check_nonreserved_kw ( "casts" ) ) { match_nonreserved_kw ( "casts" ); std::pair < bool, bool > from_to = introspect_cast_from_to ( ); - std::string param = optional_identifier ( ); + std::unique_ptr < cli::Arg > param = arg ( ); match ( cli::Lexer::TokenType::END ); return std::make_unique < CastsIntrospectionCommand > ( std::move ( param ), from_to.first, from_to.second ); } else { @@ -239,7 +251,7 @@ std::unique_ptr < Command > Parser::parse ( ) { return std::make_unique < QuitCommand > ( ); } else if ( check_nonreserved_kw ( "help" ) ) { match_nonreserved_kw ( "help" ); - std::string command = optional_identifier ( ); + std::unique_ptr < cli::Arg > command = optional_arg ( ); match ( cli::Lexer::TokenType::END ); return std::make_unique < HelpCommand > ( std::move ( command ) ); } else if ( check_nonreserved_kw ( "introspect" ) ) { diff --git a/alib2cli/src/parser/Parser.h b/alib2cli/src/parser/Parser.h index 4fce5ef617880ef801025c536714714682bd485b..7300c00c15474c85b1c86be838597bfce6a46966 100644 --- a/alib2cli/src/parser/Parser.h +++ b/alib2cli/src/parser/Parser.h @@ -75,6 +75,8 @@ public: std::unique_ptr < Arg > arg ( ); + std::unique_ptr < Arg > optional_arg ( ); + std::unique_ptr < Param > in_redirect_param ( ); std::unique_ptr < Param > param ( ); @@ -89,8 +91,6 @@ public: void result ( std::shared_ptr < StatementList > & list ); - std::string optional_identifier ( ); - std::pair < bool, bool > introspect_cast_from_to ( ); std::unique_ptr < Command > introspect_command ( ); diff --git a/alib2common/src/abstraction/Registry.cpp b/alib2common/src/abstraction/Registry.cpp index 179b436b1e9d6ed67688b19633573552b863d169..eb33ceef83dd50f356b42feef0f91d1f16985134 100644 --- a/alib2common/src/abstraction/Registry.cpp +++ b/alib2common/src/abstraction/Registry.cpp @@ -22,10 +22,6 @@ void Registry::listAlgorithmGroup ( const std::string & group ) { AlgorithmRegistry::listGroup ( group ); } -void Registry::listAlgorithmOverloads ( const std::string & algorithm ) { - AlgorithmRegistry::listOverloads ( algorithm ); -} - void Registry::listAlgorithms ( ) { AlgorithmRegistry::list ( ); } @@ -46,6 +42,10 @@ void Registry::listCastsTo ( const std::string & type ) { CastRegistry::listTo ( type ); } +void Registry::listOverloads ( const std::string & algorithm ) { + AlgorithmRegistry::listOverloads ( algorithm ); +} + std::shared_ptr < abstraction::OperationAbstraction > Registry::getAlgorithmAbstraction ( const std::string & name, const ext::vector < std::string > & paramTypes ) { return AlgorithmRegistry::getAbstraction ( name, paramTypes ); } diff --git a/alib2common/src/abstraction/Registry.h b/alib2common/src/abstraction/Registry.h index 677da32a05366fe09af8243d4b74d84c7e713421..5a9d91b7e6bac29ed910f6396583aeaa0876a3ce 100644 --- a/alib2common/src/abstraction/Registry.h +++ b/alib2common/src/abstraction/Registry.h @@ -15,7 +15,6 @@ namespace abstraction { class Registry { public: static void listAlgorithmGroup ( const std::string & group ); - static void listAlgorithmOverloads ( const std::string & algorithm ); static void listAlgorithms ( ); static void listDataTypes ( ); @@ -24,6 +23,8 @@ public: static void listCastsFrom ( const std::string & type ); static void listCastsTo ( const std::string & type ); + static void listOverloads ( const std::string & algorithm ); + static std::shared_ptr < abstraction::OperationAbstraction > getAlgorithmAbstraction ( const std::string & name, const ext::vector < std::string > & paramTypes ); static std::shared_ptr < abstraction::OperationAbstraction > getAlgorithmAbstraction ( const std::string & name, const ext::vector < std::string > & paramTypes, bool & unwrap, bool & normalize ); static std::shared_ptr < abstraction::OperationAbstraction > getCastAbstraction ( const std::string & target, const std::string & param, bool & normalize );