Skip to content

file and folder management written in rust

License

Notifications You must be signed in to change notification settings

0101coding/punch

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation


Logo

punch

🗂️ file and folder management written in rust 📄

About punch 💡

It can be kind of easy to forget which bash command does what, for folder creation, we have mkdir, for files cat and touch , and for deletion we have rm, each of them has its own flags and ways to append multiple, so why not just have one command do it all.

Name inspired by the touch command

commands:

📒 NOTE: all commands can't be joined together any number of times

  • ex: punch <flag(optional)> <file or directory_name> <file or directory_name> ...
  • punch ./folder1/ file1.txt file2.txt ./folder2 ./folder3 "to create multiple files and folders"

all directories must start with "./" and end with "/"

  • punch --help "to bring up help"
  • punch <file_name>... "to create file" or directory
  • punch -r <file1> <file2> "to rename a file"
  • punch -d <file_name> "or"  punch -d ./<directory_name>/ "to delete"
  • 🔔(bonus)

  • punch -in ./<target_directory_name>/ <file or directory_name> "creates files inside target directory"
  • punch -din ./<target_directory_name>/ <file or directory_name> "deletes files inside target directory"
  • punch -t <file or directory_name> "trashed the specified file or directory"
  • punch -m <file names separated by spaces e.g. test.txt test1.txt> <./<directory_name>/ or number_of_moves: number>
  • punch -l "Lists the sub-directories and files in the current working directory"
  • punch -o "opens file with default application"
  • punch -u "undoes the last create or trash command"
  • punch --sizeof "returns the size of a file/folder"
  • punch -s "displays a table of file creation/deletion/trash history"

Built With

Rust Bash

Building from Source 🎁

  1. Clone the repo
    git clone https://github.com/spicylemonade/punch.git
  2. CD into the project
    cd ./punch
  3. Run the build script
    source build.sh
    or
     . ./build.sh

    For Windows ->

     ./build.ps1

If the build ends in an error you may not have the c libraries installed:

for debian based systems ->

  sudo apt-get install build-essential

for arch based

  sudo pacman -Sy base-devel

for windows ->

run .\vs_BuildTools.exe in the punch clone directory then click on "Desktop Development with c++" and install

{To top}

Examples

image

image

image

{To top}

contributions:eyes:

contributions are welcome, just fork and pull request

About

file and folder management written in rust

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 92.3%
  • Shell 5.0%
  • PowerShell 2.7%