Compare commits

..

No commits in common. "master" and "1.0" have entirely different histories.
master ... 1.0

4 changed files with 59 additions and 50 deletions

View File

@ -77,4 +77,4 @@ steps:
pull: if-not-exists
commands:
- . $HOME/.bashrc
- trash | grep required
- trash

18
LICENSE
View File

@ -2,8 +2,20 @@ MIT License
Copyright (c) 2021 Kim Oliver Drechsel <kim@drechsel.xyz>
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
Permission is hereby granted, without written agreement and without
license or royalty fees, to use, copy, modify, and distribute this
software and its documentation for any purpose, provided that the
above copyright notice and the following two paragraphs appear in
all copies of this software.
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
DAMAGE.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.

View File

@ -1,18 +1,18 @@
# trash.sh - A cli trash bin for files and directories instead of deleting them directly
# trash - A trash bin for files and directories instead of deleting them directly
[![Build Status](https://drone.pyas.de/api/badges/Kim/trash.sh/status.svg)](https://drone.pyas.de/Kim/trash.sh)
[![Build Status](https://drone.pyas.de/api/badges/Kim/trash/status.svg)](https://drone.pyas.de/Kim/trash)
## Installation:
Put the trash.sh file to your desired location (e.g home directory) and source it in your `$HOME/.bashrc` or in `/etc/.bashrc`:
the trash.sh file in your desired path and source it in your $HOME/.bashrc or in /etc/.bashrc:
. /path/to/trash.sh
- When the script runs, it first checks if `$HOME/.trash/` (your trash bin) exists and creates it if missing.
- As the Script runs it first checks if $HOME/.trash/ (your trash bin) in your home dir exists and creates it if missing.
Add the cleanup job to your crontab:
Add cleanup job to your cron:
# .trash cleanup of all contents (files and dirs) older than 31 days every morning at 06:00
0 6 * * 0 find $HOME/.trash/ -mtime +31 -delete
0 6 * * 0 find /home/YOURHOME/.trash/ -mtime +31 -delete
## Usage:

View File

@ -1,21 +1,18 @@
#!/usr/bin/env bash
# Trash Bin Functionss
# On Github: https://github.com/kimdre/trash.sh
#!/bin/bash
# Trash Functions
TRASH_DIR="$HOME/.trash"
FILE_PATHS_FILE="$TRASH_DIR/.filepaths"
TRASH_DIR="$HOME"/.trash
[ ! -d "$TRASH_DIR" ] && mkdir "$TRASH_DIR"
FILE_PATHS_FILE="$TRASH_DIR/.filepaths"
[ ! -f "$FILE_PATHS_FILE" ] && touch "$FILE_PATHS_FILE"
usage() {
local func_args="$1"
if [[ $func_args == 0 ]];
then echo -e "At least one file/directory as argument required:\nExamples: FILE.txt /DIR/FILE.txt SUB_DIR/FILE.* /DIR/* DIR/DIR ..."
return 1
else
return 0
then echo -e "At least one argument required:\ncommand FILE1 DIR2 ..."
exit
fi
}
@ -24,13 +21,13 @@ trash_list() {
}
trash_put() {
usage "$#" && {
usage "$#"
for FILE in $@; do
# Store old filepath for later restore
echo "$FILE $(readlink -f "$FILE")" >>"$FILE_PATHS_FILE"
done
mv -v $* "$TRASH_DIR/"
}
}
trash_empty() {
@ -39,7 +36,8 @@ trash_empty() {
}
trash_restore() {
usage "$#" && {
usage "$#"
for FILE_TO_RESTORE in "$@"; do
# Get old filepath for restore
OLD_PATH=$(grep "$FILE_TO_RESTORE" "$FILE_PATHS_FILE" | cut -d ' ' -f2)
@ -50,11 +48,11 @@ trash_restore() {
# Replace / with \/ from string and remove filepath from file after move was successful
sed -i "/${FILE_TO_RESTORE////\\/}/d" "$FILE_PATHS_FILE"
done
}
}
trash_rm() {
usage "$#" && {
usage "$#"
for FILE_TO_REMOVE in "$@"; do
if ! echo "$FILE_TO_REMOVE" | grep "$HOME/.trash"
then FILEPATH_TO_REMOVE="$HOME/.trash/$FILE_TO_REMOVE"
@ -66,7 +64,6 @@ trash_rm() {
echo "$FILE_TO_REMOVE is not in Trash." && false
fi
done
}
}
alias trash='trash_put'