parent
							
								
									fb2f2d9cb2
								
							
						
					
					
						commit
						80bc5833e7
					
				
				 1 changed files with 0 additions and 46 deletions
			
			
		| @ -1,46 +0,0 @@ | ||||
| import os | ||||
| from cffi import FFI | ||||
| from typing import Any, List | ||||
| 
 | ||||
| # Workaround for the EON/termux build of Python having os.*xattr removed. | ||||
| ffi = FFI() | ||||
| ffi.cdef(""" | ||||
| int setxattr(const char *path, const char *name, const void *value, size_t size, int flags); | ||||
| ssize_t getxattr(const char *path, const char *name, void *value, size_t size); | ||||
| ssize_t listxattr(const char *path, char *list, size_t size); | ||||
| int removexattr(const char *path, const char *name); | ||||
| """) | ||||
| libc = ffi.dlopen(None) | ||||
| 
 | ||||
| def setxattr(path, name, value, flags=0) -> None: | ||||
|   path = path.encode() | ||||
|   name = name.encode() | ||||
|   if libc.setxattr(path, name, value, len(value), flags) == -1: | ||||
|     raise OSError(ffi.errno, f"{os.strerror(ffi.errno)}: setxattr({path}, {name}, {value}, {flags})") | ||||
| 
 | ||||
| def getxattr(path, name, size=128): | ||||
|   path = path.encode() | ||||
|   name = name.encode() | ||||
|   value = ffi.new(f"char[{size}]") | ||||
|   l = libc.getxattr(path, name, value, size) | ||||
|   if l == -1: | ||||
|     # errno 61 means attribute hasn't been set | ||||
|     if ffi.errno == 61: | ||||
|       return None | ||||
|     raise OSError(ffi.errno, f"{os.strerror(ffi.errno)}: getxattr({path}, {name}, {size})") | ||||
|   return ffi.buffer(value)[:l] | ||||
| 
 | ||||
| def listxattr(path, size=128) -> List[Any]: | ||||
|   path = path.encode() | ||||
|   attrs = ffi.new(f"char[{size}]") | ||||
|   l = libc.listxattr(path, attrs, size) | ||||
|   if l == -1: | ||||
|     raise OSError(ffi.errno, f"{os.strerror(ffi.errno)}: listxattr({path}, {size})") | ||||
|   # attrs is b'\0' delimited values (so chop off trailing empty item) | ||||
|   return [a.decode() for a in ffi.buffer(attrs)[:l].split(b"\0")[0:-1]] | ||||
| 
 | ||||
| def removexattr(path, name) -> None: | ||||
|   path = path.encode() | ||||
|   name = name.encode() | ||||
|   if libc.removexattr(path, name) == -1: | ||||
|     raise OSError(ffi.errno, f"{os.strerror(ffi.errno)}: removexattr({path}, {name})") | ||||
					Loading…
					
					
				
		Reference in new issue