1
0
mirror of https://github.com/arsenetar/send2trash.git synced 2024-12-06 12:49:02 +00:00
send2trash/README.rst

45 lines
1.7 KiB
ReStructuredText
Raw Normal View History

2010-04-07 08:43:36 +00:00
==================================================
Send2Trash -- Send files to trash on all platforms
==================================================
Send2Trash is a small package that sends files to the Trash (or Recycle Bin) *natively* and on
*all platforms*. On OS X, it uses native ``FSMoveObjectToTrashSync`` Cocoa calls, on Windows, it
2013-07-19 23:26:34 +00:00
uses native (and ugly) ``SHFileOperation`` win32 calls. On other platforms, if `PyGObject`_ and
`GIO`_ are available, it will use this. Otherwise, it will fallback to its own implementation
of the `trash specifications from freedesktop.org`_.
2010-04-07 08:43:36 +00:00
2010-10-18 10:13:37 +00:00
``ctypes`` is used to access native libraries, so no compilation is necessary.
Send2Trash supports Python 2.7 and up (Python 3 is supported).
2010-04-07 08:43:36 +00:00
Installation
------------
You can download it with pip::
pip install Send2Trash
or you can download the source from http://github.com/hsoft/send2trash and install it with::
2010-04-07 08:43:36 +00:00
>>> python setup.py install
2010-04-07 08:43:36 +00:00
Usage
-----
>>> from send2trash import send2trash
>>> send2trash('some_file')
2018-02-06 22:28:47 +00:00
On Freedesktop platforms (Linux, BSD, etc.), you may not be able to efficiently
trash some files. In these cases, an exception ``send2trash.TrashPermissionError``
is raised, so that the application can handle this case. This inherits from
``PermissionError`` (``OSError`` on Python 2). Specifically, this affects
files on a different device to the user's home directory, where the root of the
device does not have a ``.Trash`` directory, and we don't have permission to
create a ``.Trash-$UID`` directory.
For any other problem, ``OSError`` is raised.
2013-07-19 23:26:34 +00:00
.. _PyGObject: https://wiki.gnome.org/PyGObject
.. _GIO: https://developer.gnome.org/gio/
.. _trash specifications from freedesktop.org: http://freedesktop.org/wiki/Specifications/trash-spec/