prompt zsh style : quelques petits trucs a revoir

This commit is contained in:
gwojda 2017-02-10 18:22:50 +01:00
parent 74713d84b0
commit ab66992500
2 changed files with 61 additions and 13 deletions

@ -1 +1 @@
Subproject commit b53fcb9db8b4baf53c73b17726f1740c4af12be0
Subproject commit acd7e54fb8045b3958dd239d469f1476404468b7

View file

@ -1,22 +1,62 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* prompt.c :+: :+: :+: */
/* ftprompt.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: gwojda <gwojda@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2016/12/13 13:51:33 by gwojda #+# #+# */
/* Updated: 2017/02/05 17:42:23 by gwojda ### ########.fr */
/* Updated: 2017/02/10 18:19:16 by gwojda ### ########.fr */
/* */
/* ************************************************************************** */
#include "minishell.h"
static int ft_git_status(void)
{
int pip[2];
char *tmp;
char *line;
pid_t soon;
char *exec[] = {"git", "status", "--porcelain", "--branch", NULL};
pipe(pip);
if ((soon = fork()))
{
wait(&soon);
if (WEXITSTATUS(soon))
return (0);
close(pip[1]);
get_next_line(pip[0], &line);
tmp = line;
if (ft_strrchr(line, '/'))
line = ft_strdup(ft_strrchr(line, '/') + 1);
ft_printf("\x1b[38;5;47mgit:(\x1b[38;5;203m%s\x1b[38;5;47m)", line);
free(tmp);
if (!get_next_line(pip[0], &tmp))
printf("\x1b[38;5;83m %C ", L'');
else
{
printf("\x1b[38;5;1m %C ", L'');
free(tmp);
}
fflush(NULL);
}
else
{
dup2(pip[1], 1);
dup2(pip[1], 2);
close(pip[0]);
execve("/usr/bin/git", exec, data_singleton()->env);
}
return (ft_strlen(line) + 8);
}
/*
**ft_printf de la lib bug avec unicode
*/
static void ft_get_date(void)
static int ft_get_date(void)
{
time_t t;
struct tm tm;
@ -32,6 +72,7 @@ static void ft_get_date(void)
else
printf("\x1b[38;5;184m%C ", L'');
fflush(NULL);
return (10);
}
static int ft_currend_dir(void)
@ -47,21 +88,28 @@ static int ft_currend_dir(void)
j = ft_strlen(env[i]);
while (j && env[i][j] != '/')
--j;
ft_putstr(env[i] + j + 1);
ft_printf("%s ", env[i] + j + 1);
return (ft_strlen(env[i] + j + 1));
}
void ft_prompt(void)
void ft_prompt()
{
int ret;
int ret;
ret = 0;
do_job_notification();
ft_get_date();
ft_putstr("\x1b[38;5;254m");
ret = ft_currend_dir();
ft_putstr("\x1b[38;5;184m");
printf(" %C ", L'');
// ft_get_date();
if (ft_getenv(data_singleton()->env, "?") && ft_atoi(ft_getenv(data_singleton()->env, "?")))
printf("\x1b[38;5;1m%C ", L'');
else
printf("\x1b[38;5;10m%C ", L'');
fflush(NULL);
ft_putstr("\x1b[38;5;361m");
ret += ft_currend_dir();
if (!(ret += ft_git_status()))
ret += ft_get_date();
printf("\x1b[38;5;184m%C ", L'');
fflush(NULL);
ft_putstr("\033[22;37m");
data_singleton()->line.prompt_size = ret + 13;
data_singleton()->line.prompt_size = ret + 6;
}