mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2024-12-22 21:22:37 +01:00
client: add agent prompt to display
This commit is contained in:
parent
85a1678147
commit
af14445509
@ -29,10 +29,12 @@
|
|||||||
#include <readline/readline.h>
|
#include <readline/readline.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include "agent.h"
|
||||||
#include "command.h"
|
#include "command.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
|
|
||||||
#define IWD_PROMPT COLOR_GREEN "[iwd]" COLOR_OFF "# "
|
#define IWD_PROMPT COLOR_GREEN "[iwd]" COLOR_OFF "# "
|
||||||
|
#define IWD_AGENT_PROMPT COLOR_BLUE "Passphrase: " COLOR_OFF
|
||||||
#define LINE_LEN 81
|
#define LINE_LEN 81
|
||||||
|
|
||||||
static struct l_signal *resize_signal;
|
static struct l_signal *resize_signal;
|
||||||
@ -40,6 +42,7 @@ static struct l_io *io;
|
|||||||
static char dashed_line[LINE_LEN];
|
static char dashed_line[LINE_LEN];
|
||||||
static char empty_line[LINE_LEN];
|
static char empty_line[LINE_LEN];
|
||||||
static struct l_timeout *refresh_timeout;
|
static struct l_timeout *refresh_timeout;
|
||||||
|
static struct saved_input *agent_saved_input;
|
||||||
|
|
||||||
static struct display_refresh {
|
static struct display_refresh {
|
||||||
char *family;
|
char *family;
|
||||||
@ -365,6 +368,9 @@ static void readline_callback(char *prompt)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (agent_prompt(prompt))
|
||||||
|
goto done;
|
||||||
|
|
||||||
if (!strlen(prompt))
|
if (!strlen(prompt))
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
@ -416,6 +422,69 @@ void display_disable_cmd_prompt(void)
|
|||||||
rl_redisplay();
|
rl_redisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void display_agent_prompt(const char *network_name)
|
||||||
|
{
|
||||||
|
if (agent_saved_input)
|
||||||
|
return;
|
||||||
|
|
||||||
|
display("Type the network passphrase for %s.\n", network_name);
|
||||||
|
|
||||||
|
agent_saved_input = l_new(struct saved_input, 1);
|
||||||
|
|
||||||
|
agent_saved_input->point = rl_point;
|
||||||
|
agent_saved_input->line = rl_copy_text(0, rl_end);
|
||||||
|
rl_set_prompt("");
|
||||||
|
rl_replace_line("", 0);
|
||||||
|
rl_redisplay();
|
||||||
|
|
||||||
|
rl_erase_empty_line = 0;
|
||||||
|
rl_set_prompt(IWD_AGENT_PROMPT);
|
||||||
|
rl_forced_update_display();
|
||||||
|
}
|
||||||
|
|
||||||
|
void display_agent_prompt_release(void)
|
||||||
|
{
|
||||||
|
if (!agent_saved_input)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (display_refresh.cmd) {
|
||||||
|
char *prompt;
|
||||||
|
char *text = rl_copy_text(0, rl_end);
|
||||||
|
|
||||||
|
if (text) {
|
||||||
|
prompt = l_strdup_printf(IWD_AGENT_PROMPT "%s\n",
|
||||||
|
text);
|
||||||
|
l_free(text);
|
||||||
|
} else {
|
||||||
|
prompt = IWD_AGENT_PROMPT;
|
||||||
|
}
|
||||||
|
|
||||||
|
l_queue_push_tail(display_refresh.redo_entries, prompt);
|
||||||
|
display_refresh.undo_lines++;
|
||||||
|
}
|
||||||
|
|
||||||
|
rl_erase_empty_line = 1;
|
||||||
|
|
||||||
|
rl_replace_line(agent_saved_input->line, 0);
|
||||||
|
rl_point = agent_saved_input->point;
|
||||||
|
|
||||||
|
l_free(agent_saved_input->line);
|
||||||
|
l_free(agent_saved_input);
|
||||||
|
agent_saved_input = NULL;
|
||||||
|
|
||||||
|
rl_set_prompt(IWD_PROMPT);
|
||||||
|
|
||||||
|
rl_redisplay();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool display_agent_is_active(void)
|
||||||
|
{
|
||||||
|
if (agent_saved_input)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void display_quit(void)
|
void display_quit(void)
|
||||||
{
|
{
|
||||||
rl_insert_text("quit");
|
rl_insert_text("quit");
|
||||||
@ -461,6 +530,12 @@ void display_init(void)
|
|||||||
|
|
||||||
void display_exit(void)
|
void display_exit(void)
|
||||||
{
|
{
|
||||||
|
if (agent_saved_input) {
|
||||||
|
l_free(agent_saved_input->line);
|
||||||
|
l_free(agent_saved_input);
|
||||||
|
agent_saved_input = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
l_timeout_remove(refresh_timeout);
|
l_timeout_remove(refresh_timeout);
|
||||||
refresh_timeout = NULL;
|
refresh_timeout = NULL;
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ struct command_family;
|
|||||||
#define COLOR_GRAY "\x1b[37m"
|
#define COLOR_GRAY "\x1b[37m"
|
||||||
#define COLOR_GREEN "\x1b[32m"
|
#define COLOR_GREEN "\x1b[32m"
|
||||||
#define COLOR_RED "\x1B[0;91m"
|
#define COLOR_RED "\x1B[0;91m"
|
||||||
|
#define COLOR_BLUE "\x1B[94m"
|
||||||
#define COLOR_OFF "\x1B[0m"
|
#define COLOR_OFF "\x1B[0m"
|
||||||
#define CLEAR_SCREEN "\033[2J"
|
#define CLEAR_SCREEN "\033[2J"
|
||||||
#define MARGIN " "
|
#define MARGIN " "
|
||||||
@ -46,6 +47,10 @@ void display_refresh_set_cmd(const char *family, const char *entity,
|
|||||||
void display_enable_cmd_prompt(void);
|
void display_enable_cmd_prompt(void);
|
||||||
void display_disable_cmd_prompt(void);
|
void display_disable_cmd_prompt(void);
|
||||||
|
|
||||||
|
void display_agent_prompt(const char *network_name);
|
||||||
|
void display_agent_prompt_release(void);
|
||||||
|
bool display_agent_is_active(void);
|
||||||
|
|
||||||
void display_quit(void);
|
void display_quit(void);
|
||||||
|
|
||||||
void display_init(void);
|
void display_init(void);
|
||||||
|
Loading…
Reference in New Issue
Block a user