From 980f692e6fcbc83fb41f831f1143b1e6ecf412c6 Mon Sep 17 00:00:00 2001 From: Josuer08 Date: Sat, 13 Feb 2021 21:10:50 -0500 Subject: [PATCH] first --- README.md | 1 + khe | 10 +++ test | 1 + tinysh | Bin 0 -> 17752 bytes tinysh.c | 210 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 5 files changed, 222 insertions(+) create mode 100644 README.md create mode 100755 khe create mode 100644 test create mode 100755 tinysh create mode 100644 tinysh.c diff --git a/README.md b/README.md new file mode 100644 index 0000000..8d4d195 --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +# tinysh-parallel diff --git a/khe b/khe new file mode 100755 index 0000000..7a6346d --- /dev/null +++ b/khe @@ -0,0 +1,10 @@ +#!/bin/bash +# Basic while loop +counter=1 +while [ $counter -le 10 ] +do +echo $counter +((counter++)) +sleep 1 +done +echo All done diff --git a/test b/test new file mode 100644 index 0000000..97df509 --- /dev/null +++ b/test @@ -0,0 +1 @@ +./khe;./khe diff --git a/tinysh b/tinysh new file mode 100755 index 0000000000000000000000000000000000000000..9f97bcdb773c75926a4251664ce5dbe792dc20fe GIT binary patch literal 17752 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 literal 0 HcmV?d00001 diff --git a/tinysh.c b/tinysh.c new file mode 100644 index 0000000..29c6a01 --- /dev/null +++ b/tinysh.c @@ -0,0 +1,210 @@ +#include +#include +#include +#include +#include +#include +#include + + +int COMMANDS_SIZE; +char **parse_command(char *my_line, char value) +{ + int buffer_size = 64; + int i = 0; + char *arg; + char **args = malloc(buffer_size * sizeof(char*)); + char *valuee = &value; + arg = strtok(my_line, valuee); + while (arg != NULL) { + args[i] = arg; + i++; + arg = strtok(NULL, valuee); + } + + args[i] = NULL; + COMMANDS_SIZE = i; + return args; +} +void trimTrailing(char * str) +{ + int index, i; + + /* Set default index */ + index = -1; + + /* Find last index of non-white space character */ + i = 0; + while(str[i] != '\0') + { + if(str[i] != ' ' && str[i] != '\t' && str[i] != '\n') + { + index= i; + } + + i++; + } + + /* Mark next character to last non-white space character as NULL */ + str[index + 1] = '\0'; +} +////////////////////EXEC PROGRAM FUNCTION///////////// +// +// +// +static int exec_prog(int argc, const char **argv) { + + pid_t pid[argc]; + int status, timeout /* unused ifdef WAIT_FOR_COMPLETION */; + + // this block executes when pid=0, (I am the father process) + + for (int i =0; i < argc; i++) { + + if ((pid[i] = fork()) < 0) { /* fork a child process */ + printf("*** ERROR: forking child process failed\n"); + exit(1); + } else if (pid[i] == 0) { /* for the child process: */ + trimTrailing(argv[i]); + char **value = parse_command(argv[i], ' '); + if (strcmp(value[0], "")) { + if (execvp(value[0], value) < 0) { /* execute the command */ + printf("*** ERROR: exec failed\n"); + exit(1); + } + exit(0); + } else { + printf(""); + exit(0); + } + } + + } + + for (int i =0; i < argc; i++) { + do { + if ((pid[i] = waitpid(pid[i], &status, WNOHANG)) == -1) { + perror("wait() error"); + } + else if (pid[i] == 0) { + /*printf("child is still running ");*/ + sleep(1); + } else { + if (WIFEXITED(status)) + printf("child exited with status of %d\n", WEXITSTATUS(status)); + /*else puts("child did not exit successfully");*/ + } + } while (pid[i] == 0); + + } + + return 0; +} +// +// +// +////////////////////////////////////////////////////// + +////////////////////BATCH MODE PROCESS//////////////// +// +// +// +int batchModeStart(const char **argv) { + + + +} +// +// +// +////////////////////////////////////////////////////// + +void promptPrint(){ +printf("⌈[tinysh] \n↳>>> "); +} + + +char *read_command_line(void) +{ + int bufsize = 1024; + char *buffer = malloc(sizeof(char) * bufsize); + int c; + int i = 0; + + while ( c != '\n' ) { + c = getchar(); + buffer[i] = c; + i++; + } + + return buffer; +} + + +int main (int argc, char *argv[]){ + + char *prompt = argv[0]; + char *filename; + bool batchMode = false; + if ( argc == 2) { + filename = argv[1]; + batchMode = true; + } else if (argc != 1) { + printf("Wrong ammount of arguments, only one file per batch \n"); + } + + /*promptPrint();*/ + /*exec_prog(1, filename);*/ + /*exec_prog(&argv[1]);*/ + + + +//Oscar J Rodriguez B (@josuer08) + if (!batchMode) { + bool active = true; + char *arguments; + while (active) { + promptPrint(); + arguments = read_command_line(); + char **args = parse_command(arguments, ';'); + trimTrailing(args[0]); + if (strcmp(args[0], "exit") == 0) {/* is it an "exit"? */ + active = false; /* exit if it is */ + } else { + exec_prog(COMMANDS_SIZE,args); + } + /*printf("%d", COMMANDS_SIZE);*/ + /*printf("%s and %s", args[0], args[1]);*/ + } + } else { + char * buffer = 0; + long length; + FILE * f = fopen (filename, "rb"); + + if (f) { + fseek (f, 0, SEEK_END); + length = ftell (f); + fseek (f, 0, SEEK_SET); + buffer = malloc (length); + if (buffer) { + fread (buffer, 1, length, f); + } + fclose (f); + } + + if (buffer) { + char **args = parse_command(buffer, ';'); + trimTrailing(args[0]); + /*printf("%s", buffer);*/ + exec_prog(COMMANDS_SIZE,args); + } + + + return 0; + + } + + + + +} -- 2.25.1