summaryrefslogtreecommitdiffstats
path: root/src/m_prompt.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/m_prompt.c')
-rw-r--r--src/m_prompt.c32
1 files changed, 29 insertions, 3 deletions
diff --git a/src/m_prompt.c b/src/m_prompt.c
index e36a07e..0fbd9f2 100644
--- a/src/m_prompt.c
+++ b/src/m_prompt.c
@@ -25,7 +25,7 @@
#include "s_struct.h"
#include "u_vars.h"
-static void m_subst_prompt_rice(char var[], t_msh *msh)
+static void m_subst_prompt_rice(char var[], t_msh *msh)
{
size_t i;
@@ -43,7 +43,7 @@ static void m_subst_prompt_rice(char var[], t_msh *msh)
}
}
-static void m_update_psx(unsigned char x, t_msh *msh)
+static void m_update_psx(unsigned char x, t_msh *msh)
{
char var[ARG_MAX];
char psx[5];
@@ -59,7 +59,33 @@ static void m_update_psx(unsigned char x, t_msh *msh)
ft_strlcpy(msh->ps[x - 1], var, 255);
}
-void m_prompt_psx(unsigned char x, t_msh *msh)
+unsigned int m_plen(char *prompt)
+{
+ unsigned int i;
+ unsigned int size;
+
+ i = 0;
+ size = 0;
+ while (prompt[i] != '\0')
+ {
+ if (prompt[i] == 27)
+ {
+ while (prompt[i] != 'm' && prompt[i] != '\0')
+ i++;
+ }
+ if (ft_isalnum(prompt[i]) ||
+ ft_ischarset("<>", prompt[i]))
+ {
+ size++;
+ i++;
+ }
+ else
+ i++;
+ }
+ return (size);
+}
+
+void m_prompt_psx(unsigned char x, t_msh *msh)
{
m_update_psx(x, msh);
ft_dprintf(STDERR_FILENO, "%s", msh->ps[x - 1]);