mirror of
https://github.com/django/django.git
synced 2024-12-28 12:06:22 +00:00
0c7633178f
Refactored compiler SELECT, GROUP BY and ORDER BY generation. While there, also refactored select_related() implementation (get_cached_row() and get_klass_info() are now gone!). Made get_db_converters() method work on expressions instead of internal_type. This allows the backend converters to target specific expressions if need be. Added query.context, this can be used to set per-query state. Also changed the signature of database converters. They now accept context as an argument.
33 lines
750 B
Python
33 lines
750 B
Python
import decimal
|
|
|
|
from django.db import models
|
|
from django.utils.encoding import python_2_unicode_compatible
|
|
|
|
|
|
class Cash(decimal.Decimal):
|
|
currency = 'USD'
|
|
|
|
def __str__(self):
|
|
s = super(Cash, self).__str__(self)
|
|
return '%s %s' % (s, self.currency)
|
|
|
|
|
|
class CashField(models.DecimalField):
|
|
def __init__(self, **kwargs):
|
|
kwargs['max_digits'] = 20
|
|
kwargs['decimal_places'] = 2
|
|
super(CashField, self).__init__(**kwargs)
|
|
|
|
def from_db_value(self, value, connection, context):
|
|
cash = Cash(value)
|
|
cash.vendor = connection.vendor
|
|
return cash
|
|
|
|
|
|
@python_2_unicode_compatible
|
|
class CashModel(models.Model):
|
|
cash = CashField()
|
|
|
|
def __str__(self):
|
|
return str(self.cash)
|