rmをゴミ箱に移動

rmをゴミ箱に移動

ファイルを削除する代わりに、特別な「ごみ箱」の場所に移動できるLinuxスクリプト/アプリケーションはありますか?私はこれを代わりに使用したいですrm(おそらく後者のエイリアスかもしれません。これは長所と短所があります)。

「ごみ箱」とは特別なフォルダを意味します。単一がmv "$@" ~/.trash最初のステップですが、理想的には古いゴミ箱ファイルを上書きするのではなく、同じ名前の複数のファイルをゴミ箱として扱う必要があります。また覆う単純なコマンド(ある種の「元に戻す」)を使用してファイルを元の場所に復元します。また、再起動時にゴミが自動的に空になることをお勧めします(または無限の成長を防ぐための同様のメカニズム)。

これには部分的な解決策がありますが、「復元」作業が特に重要です。グラフィックシェルを持つ不都合なシステムに依存しない既存のソリューションはありますか?

(しかし、人々は頻繁なバックアップとVCSの使用とは対照的に、このアプローチが合理的であるかどうかについて議論してきました。これらの議論はすべて意味がありますが、私が求めているものの市場はまだまだあると信じています。)

答え1

一つある空仕様(下書き)freedesktop.orgから。これは明らかにデスクトップ環境が一般的に実装するものです。

コマンドラインの実装は次のとおりです。ゴミ-cli。詳しく見なくても好きな機能を提供しているようです。そうでない場合は、これがどの程度部分的な解決策であるかを教えてください。

あるプログラムを代替/別名として使用する限りrm、そうしないには十分な理由があります。私にとって最も重要なことは次のとおりです。

  • プログラムはすべてのrmオプションを理解/処理し、それに応じて行動する必要があります。
  • 他人のシステムで作業するとき、「新しいrm」の意味に慣れて致命的な結果をもたらすコマンドを実行する危険があります。

答え2

前の回答では、コマンドtrash-clirmtrash。デフォルトでは、2つのコマンドはUbuntu 18.04では見つかりませんが、次のコマンドはgioはい。コマンドgio help trash出力:

Usage:
  gio trash [OPTION…] [LOCATION...]

Move files or directories to the trash.

Options:
  -f, --force     Ignore nonexistent files, never prompt
  --empty         Empty the trash

私は以下を使ってテストします。gio trash FILENAMEコマンドラインでは、ファイルブラウザでファイルを選択し、DELボタンをクリックしたかのように機能します。ファイルはデスクトップのごみ箱フォルダに移動さ​​れます。 (該当するオプションを使用しなくても、-fコマンドに確認メッセージは表示されません.)

この方法でファイルを削除することは、安全のためにファイルを再定義し、すべての削除を確認する必要があるよりも便利でありながら元に戻すことができますrmrm -i削除してはいけないファイルを誤って確認した場合、それでも運が悪くなる可能性があります。

alias tt='gio trash'私のエイリアス定義ファイルにtt「trash」のニーモニックを追加しました。

2018年6月27日に修正:サーバーシステムにはごみ箱ディレクトリと同等のものはありません。私は別のコンピュータでタスクを実行するために、次のBashスクリプトを作成して、生成されたgio trashごみ箱ディレクトリに引数として提供されたファイルを移動しました。このスクリプトは動作テスト済みです。私はいつもこのスクリプトを使います。2024年4月12日にスクリプトが更新されました。

#!/bin/bash

# move_to_trash
#
# Teemu Leisti 2024-04-12
#
# USAGE:
#
#   Move the file(s) given as argument(s) to the trash directory, if they are
#   not already there.
#
# RATIONALE:
#
#   The script is intended as a command-line equivalent of deleting a file or
#   directory from a graphical file manager. On hosts that implement the
#   FreeDesktop.org specification on trash directories (hereon called "the trash
#   specification"; see
#   https://specifications.freedesktop.org/trash-spec/trashspec-latest.html),
#   that action moves the target file(s) to a built-in trash directory, and that
#   is exactly what this script does.
#
#   On other hosts, this script uses a custom trash directory (~/.Trash/). The
#   analogy of moving a file to trash is not perfect, as the script does not
#   offer the functionalities of restoring a trashed file to its original
#   location or emptying the trash directory. Rather, it offers an alternative
#   to the 'rm' command, thereby giving the user the peace of mind that they can
#   still undo an unintended deletion before emptying the custom trash
#   directory.
#
# IMPLEMENTATION:
#
#   To determine whether it's running on a host that implements the trash
#   specification, the script tests for the existence of (a) the gio command and
#   (b) either directory $XDG_DATA_HOME/Trash/, or, if that environment variable
#   hasn't bee set, of directory ~/.local/share/Trash/. If the test yields true,
#   the script relies on calling 'gio trash'.
#
#   On other hosts:
#     - There is no built-in trash directory, so the script creates a custom
#       directory ~/.Trash/, unless it already exists. (The script aborts if
#       there is an existing non-directory ~/.Trash.)
#     - The script appends a millisecond-resolution timestamp to all the files
#       it moves to the custom trash directory, to both inform the user of the
#       time of the trashing, and to avoid overwrites.
#     - The user will have to perform an undo by commanding 'mv' on a file or
#       directory moved to ~/.Trash/.
#     - The user will have to empty the custom trash directory by commanding:
#           rm -rf ~/.Trash/* ~/.Trash/.*
#
#   The script will not choke on a nonexistent file. It outputs the final
#   disposition of each filename argument: does not exist, was already in trash,
#   or was moved to trash.
#
# COPYRIGHT WAIVER:
#
#   The author dedicates this Bash script to the public domain by waiving all of
#   their rights to the work worldwide under copyright law, including all
#   related and neighboring rights, to the extent allowed by law. You can copy,
#   modify, distribute, and perform the script, even for commercial purposes,
#   all without asking for permission.

