Bringing the hell of pointers to Python.
Project description
pointers.py
Bringing the hell of pointers to Python
Why would you ever need this
Example
from pointers import to_ptr, Pointer, decay
a: str = '123'
b: str = 'abc'
@decay
def switch(ptr_a: Pointer[str], ptr_b: Pointer[str]):
ptr_a << ptr_b
switch(a, b)
print(a, b) # abc abc
Installation
Linux/macOS
python3 -m pip install -U pointers.py
Windows
py -3 -m pip install -U pointers.py
Usage
Creation
To convert something to a pointer, use the pointers.to_ptr()
function. Then, when annotating function types use the pointers.Pointer
class, like so:
from pointers import Pointer, to_ptr
class test_class:
pass
def some_function(ptr: Pointer[test_class]): # can be any data type (str, tuple, etc)
...
some_function(to_ptr(test_class())) # converts the instance to a pointer object
Dereferencing
To dereference a pointer, use the Pointer.dereference()
function:
def some_function(ptr: Pointer[test_class]):
my_instance: test_class = ptr.dereference() # dereferences the pointer
instance = test_class()
some_function(to_ptr(instance))
Alternatively, you can use the * operator to dereference the pointer:
def some_function(ptr: Pointer[str]):
print(*ptr) # a
some_function(to_ptr("a"))
Note that when using the * operator, the following syntax will not work properly:
deref = *ptr
print(deref)
For the above scenario you can use the dereferencing assignment operator, ,=
, or the ~
operator:
deref ,= ptr # works correctly
print(deref)
deref = ~ptr # also works correctly
print(deref)
A segmentation fault will occur if the address does not exist, so make sure the pointer is valid.
Assignment
To assign the pointer to a different address, use the assign()
method:
ptr = to_ptr("abc")
ptr2 = to_ptr("test") # must be same type
ptr.assign(ptr2)
print(*ptr) # test
You can also use the >>
operator instead, which gets rid of the need to pass in a pointer at all:
ptr = to_ptr("abc")
ptr >> "test" # does not need to_ptr
print(*ptr) # test
Movement
Pointers.py supports data movement, but it is very dangerous to use. For example:
a = '123'
b = 'abc'
ptr_a = to_ptr(a)
ptr_b = to_ptr(b)
ptr_a.move(ptr_b) # uou can also use the <<
print(a) # abc
Movement works with any data type, but can break things internally when the pointer points to a literal:
a = 1
b = 2
ptr_a = to_ptr(a)
ptr_b = to_ptr(b)
ptr_a << ptr_b # moves 2 into 1
print(1) # 2
# literal 1 has now become 2
# segmentation fault occurs on interpreter shutoff
Decaying
If you would like to automatically decay values to a pointer, use the pointers.decay
decorator, like this:
@decay
def some_function(ptr: Pointer[str], b: str): # converts "ptr" to a pointer since its hinted as Pointer[str]
print(ptr.dereference(), b) # a b
some_function("a", "b") # converts "a" to a pointer, and leaves b as it is
Make sure you annotate the argument with Pointer
or else decay won't convert it.
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
Built Distribution
Hashes for pointers.py-1.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5c9d895697eb82ce8f638e7cbbee939d1525f368dbe48e03b1252149699048fb |
|
MD5 | 7954da7e9586a1d2a2177b9d5a916599 |
|
BLAKE2b-256 | 96789b4d6648b094bae1b1b255fa945ca70e40685d9d02e23b4d739d7c9a1a11 |