Skip to content

Latest commit

 

History

History
105 lines (72 loc) · 2.89 KB

README.md

File metadata and controls

105 lines (72 loc) · 2.89 KB

tap 🖱️

License: MIT Rust

tap is a next-generation replacement for the Unix touch command, offering enhanced capabilities and intuitive options for file and directory manipulation.

🌟 Features

  • Create or update files and directories
  • Set file permissions (with recursive option for directories)
  • Write or append content to files
  • Use template files for content
  • Remove trailing whitespace from lines
  • Check for file/directory existence without modification
  • Support for glob patterns
  • Set custom timestamps for files

🚀 Installation

To install tap, you need to have Rust and Cargo installed on your system. If you don't have them installed, you can get them from rust-lang.org.

Once you have Rust and Cargo, you can install tap using the following command:

cargo install tap

Or, to build from source:

git clone https://github.com/crazywolf132/tap.git
cd tap
cargo build --release

The built binary will be located at target/release/tap.

💡 Usage

Here are some examples of how to use tap:

# Create a new file or update its timestamp
tap file.txt

# Create multiple files
tap file1.txt file2.txt file3.txt

# Create a directory
tap -d new_directory

# Set file permissions
tap --chmod 644 file.txt

# Set file permissions recursively
tap -R --chmod 755 src/

# Write content to a file
tap -w "Hello, World!" greeting.txt

# Append content to a file
tap -a -w "New line" existing_file.txt

# Use a template file
tap --template README.md new_file.md

# Remove trailing whitespace
tap --trim *.txt

# Check if files exist (dry run)
tap --check config/*.yml

# Set a specific timestamp
tap -t "2023-05-01 12:00:00" file.txt

# Use glob patterns
tap src/**/*.rs

🔧 Options

  • -d, --dir: Create a directory instead of a file
  • --chmod <MODE>: Set specific permissions (octal format, e.g., 644)
  • -w, --write <CONTENT>: Add content to the file
  • -t, --timestamp <TIME>: Set access and modification times (YYYY-MM-DD HH:MM:SS)
  • -a, --append: Append content instead of overwriting
  • -v, --verbose: Enable verbose output
  • -R, --recursive: Apply chmod recursively (only works with directories)
  • --template <FILE>: Use a template file for content
  • --trim: Remove trailing whitespace from each line
  • --check: Check if the file or directory exists (dry run)

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

🙏 Acknowledgments

  • Inspired by the original Unix touch command
  • Built with Rust and clap