if [ -z "$XDG_DATA_HOME" ] ; then
    xdg_trash_directory=$(realpath ~/.local/share/Trash/)
else
    xdg_trash_directory=$(realpath $XDG_DATA_HOME/Trash/)
fi

gio_command_exists=0
if $(command -v gio > /dev/null 2>&1) ; then
    gio_command_exists=1
fi

host_implements_trash_specification=0
if [[ -d "${xdg_trash_directory}" ]] && (( gio_command_exists == 1 )) ; then
    # Executing on a host that implements the trash specification.
    host_implements_trash_specification=1
    trash_directory="${xdg_trash_directory}"
else
    # Executing on other host, so attempt to use a custom trash directory.
    trash_directory=$(realpath ~/.Trash)
    if [[ -e "${trash_directory}" ]] ; then
        # It exists.
        if [[ ! -d "${trash_directory}" ]] ; then
            # But is not a directory, so abort.
            echo "Error: ${trash_directory} exists, but is not a directory."
            exit 1
        fi
    else
        # It does not exists, so create it.
        mkdir "${trash_directory}"
        echo "Created directory ${trash_directory}"
    fi
fi

# Deal with all filenames (a concept that covers names of both files and
# directories) given as arguments.
for file in "$@" ; do
    file_to_be_trashed=$(realpath -- "${file}")
    file_basename=$(basename -- "${file_to_be_trashed}")
    if [[ ! -e ${file_to_be_trashed} ]] ; then
        echo "does not exist:   ${file_to_be_trashed}"
    elif [[ "${file_to_be_trashed}" == "${trash_directory}"* ]] ; then
        echo "already in trash: ${file_to_be_trashed}"
    else
        # ${file_to_be_trashed} exists and is not yet in the trash directory,
        # so move it there.
        if (( host_implements_trash_specification == 1 )) ; then
            gio trash "${file_to_be_trashed}"
        else
            # Move the file to the custom trash directory, with a new name that
            # appends a millisecond-resolution timestamp to the original.
            head="${trash_directory}/${file_basename}"_TRASHED_ON_
            move_file_to="${head}$(date '+%Y-%m-%d_AT_%H-%M-%S.%3N')"
            while [[ -e "${move_file_to}" ]] ; do
                # Generate a new name with a new timestamp, as the previously
                # generated one denoted an existing file or directory. It's very
                # unlikely that this loop needs to be executed even once.
                move_file_to="${head}$(date '+%Y-%m-%d_AT_%H-%M-%S.%3N')"
            done
            # There is no file or directory named ${move_file_to}, so
            # we can use it as the move target.
            /bin/mv "${file_to_be_trashed}" "${move_file_to}"
        fi
        echo "moved to trash:   ${file_to_be_trashed}"
    fi
done

答え3

ゴミ-cliUbuntuではapt-getを使用し、Fedoraではyumを使用してインストールできるLinuxアプリケーションです。このコマンドを使用すると、trash listOfFiles指定されたコンテンツがごみ箱に移動されます。

答え4

まずmove_to_trash関数を定義します。

move_to_trash () {
    mv "$@" ~/.trash
}

その後、エイリアスは次rmのようになります。

alias rm='move_to_trash'

rm次のようにバックスラッシュを使用してエスケープして、いつでもoldを呼び出すことができます\rm

再起動時にごみ箱のディレクトリを空にする方法はわかりませんが(システムによってはスクリプトを調べる必要があるかもしれませんrc*)、cron定期的にディレクトリを空にするタスクを作成することも価値があるかもしれません。

関連情報