Skip to content

Commit

Permalink
Added little improvements: free line_read before re-using it & check …
Browse files Browse the repository at this point in the history
…for nullptr read_line before using it
  • Loading branch information
cogutvalera committed Jun 2, 2019
1 parent 59ad730 commit 73ae27e
Showing 1 changed file with 26 additions and 0 deletions.
26 changes: 26 additions & 0 deletions src/rpc/cli.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -316,6 +316,7 @@ void cli::getline( const std::string& prompt, std::string& line)
if( _isatty( _fileno( stdin ) ) )
#endif
{
<<<<<<< HEAD
if( _getline_thread )
{
_getline_thread->async( [&prompt,&line](){
Expand All @@ -338,6 +339,31 @@ void cli::getline( const std::string& prompt, std::string& line)
free(line_read);
}).wait();
}
=======
rl_set_complete_func(my_rl_complete);
rl_set_list_possib_func(cli_completion);

static fc::thread getline_thread("getline");
getline_thread.async( [&](){
char* line_read = nullptr;
std::cout.flush(); //readline doesn't use cin, so we must manually flush _out
line_read = readline(prompt.c_str());
if( line_read == nullptr )
FC_THROW_EXCEPTION( fc::eof_exception, "" );
line = line_read;
// we don't need here to add line in editline's history, cause it will be doubled
free(line_read);
if (cli_check_secret(line_read)) {
el_no_echo = 1;
line_read = readline("Enter password: ");
if( line_read == nullptr )
FC_THROW_EXCEPTION( fc::eof_exception, "" );
el_no_echo = 0;
line = line + ' ' + line_read;
}
free(line_read);
}).wait();
>>>>>>> Added little improvements: free line_read before re-using it & check for nullptr read_line before using it
}
else
#endif
Expand Down

0 comments on commit 73ae27e

Please sign in to comment.