Skip to content

Implementation of a shell for Linux-like systems

Notifications You must be signed in to change notification settings

dimadem/minishell

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

image

Norminette workflow Compilation workflow Valgrind workflow

42 Minishell Project 🐚

Welcome to the 42 Minishell project! This project our minimalist shell implementation designed to mimic features of bash. It supports various shell features, including pipes, environment variables, built-in commands, and more. 🚀

Features

  • Basic Shell Functions: Command execution, redirections, and pipes (|).
  • Environment & Loval Variables: Handles $VAR expansions.
  • Built-in Commands: Includes cd, echo, env, export, pwd, unset, and exit.
  • Signal Handling: Graceful handling of Ctrl+C, Ctrl+\, and Ctrl+D.
  • Error Handling: Displays clear messages for invalid inputs or syntax errors.
  • Custom Memory Management: Implements robust memory safety mechanisms.

Installation and Usage

To compile and run the project, follow these steps:

  1. Clone the repository:

    git clone [email protected]:dimadem/minishell.git minishell
    cd minishell
    make
    ./minishell
    
  2. Please see documentation for this project under https://dimadem.github.io/minishell/

  3. The project uses an Abstract Syntax Tree (AST) to recursively enforce the correct order of execution for commands. This ensures proper parsing and execution logic, even for complex pipelines and redirections.

  4. High-level project architecture:

    • build/: Directory for object files and other intermediate build artifacts.
    • docs/: Documentation for the project.
    • inc/: Header files for the project, defining interfaces for different modules:
      • builtins.h: Declarations for built-in shell commands.
      • execute.h: Declarations for command execution functions.
      • parser.h: Declarations for command-line parsing functions.
      • pipe.h: Declarations for piping functions.
      • redirection.h: Declarations for redirection functions.
      • shell.h: General declarations for the shell.
      • tokens.h: Declarations for token parsing functions.
    • lib/: Directory for third-party libraries, such as libft.
    • src/: Source files for the project, organized into subdirectories by functionality:
      • builtins/: Implementation of built-in shell commands.
      • execute/: Implementation of command execution logic.
      • parser/: Implementation of command-line parsing.
      • pipe/: Implementation of piping between commands.
      • redirection/: Implementation of input/output redirection.
      • utils/: Implementation of auxiliary functions.
      • test/: Tests for project components.
      • main.c: Entry point of the shell application.

Conclusion

The 42 Minishell project delves into system-level programming, process management, and advanced parsing. It provides a foundation for further OS-level development.

About

Implementation of a shell for Linux-like systems

Resources

Stars

Watchers

Forks