]> git.dkaiser.de - 42/pipex.git/commitdiff
Put env util functions in separate file input_handling
authorDominik Kaiser <dkaiser@3-F-2.42heilbronn.de>
Thu, 2 May 2024 14:47:43 +0000 (16:47 +0200)
committerDominik Kaiser <dkaiser@3-F-2.42heilbronn.de>
Thu, 2 May 2024 14:47:43 +0000 (16:47 +0200)
include/pipex.h
src/env_utils.c [new file with mode: 0644]
src/input_handling.c

index 1a79cf1d820ad30d45f54eb695c7fdd42bc2a374..8ec565db2ac5b178e6ea33d9c35ec595a2abc3a0 100644 (file)
@@ -6,14 +6,27 @@
 /*   By: dkaiser <dkaiser@student.42heilbronn.de    +#+  +:+       +#+        */
 /*                                                +#+#+#+#+#+   +#+           */
 /*   Created: 2024/04/29 14:04:28 by dkaiser           #+#    #+#             */
-/*   Updated: 2024/04/29 16:38:38 by dkaiser          ###   ########.fr       */
+/*   Updated: 2024/05/02 16:22:31 by dkaiser          ###   ########.fr       */
 /*                                                                            */
 /* ************************************************************************** */
 
 #ifndef PIPEX_H
 # define PIPEX_H
 
-# include "../libft/libft.h"
+# include "libft.h"
 # include <unistd.h>
 
+typedef struct s_pxdata
+{
+       int             in_fd;
+       int             out_fd;
+       char    **cmds;
+}                      t_pxdata;
+
+char           **get_split_path(char *envp[]);
+char           *get_pwd(char *envp[]);
+char           *find_in_path(char *cmd, char **path);
+char           *get_cmd_path(char *cmd, char **path, char *pwd);
+t_pxdata       *get_pxdata(int argc, char *argv[], char *envp[]);
+
 #endif // PIPEX_H
diff --git a/src/env_utils.c b/src/env_utils.c
new file mode 100644 (file)
index 0000000..6ad5ffc
--- /dev/null
@@ -0,0 +1,78 @@
+/* ************************************************************************** */
+/*                                                                            */
+/*                                                        :::      ::::::::   */
+/*   env_utils.c                                        :+:      :+:    :+:   */
+/*                                                    +:+ +:+         +:+     */
+/*   By: dkaiser <dkaiser@student.42heilbronn.de    +#+  +:+       +#+        */
+/*                                                +#+#+#+#+#+   +#+           */
+/*   Created: 2024/05/02 16:19:31 by dkaiser           #+#    #+#             */
+/*   Updated: 2024/05/02 16:22:34 by dkaiser          ###   ########.fr       */
+/*                                                                            */
+/* ************************************************************************** */
+
+#include "pipex.h"
+
+char   **get_split_path(char *envp[])
+{
+       char    *path;
+
+       while (!ft_strnstr(*envp, "PATH=", 5))
+               envp++;
+       if (!*envp)
+               return (NULL);
+       path = *envp + 5;
+       return (ft_split(path, ':'));
+}
+
+char   *get_pwd(char *envp[])
+{
+       while (!ft_strnstr(*envp, "PWD=", 4))
+               envp++;
+       if (!*envp)
+               return (NULL);
+       return (*envp + 4);
+}
+
+char   *find_in_path(char *cmd, char **path)
+{
+       char    *cur_path;
+       char    *cmd_path;
+
+       cmd_path = NULL;
+       while (*path)
+       {
+               if (cmd_path)
+                       free(cmd_path);
+               cur_path = ft_strjoin(*path, "/");
+               if (!cur_path)
+                       return (NULL);
+               cmd_path = ft_strjoin(cur_path, cmd);
+               free(cur_path);
+               if (!cmd_path)
+                       return (NULL);
+               if (access(cmd_path, X_OK) != -1)
+                       return (cur_path);
+               path++;
+       }
+       return (NULL);
+}
+
+char   *get_cmd_path(char *cmd, char **path, char *pwd)
+{
+       char    *cur_dir;
+
+       if (cmd[0] == '/')
+               return (cmd); // TODO: Maybe use duplicate instead,
+                       so there will be no problem on free()
+       else if (strchr(cmd, '/'))
+       {
+               cur_dir = ft_strjoin(pwd, "/");
+               // TODO: Free on fail
+               // TODO: Maybe check if executable, else there might be a problem...
+               return (ft_strjoin(cur_dir, cmd));
+       }
+       else
+       {
+               return (find_in_path(cmd, path));
+       }
+}
index f6fa7f8a6d42981afd7d5cddc4c2f8a94889ffcf..27b418e075261d2c3560f981b88b093e6eec42a1 100644 (file)
@@ -6,7 +6,7 @@
 /*   By: dkaiser <dkaiser@student.42heilbronn.de    +#+  +:+       +#+        */
 /*                                                +#+#+#+#+#+   +#+           */
 /*   Created: 2024/05/02 12:13:23 by dkaiser           #+#    #+#             */
-/*   Updated: 2024/05/02 15:36:43 by dkaiser          ###   ########.fr       */
+/*   Updated: 2024/05/02 16:42:01 by dkaiser          ###   ########.fr       */
 /*                                                                            */
 /* ************************************************************************** */
 
 #include <stdlib.h>
 #include <unistd.h>
 
-static char    **get_split_path(char *envp[])
-{
-       char    *path;
-
-       while (!ft_strnstr(*envp, "PATH=", 5))
-               envp++;
-       if (!*envp)
-               return (NULL);
-       path = *envp + 5;
-       return (ft_split(path, ':'));
-}
-
-static char    *get_pwd(char *envp[])
-{
-       while (!ft_strnstr(*envp, "PWD=", 4))
-               envp++;
-       if (!*envp)
-               return (NULL);
-       return (*envp + 4);
-}
-
-static char    *find_in_path(char *cmd, char **path)
-{
-       char    *cur_path;
-       char    *cmd_path;
-
-       cmd_path = NULL;
-       while (*path)
-       {
-               if (cmd_path)
-                       free(cmd_path);
-               cur_path = ft_strjoin(*path, "/");
-               // TODO: Free on fail
-               cmd_path = ft_strjoin(cur_path, cmd);
-               free(cur_path);
-               if (access(cmd_path, X_OK) != -1)
-                       return (cur_path);
-               path++;
-       }
-       return (NULL);
-}
-
-static char    *get_cmd_path(char *cmd, char **path, char *pwd)
-{
-       char    *cur_dir;
-
-       if (cmd[0] == '/')
-               return (cmd); // TODO: Maybe use duplicate instead, so there will be no problem on free()
-       else if (strchr(cmd, '/'))
-       {
-               cur_dir = ft_strjoin(pwd, "/");
-               // TODO: Free on fail
-               // TODO: Maybe check if executable, else there might be a problem...
-               return (ft_strjoin(cur_dir, cmd));
-       }
-       else
-    {
-        return (find_in_path(cmd, path));
-    }
-}
-
 static char    **get_cmds(int argc, char *argv[], char *envp[])
 {
        char    **cmds;