/funktown

Immutable Data Structures for Python

Primary LanguagePythonMIT LicenseMIT

FunkTown: Functional Data Structures for Python

This library implements an efficient ImmutableDict and ImmutableVector class inspired by the implementation of Vectors and Maps in the Clojure programming language.

Installation

If you are installing from the cloned repository, just use

python setup.py install

Package is also available from PyPI. In that case, use

pip install funktown

ArchLinux users can install from the AUR

yaourt -S python2-funktown 
yaourt -S python-funktown # python 3 version

API

ImmutableVector

The constructor takes a list of initial values. It supports standard list operations such as item access, slicing, and concatenation.

assoc(index, value)

Returns a new vector with the value assigned to the given index

conj(value)

Returns a new vector with the value appended to the back. Roughly equivalent to vec.assoc(len(vec), value)

pop()

Returns a new vector with the final item removed.

ImmutableDict

The constructor can take a dict and/or keyword arguments. Item access follows the same behavior as builtin python dicts.

assoc(key, value)

Returns a new immutable dict with the value associated with the given key.

get(key)

Like in Python's builtin dict, this will act like item access, except returning None instead of raising a KeyError.

remove(key)

Return a new ImmutableDict with the item at that key removed

update(otherdict)

Return a new immutable dict updated with the records in otherdict.

Compatiblity

Funktown has been tested with Python 2.7.2 and 3.2.2 on a Linux system. It should be compatible with all python versions greater than 2.6.