Skip to main content

Your Python project companion

Project description

made-with-python License Documentation Status

This package adds functionality to core Python container classes and provides functions for common tasks.

Mappings

  • Dictionary: drop-in replacement for a python dict with an add method for a default mechanism of adding data, a delete method for a default mechanism of deleting data, and a subset method for returning a subset of the key/value pairs in a new Dictionary.
  • Catalog: wildcard-accepting dict which is intended for storing different options and strategies. It also returns lists of matches if a list of keys is provided.
  • Library: a chained mapping used for storing registered subclasses and instances.

Sequences

  • Listing: drop-in replacement for a python list with an add method for a default mechanism of adding data, a delete method for a default mechanism of deleting data, and a subset method for returning a subset of the key/value pairs in a new Listing.
  • Hybrid: iterable with both dict and list interfaces. Stored items must be hashable or have a name attribute.

Passthrough

  • Proxy: transparently wraps an object and directs access methods to access the wrapped object when appropriate (under construction for edge cases).

Factories

  • InstanceFactory: mixin that stores all subclass instances in the instances class attribute and returns stored instances when the create classmethod is called.
  • LibraryFactory: mixin that stores all subclasses and subclass instances in the library class attribute and returns stored subclasses and/or instances when the create classmethod is called.
  • SourceFactory: mixin that calls the appropriate creation method based on the type of passed first argument to create and the types stored in the keys of the sources class attribute.
  • StealthFactory: mixin that returns stored subclasses when the create classmethod is called without having a subclasses class attribute like SubclassFactory.
  • SubclassFactory: mixin that stores all subclasses in the subclasses class attribute and returns stored subclasses when the create classmethod is called.
  • TypeFactory: mixin that calls the appropriate creation method based on the type of passed first argument to create and the snakecase name of the type. This factory is prone to significant key errors unless you are sure of the snakecase names of all possible submitted type names. SourceFactory avoids this problem by allowing you to declare corresponding types and string names.

Converters

  • instancify: converts a class to an instance or adds kwargs to a passed instance as attributes.
  • listify: converts passed item to a list.
  • namify: returns hashable name for passed item.
  • numify: attempts to convert passed item to a numerical type.
  • pathlibify: converts a str to a pathlib object or leaves it as a pathlib object.
  • stringify:
  • tuplify: converts a passed item to a tuple.
  • typify: converts a str type to other common types, if possible.
  • windowify:
  • to_dict:
  • to_index:
  • str_to_index:
  • to_int:
  • str_to_int:
  • float_to_int:
  • to_list:
  • str_to_list:
  • to_float:
  • int_to_float:
  • str_to_float:
  • to_path:
  • str_to_path:
  • to_str:
  • int_to_str:
  • float_to_str:
  • list_to_str:
  • none_to_str:
  • path_to_str:
  • datetime_to_str:

Modifiers

  • Adders:
    • add_prefix: adds a str prefix to item.
    • add_slots: adds __slots__ to a dataclass.
    • add_suffix: adds a str suffix to item.
  • Dividers:
    • cleave: divides an item into 2 parts based on divider argument.
    • separate: divides an item into n+1 parts based on divider argument.
  • Subtractors:
    • deduplicate: removes duplicate data from an item.
    • drop_dunders: drops strings from a list if they start and end with double underscores.
    • drop_prefix: removes a str prefix from an item.
    • drop_prefix_from_dict
    • drop_prefix_from_list
    • drop_prefix_from_set
    • drop_prefix_from_str
    • drop_prefix_from_tuple
    • drop_privates
    • drop_substring: removes a substring from an item.
    • drop_suffix: removes a str suffix from an item.
    • drop_suffix_from_dict
    • drop_suffix_from_list
    • drop_suffix_from_set
    • drop_suffix_from_str
    • drop_suffix_from_tuple
  • Other:
    • capitalify: converts a snake case str to capital case.
    • snakify: converts a capital case str to snake case.
    • uniquify: returns a unique key for a dict.

Registers

  • registered: a decorator that stores a registry in a registry attribute of the function or class which is wrapped by the decorator.
  • Registrar: a mixin for automatic subclass registration.

Validators

  • bonafide: decorator that validates or converts types based on type annotations of the wrapped function or dataclass (under construction)

camina`s framework supports a wide range of coding styles. You can create complex multiple inheritance structures with mixins galore or simpler, compositional objects. Even though the data structures are necessarily object-oriented, all of the tools to modify them are also available as functions, for those who prefer a more funcitonal approaching to programming.

The project is also highly internally documented so that users and developers can easily make camina work with their projects. It is designed for Python coders at all levels. Beginners should be able to follow the readable code and internal documentation to understand how it works. More advanced users should find complex and tricky problems addressed through efficient code.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

camina-0.1.10.tar.gz (27.4 kB view hashes)

Uploaded Source

Built Distribution

camina-0.1.10-py3-none-any.whl (30.1 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page