X-Git-Url: http://users.mur.at/ms/git/gitweb/?p=OpenColorIO-Configs.git;a=blobdiff_plain;f=aces_1.0.0%2Fpython%2Faces_ocio%2Futilities.py;h=1d426d98a659a28a45f09d23040d33ef8f31fbb9;hp=00804e3947710f1dea1e43cb236b01bcc5f9c1bd;hb=cad9d48a0f1067769435904348e9fffeffd25eb9;hpb=6eac5f132b3888eee16a8306d91b9405346f3ac2 diff --git a/aces_1.0.0/python/aces_ocio/utilities.py b/aces_1.0.0/python/aces_ocio/utilities.py index 00804e3..1d426d9 100644 --- a/aces_1.0.0/python/aces_ocio/utilities.py +++ b/aces_1.0.0/python/aces_ocio/utilities.py @@ -5,10 +5,14 @@ Defines various package utilities objects. """ +from __future__ import division + +import itertools import os import re +from collections import OrderedDict -import PyOpenColorIO as OCIO +import PyOpenColorIO as ocio __author__ = 'ACES Developers' __copyright__ = 'Copyright (C) 2014 - 2015 - ACES Developers' @@ -20,11 +24,13 @@ __status__ = 'Production' __all__ = ['ColorSpace', 'mat44_from_mat33', 'filter_words', - 'files_walker'] + 'files_walker', + 'replace', + 'sanitize', + 'compact', + 'colorspace_prefixed_name', + 'unpack_default'] -# -# Utility classes and functions -# class ColorSpace(object): """ @@ -33,15 +39,17 @@ class ColorSpace(object): def __init__(self, name, + aliases=[], description=None, - bit_depth=OCIO.Constants.BIT_DEPTH_F32, - equality_group=None, + bit_depth=ocio.Constants.BIT_DEPTH_F32, + equality_group='', family=None, is_data=False, to_reference_transforms=[], from_reference_transforms=[], - allocation_type=OCIO.Constants.ALLOCATION_UNIFORM, - allocation_vars=[0.0, 1.0]): + allocation_type=ocio.Constants.ALLOCATION_UNIFORM, + allocation_vars=[0, 1], + aces_transform_id=None): """ Object description. @@ -57,6 +65,7 @@ class ColorSpace(object): """ self.name = name + self.aliases = aliases self.bit_depth = bit_depth self.description = description self.equality_group = equality_group @@ -66,6 +75,7 @@ class ColorSpace(object): self.from_reference_transforms = from_reference_transforms self.allocation_type = allocation_type self.allocation_vars = allocation_vars + self.aces_transform_id = aces_transform_id def mat44_from_mat33(mat33): @@ -83,10 +93,10 @@ def mat44_from_mat33(mat33): Return value description. """ - return [mat33[0], mat33[1], mat33[2], 0.0, - mat33[3], mat33[4], mat33[5], 0.0, - mat33[6], mat33[7], mat33[8], 0.0, - 0, 0, 0, 1.0] + return [mat33[0], mat33[1], mat33[2], 0, + mat33[3], mat33[4], mat33[5], 0, + mat33[6], mat33[7], mat33[8], 0, + 0, 0, 0, 1] def filter_words(words, filters_in=None, filters_out=None, flags=0): @@ -142,9 +152,8 @@ def files_walker(directory, filters_in=None, filters_out=None, flags=0): Return value description. """ - for parent_directory, directories, files in os.walk(directory, - topdown=False, - followlinks=True): + for parent_directory, directories, files in os.walk( + directory, topdown=False, followlinks=True): for file in files: path = os.path.join(parent_directory, file) if os.path.isfile(path): @@ -152,3 +161,122 @@ def files_walker(directory, filters_in=None, filters_out=None, flags=0): continue yield path + + +def replace(string, data): + """ + Replaces the data occurrences in the string. + + Parameters + ---------- + string : str or unicode + String to manipulate. + data : dict + Replacement occurrences. + + Returns + ------- + unicode + Manipulated string. + + Examples + -------- + >>> patterns = {"John" : "Luke", + ... "Jane" : "Anakin", + ... "Doe" : "Skywalker", + ... "Z6PO" : "R2D2"} + >>> data = "Users are: John Doe, Jane Doe, Z6PO." + >>> replace(data,patterns ) + u'Users are: Luke Skywalker, Anakin Skywalker, R2D2.' + """ + + for old, new in data.iteritems(): + string = string.replace(old, new) + return string + + +def sanitize(path): + """ + Object description. + + Parameters + ---------- + parameter : type + Parameter description. + + Returns + ------- + type + Return value description. + """ + + return replace(path, {' ': '_', ')': '_', '(': '_'}) + + +def compact(string): + """ + Removes blanks, underscores, dashes and parentheses. + + Parameters + ---------- + string : str or unicode + String to compact. + + Returns + ------- + str or unicode + A compact version of that string. + """ + + return replace(string.lower(), + OrderedDict(((' ', '_'), + ('(', '_'), + (')', '_'), + ('.', '_'), + ('-', '_'), + ('___', '_'), + ('__', '_'), + ('_', '')))) + + +def colorspace_prefixed_name(colorspace): + """ + Returns given *OCIO* colorspace prefixed name with its family name. + + Parameters + ---------- + colorspace : Colorspace + Colorspace to prefix. + + Returns + ------- + str or unicode + Family prefixed *OCIO* colorspace name. + """ + prefix = colorspace.family.replace('/', ' - ') + + return '%s - %s' % (prefix, colorspace.name) + + +def unpack_default(iterable, length=3, default=None): + """ + Unpacks given iterable maintaining given length and filling missing + entries with given default. + + Parameters + ---------- + iterable : object + Iterable. + length : int + Iterable length. + default : object + Filling default object. + + Returns + ------- + iterable + """ + + return itertools.islice(itertools.chain(iter(iterable), + itertools.repeat(default)), + length)