Utilities to write python wrappers around C code
Project description
Module cffi_utils.sowrapper
Utility functions to locate and load shared libraries
DESCRIPTION
Recommended usage:
Should only need to use get_lib_ffi_shared() or get_lib_ffi_resource()
Use get_lib_ffi_shared to load a system-wide shared library with a known library filename and / or path
Use get_lib_ffi_resource to load a module-specific shared library where library filename MAY be mangled as per PEP3149 and path MAY need to be looked up using pkg_resources. Internally, get_lib_ffi_resource() calls get_lib_ffi_shared()
Both return a tuple: (ffi, lib):
ffi-->FFIExt - should behave like cffi.FFI with some additional
utility methods
lib-->SharedLibWrapper instance - use methods on this object to
call methods in the shared library
CLASSES
class SharedLibWrapper(__builtin__.object) | Methods defined here: | | __init__(self, libpath, c_hdr, module_name=None) | libpath-->str: library name; can also be full path | c_hdr-->str: C-style header definitions for functions to wrap | ffi-->FFIExt or cffi.FFI
FUNCTIONS
get_lib_ffi_resource(module_name, libpath, c_hdr)
module_name-->str: module name to retrieve resource
libpath-->str: shared library filename with optional path
c_hdr-->str: C-style header definitions for functions to wrap
Returns-->(ffi, lib)
Use this method when you are loading a package-specific shared library
If you want to load a system-wide shared library, use get_lib_ffi_shared
instead
get_lib_ffi_shared(libpath, c_hdr)
libpath-->str: shared library filename with optional path
c_hdr-->str: C-style header definitions for functions to wrap
Returns-->(ffi, lib)
Module cffi_utils.ffi
Extension of cffi.FFI adding a few utility methods
CLASSES
class FFIExt(cffi.api.FFI) | FFIExt is an extension of cffi.FFI, adding a few utility methods | | get_cdata(), get_buffer() and get_bytes() all operate on a variable | list of arguments as a convenience. | | Otherwise, get_cdata() and get_buffer() are equivalent to | FFI.from_buffer() and FFI.buffer() respectively | | get_bytes() is identical to get_buffer() except that outputs are | converted to bytes | | get_buffer(self, *args) | all args-->_cffi_backend.CDataOwn | Must be a pointer or an array | Returns-->buffer (if a SINGLE argument was provided) | LIST of buffer (if a args was a tuple or list) | | get_bytes(self, *args) | all args-->_cffi_backend.CDataOwn | Must be a pointer or an array | Returns-->bytes (if a SINGLE argument was provided) | LIST of bytes (if a args was a tuple or list) | | get_cdata(self, *args) | all args-->_cffi_backend.buffer | Returns-->cdata (if a SINGLE argument was provided) | LIST of cdata (if a args was a tuple or list) | | get_extension(self)
Module cffi_utils.py2to3
Utility functions for Py2/Py3 compatibility
FUNCTIONS
chr(x)
x-->int / byte
Returns-->byte / str of length 1
Behaves like PY2 chr() in PY2 or PY3
decode(b, encoding='latin-1')
b-->bytes
encoding-->str: encoding to use. Recommended to use default
Returns-->str: b decoded to str using encoding
Works in PY2, PY3
encode(s, encoding='latin-1')
s-->str
encoding-->str: encoding to use. Recommended to use default
Returns-->bytes: s encoded to bytes using encoding
Works in PY2, PY3
fromBytes(b)
s-->bytes (or str)
Returns-->str (works in PY2, PY3)
inputFromBytes(func, *args, **kwargs)
Descriptor that converts all arguments to str
inputToBytes(func, *args, **kwargs)
Descriptor that converts all arguments to bytes
ord(x)
x-->int / byte
Returns-->int
Behaves like PY2 ord() in PY2 or PY3
outputFromBytes(func, *args, **kwargs)
Descriptor that converts all return values to str
outputToBytes(func, *args, **kwargs)
Descriptor that converts all return values to bytes
toBytes(s)
s-->str (or bytes)
Returns-->bytes (works in PY2, PY3)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file cffi_utils-0.79.tar.gz.
File metadata
- Download URL: cffi_utils-0.79.tar.gz
- Upload date:
- Size: 21.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b0986b85e13b158af07c9a17f2fe353961c61b94342796ab4e96ca5e8e072a2c
|
|
| MD5 |
6d85a905c0634c03ea14072ea30ea0b1
|
|
| BLAKE2b-256 |
95bf4987402d94352b29e831f48e3a9669a1a39d9207aba8e247964c4fb9ef17
|