from .symbology_object import SymbologyObject class Symbology(SymbologyObject): """ /symbology Positional arguments: No arguments are required. Optional arguments: All arguments are inherited from SymbologyObject Attributes: object : str . Returns the type of object it is. (card, error, etc) has_more : bool . True if there are more pages to the object. data : list . A list of all data returned. data_length : int . The length of the data returned. The following require an integer as an arg, which acts as a tuple. symbol_symbol(num) : str . The plaintext symbol, usually written with curly braces. symbol_loose_variant(num) : str . The alternate version of the symbol, without curly braces. symbol_transposable(num): bool . True if it's possibly to write the symbol backwards. symbol_represents_mana(num): bool . True if this is a mana symbol. symbol_cmc(num): float . The total converted mana cost of the symbol. symbol_appears_in_mana_costs(num): bool . True if the symbol appears on the mana cost of any card. symbol_funny(num): bool . True if the symbol is featured on any funny cards. symbol_colors(num): float . An array of all colors in the given symbol. Example usage: >>> symbol = scrython.symbology.Symbology() """ def __init__(self): self.url = 'symbology?' super(Symbology, self).__init__(self.url) def _checkForKey(self, key): try: return self.scryfallJson[key] except Exception: raise KeyError('This object ahs no key \'{}\''.format(key)) def _checkForTupleKey(self, parent, num, key): try: return self.scryfallJson[parent][num][key] except Exception: raise KeyError('This object has no key \'{}\''.format(key)) def object(self): self._checkForKey('object') return self.scryfallJson['object'] def has_more(self): self._checkForKey('has_more') return self.scryfallJson['has_more'] def data(self): self._checkForKey('has_more') return self.scryfallJson['data'] def data_length(self): self._checkForKey('data') return len(self.scryfallJson['data']) def symbol_symbol(self, num): self._checkForTupleKey('data', num, 'symbol') return self.scryfallJson['data'][num]['symbol'] def symbol_loose_variant(self, num): self._checkForTupleKey('data', num, 'loose_variant') return self.scryfallJson['data'][num]['loose_variant'] def symbol_transposable(self, num): self._checkForTupleKey('data', num, 'transposable') return self.scryfallJson['data'][num]['transposable'] def symbol_represents_mana(self, num): self._checkForTupleKey('data', num, 'represents_mana') return self.scryfallJson['data'][num]['represents_mana'] def symbol_cmc(self, num): self._checkForTupleKey('data', num, 'cmc') return self.scryfallJson['data'][num]['cmc'] def symbol_appears_in_mana_costs(self, num): self._checkForTupleKey('data', num, 'appears_in_mana_costs') return self.scryfallJson['data'][num]['appears_in_mana_costs'] def symbol_funny(self, num): self._checkForTupleKey('data', num, 'funny') return self.scryfallJson['data'][num]['funny'] def symbol_colors(self, num): self._checkForTupleKey('data', num, 'colors') return self.scryfallJson['data'][num]['colors']