]> git.k1024.org Git - pyxattr.git/blob - README.md
Enable PathLib tests under pypy-3.10
[pyxattr.git] / README.md
1 # pyxattr
2
3 This is the pyxattr module, a Python extension module which gives access
4 to the extended attributes for filesystem objects available in some
5 operating systems.
6
7 [![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/iustin/pyxattr/ci.yml?branch=main)](https://github.com/iustin/pyxattr/actions/workflows/ci.yml)
8 [![Codecov](https://img.shields.io/codecov/c/github/iustin/pyxattr)](https://codecov.io/gh/iustin/pyxattr)
9 [![Read the Docs](https://img.shields.io/readthedocs/pyxattr)](https://pyxattr.readthedocs.io/en/latest/?badge=latest)
10 [![GitHub issues](https://img.shields.io/github/issues/iustin/pyxattr)](https://github.com/iustin/pyxattr/issues)
11 ![GitHub tag (latest by date)](https://img.shields.io/github/v/tag/iustin/pyxattr)
12 [![GitHub release (latest by date)](https://img.shields.io/github/v/release/iustin/pyxattr)](https://github.com/iustin/pyxattr/releases)
13 [![PyPI](https://img.shields.io/pypi/v/pyxattr)](https://pypi.org/project/pyxattr/)
14 ![Debian package](https://img.shields.io/debian/v/python-pyxattr)
15 ![Ubuntu package](https://img.shields.io/ubuntu/v/python-pyxattr)
16 ![GitHub Release Date](https://img.shields.io/github/release-date/iustin/pyxattr)
17 ![GitHub commits since latest release](https://img.shields.io/github/commits-since/iustin/pyxattr/latest)
18 ![GitHub last commit](https://img.shields.io/github/last-commit/iustin/pyxattr)
19 [![OpenSSF Best Practices](https://bestpractices.coreinfrastructure.org/projects/7236/badge)](https://bestpractices.coreinfrastructure.org/projects/7236)
20
21 Downloads: go to <https://pyxattr.k1024.org/downloads/>. The source
22 repository is either at <https://git.k1024.org/pyxattr.git> or at
23 <https://github.com/iustin/pyxattr>.
24
25 See the `CONTRIBUTING.md` file for details on how to contribute, or
26 support me on [ko-fi](https://ko-fi.com/iustin).
27
28 ## Requirements
29
30 The current supported Python versions are 3.7+ (tested up to 3.12), or
31 PyPy versions 3.7+ (tested up to 3.10). The code should currently be
32 compatible down to Python 3.4, but such versions are no longer tested.
33
34 The library has been written and tested on Linux, kernel v2.4 or
35 later, with XFS and ext2/ext3/ext4 file systems, and MacOS recent
36 versions. If any other platform implements the same behaviour,
37 pyxattr could be used.
38
39 To build the module from source, you will need both a Python
40 development environment/libraries and the C compiler, plus the
41 setuptools tool installed, and for building the documentation you need
42 to have Sphinx installed. The exact list of dependencies depends on
43 the operating system/distribution, but should be something along the
44 lines of `python3-devel` (RedHat), `python3-all-dev` (Debian), etc.
45
46 Alternatively, you can install directly from pip after installing the
47 above depedencies (C compiler, Python development libraries):
48
49     pip install pyxattr
50
51 Or you can install already compiled versions from your distribution,
52 e.g. in Debian:
53
54     sudo apt install python3-pyxattr
55
56 ## Security
57
58 For reporting security vulnerabilities, please see `SECURITY.md`.
59
60 ## Basic example
61
62     >>> import xattr
63     >>> xattr.listxattr("file.txt")
64     ['user.mime_type']
65     >>> xattr.getxattr("file.txt", "user.mime_type")
66     'text/plain'
67     >>> xattr.setxattr("file.txt", "user.comment", "Simple text file")
68     >>> xattr.listxattr("file.txt")
69     ['user.mime_type', 'user.comment']
70     >>> xattr.removexattr ("file.txt", "user.comment")
71
72 ## License
73
74 pyxattr is Copyright 2002-2008, 2012-2015 Iustin Pop.
75
76 pyxattr is free software; you can redistribute it and/or modify it under the
77 terms of the GNU Lesser General Public License as published by the Free
78 Software Foundation; either version 2.1 of the License, or (at your option) any
79 later version. See the COPYING file for the full license terms.
80
81 Note that previous versions had different licenses: version 0.3 was licensed
82 under LGPL version 3 (which, I realized later, is not compatible with GPLv2,
83 hence the change to LGPL 2.1), and even older versions were licensed under GPL
84 v2 or later.