diff options
author | jethro <jtg@xtrabass.com> | 2017-05-29 18:39:49 -0400 |
---|---|---|
committer | jethro <jtg@xtrabass.com> | 2017-06-18 10:08:37 -0400 |
commit | e1f3dfccc8a099eb08e0d9ef758b216d035afd78 (patch) | |
tree | abf35aacb54779d49ef4616d7a2b13ed718fc709 /contrib/epee/include/readline_buffer.h | |
parent | Merge pull request #2055 (diff) | |
download | monero-e1f3dfccc8a099eb08e0d9ef758b216d035afd78.tar.xz |
Add readline support to cli
This PR adds readline support to the daemon and monero-wallet-cli. Only
GNU readline is supported (e.g. not libedit) and there are cmake checks
to ensure this.
There is a cmake variable, Readline_ROOT_DIR that can specify a
directory to find readline, otherwise some default paths are searched.
There is also a cmake option, USE_READLINE, that defaults to ON. If set
to ON, if readline is not found, the build continues but without
readline support.
One negative side effect of using readline is that the color prompt in
the wallet-cli now has no color and just uses terminal default. I know
how to fix this but it's quite a big change so will tackle another time.
Diffstat (limited to '')
-rw-r--r-- | contrib/epee/include/readline_buffer.h | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/contrib/epee/include/readline_buffer.h b/contrib/epee/include/readline_buffer.h new file mode 100644 index 000000000..7d929bc4c --- /dev/null +++ b/contrib/epee/include/readline_buffer.h @@ -0,0 +1,40 @@ +#pragma once + +#include <streambuf> +#include <sstream> +#include <iostream> + +namespace rdln +{ + class readline_buffer : public std::stringbuf + { + public: + readline_buffer(); + void start(); + void stop(); + int process(); + bool is_running() + { + return m_cout_buf != NULL; + } + void get_line(std::string& line); + void set_prompt(const std::string& prompt); + + protected: + virtual int sync(); + + private: + std::streambuf* m_cout_buf; + }; + + class suspend_readline + { + public: + suspend_readline(); + ~suspend_readline(); + private: + readline_buffer* m_buffer; + bool m_restart; + }; +} + |