]> git.tuebingen.mpg.de Git - paraslash.git/blobdiff - interactive.c
i9e: Fix a prompt display issue
[paraslash.git] / interactive.c
index 14186cd29026ba60fa9dd572e65b7d55ffc66256..ef6fc7620195188db8ccf491176142b29690a9ba 100644 (file)
@@ -290,21 +290,21 @@ static bool input_available(void)
 static void i9e_line_handler(char *line)
 {
        int ret;
+       struct btr_node *dummy = btr_new_node(&(struct btr_node_description)
+               EMBRACE(.name = "dummy line handler"));
+       i9e_attach_to_stdout(dummy);
 
        ret = i9ep->ici->line_handler(line);
        if (ret < 0)
                PARA_WARNING_LOG("%s\n", para_strerror(-ret));
        rl_set_prompt("");
        if (line) {
-               if (!*line)
-                       rl_set_prompt(i9ep->ici->prompt);
-               else
+               if (*line)
                        add_history(line);
                free(line);
-       } else {
-               rl_set_prompt("");
+       } else
                i9ep->input_eof = true;
-       }
+       btr_remove_node(&dummy);
 }
 
 static int i9e_post_select(__a_unused struct sched *s, __a_unused struct task *t)
@@ -447,8 +447,7 @@ int i9e_open(struct i9e_client_info *ici, struct sched *s)
        if (ret < 0)
                return ret;
        i9ep->task.pre_select = i9e_pre_select;
-       i9ep->task.new_post_select = i9e_post_select;
-       i9ep->task.post_select = NULL;
+       i9ep->task.post_select = i9e_post_select;
        sprintf(i9ep->task.status, "i9e");
        register_task(s, &i9ep->task);
        rl_readline_name = "para_i9e";