/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* c_matching.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: alao +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2016/10/15 13:27:14 by alao #+# #+# */ /* Updated: 2017/03/09 17:25:06 by gwojda ### ########.fr */ /* */ /* ************************************************************************** */ #include "completion.h" static int c_exclusion_folder(t_comp *c) { DIR *rep; char *tmp; char *tmp2; tmp = ft_strjoin(c->cpath, c->match); tmp2 = NULL; if (tmp[ft_strlen(tmp) - 1] == '/') return (0); if ((rep = opendir(tmp)) && (!closedir(rep))) { tmp ? ft_memdel((void *)&tmp) : (0); tmp2 = ft_strjoin(c->match, "/"); c_updater(c, tmp2); tmp2 ? ft_memdel((void *)&tmp2) : (0); return (1); } tmp ? ft_memdel((void *)&tmp) : (0); tmp ? ft_memdel((void *)&tmp) : (0); return (0); } /* ** chevron y es-tu ??? */ int c_chevron(t_comp *c) { size_t pos; pos = c->ircmd; while (pos) { if (c->rcmd[pos] == '<' || c->rcmd[pos] == '>') return (1); --pos; } if (c->rcmd[pos] == '<' || c->rcmd[pos] == '>') return (1); return (0); } /* ** Start the parsing for the autocompletion. ** Check the first char of the c->rcmd for a . or /. to see if it's a local ** path to search even if there's no space in the command. ** If a space is found in the command. The function will assume it's a binary ** completion that is needed. Else the c_seek_files() is called to search for ** local path along with the binary part separated. ** If any of the other part successfully created a list, the c_sizing is called ** and 1 is returned. The last condition also check is the structure still ** exist. It's only when the c_rematch() called it that it can be the case. ** Else 0 is returned. */ static char *c_current_words(t_comp *c) { int pos; pos = c->ircmd; while (pos && c->rcmd[pos] != ' ') --pos; if (c->rcmd[pos] == ' ') ++pos; return (c->rcmd + pos); } int c_matching(t_data *s, t_comp *c) { char *current_word; char *tmp; current_word = c_current_words(c); if (ft_strchr(c->rcmd, '/')) { c->cpath = ft_strndup(current_word, ft_strrchr(c->rcmd, '/') - current_word + 1); if (current_word[0] == '~') { tmp = c->cpath; c->cpath = ft_str3join(getenv("PWD"), "/", c->cpath + 2); free(tmp); } !c->match ? c->match = ft_strdupi_w(ft_strrchr(c->rcmd, '/') + 1) : 0; c_parser(c, c->cpath, c->match); c_exclusion_folder(c); } else if (ft_strchr(c->rcmd, '$')) c_seek_env(c, current_word); else if (c->rcmd[0] != '.' && !(ft_strchr(c->rcmd, ' ')) && !c_chevron(c)) c_seek_binary(s, c); else c_seek_files(s, c); if (s->comp && s->comp->lst) { c_sizing(c); return (1); } return (0); }