Django

Code

Ticket #399: django-bigint-20070712.patch

File django-bigint-20070712.patch, 7.4 kB (added by Peter Nixon <listuser@peternixon.net>, 1 year ago)

Add BigIntegerField?? support to django (SQLite, MySQL, Postgresql (and postgresql_psycopg2), Oracle, MSSQL)

  • django/oldforms/__init__.py

    old new  
    759759        if not 0 <= int(field_data) <= 32767: 
    760760            raise validators.CriticalValidationError, ugettext("Enter a whole number between 0 and 32,767.") 
    761761 
     762class BigIntegerField(IntegerField): 
     763    def __init__(self, field_name, length=20, maxlength=None, is_required=False, validator_list=None, member_name=None): 
     764        if validator_list is None: validator_list = [] 
     765        validator_list = [self.isInteger] + validator_list 
     766        if member_name is not None: 
     767            self.member_name = member_name 
     768        IntegerField.__init__(self, field_name, length, maxlength, is_required, validator_list) 
     769 
    762770class FloatField(TextField): 
    763771    def __init__(self, field_name, is_required=False, validator_list=None):  
    764772        if validator_list is None: validator_list = []  
  • django/db/models/fields/__init__.py

    old new  
    800800        defaults.update(kwargs) 
    801801        return super(IntegerField, self).formfield(**defaults) 
    802802 
     803class BigIntegerField(IntegerField): 
     804    empty_strings_allowed = False 
     805    def get_manipulator_field_objs(self): 
     806        return [oldforms.BigIntegerField] 
     807 
    803808class IPAddressField(Field): 
    804809    empty_strings_allowed = False 
    805810    def __init__(self, *args, **kwargs): 
  • django/db/backends/ado_mssql/creation.py

    old new  
    1111    'FloatField':        'double precision', 
    1212    'ImageField':        'varchar(100)', 
    1313    'IntegerField':      'int', 
     14    'BigIntegerField':   'bigint', 
    1415    'IPAddressField':    'char(15)', 
    1516    'ManyToManyField':   None, 
    1617    'NullBooleanField':  'bit', 
  • django/db/backends/postgresql/introspection.py

    old new  
    6969# Maps type codes to Django Field types. 
    7070DATA_TYPES_REVERSE = { 
    7171    16: 'BooleanField', 
     72    20: 'BigIntegerField', 
    7273    21: 'SmallIntegerField', 
    7374    23: 'IntegerField', 
    7475    25: 'TextField', 
  • django/db/backends/postgresql/creation.py

    old new  
    1515    'FloatField':        'double precision', 
    1616    'ImageField':        'varchar(100)', 
    1717    'IntegerField':      'integer', 
     18    'BigIntegerField':   'bigint', 
    1819    'IPAddressField':    'inet', 
    1920    'ManyToManyField':   None, 
    2021    'NullBooleanField':  'boolean', 
  • django/db/backends/sqlite3/introspection.py

    old new  
    6262    'smallinteger': 'SmallIntegerField', 
    6363    'int': 'IntegerField', 
    6464    'integer': 'IntegerField', 
     65    'bigint': 'BigIntegerField', 
    6566    'text': 'TextField', 
    6667    'char': 'CharField', 
    6768    'date': 'DateField', 
  • django/db/backends/sqlite3/creation.py

    old new  
    1414    'FloatField':                   'real', 
    1515    'ImageField':                   'varchar(100)', 
    1616    'IntegerField':                 'integer', 
     17    'BigIntegerField':              'bigint', 
    1718    'IPAddressField':               'char(15)', 
    1819    'ManyToManyField':              None, 
    1920    'NullBooleanField':             'bool', 
  • django/db/backends/mysql/introspection.py

    old new  
    8383    FIELD_TYPE.FLOAT: 'FloatField', 
    8484    FIELD_TYPE.INT24: 'IntegerField', 
    8585    FIELD_TYPE.LONG: 'IntegerField', 
    86     FIELD_TYPE.LONGLONG: 'IntegerField', 
     86    FIELD_TYPE.LONGLONG: 'BigIntegerField', 
    8787    FIELD_TYPE.SHORT: 'IntegerField', 
    8888    FIELD_TYPE.STRING: 'CharField', 
    8989    FIELD_TYPE.TIMESTAMP: 'DateTimeField', 
  • django/db/backends/mysql/creation.py

    old new  
    1515    'FloatField':        'double precision', 
    1616    'ImageField':        'varchar(100)', 
    1717    'IntegerField':      'integer', 
     18    'BigIntegerField':   'bigint', 
    1819    'IPAddressField':    'char(15)', 
    1920    'ManyToManyField':   None, 
    2021    'NullBooleanField':  'bool', 
  • django/db/backends/oracle/creation.py

    old new  
    1818    'FloatField':                   'DOUBLE PRECISION', 
    1919    'ImageField':                   'NVARCHAR2(100)', 
    2020    'IntegerField':                 'NUMBER(11)', 
     21    'BigIntegerField':              'NUMBER(19)', 
    2122    'IPAddressField':               'VARCHAR2(15)', 
    2223    'ManyToManyField':              None, 
    2324    'NullBooleanField':             'NUMBER(1) CHECK ((%(column)s IN (0,1)) OR (%(column)s IS NULL))', 
  • django/db/backends/postgresql_psycopg2/introspection.py

    old new  
    6969# Maps type codes to Django Field types. 
    7070DATA_TYPES_REVERSE = { 
    7171    16: 'BooleanField', 
     72    20: 'BigIntegerField', 
    7273    21: 'SmallIntegerField', 
    7374    23: 'IntegerField', 
    7475    25: 'TextField', 
  • django/contrib/admin/views/doc.py

    old new  
    303303    'ForeignKey'                : _('Integer'), 
    304304    'ImageField'                : _('File path'), 
    305305    'IntegerField'              : _('Integer'), 
     306    'BigIntegerField'           : _('Integer'), 
    306307    'IPAddressField'            : _('IP address'), 
    307308    'ManyToManyField'           : '', 
    308309    'NullBooleanField'          : _('Boolean (Either True, False or None)'), 
  • docs/model-api.txt

    old new  
    126126automatically be added to your model if you don't specify otherwise. See 
    127127`Automatic primary key fields`_. 
    128128 
     129``BigIntegerField`` 
     130~~~~~~~~~~~~~~~~ 
     131 
     132A big integer. 
     133 
     134The admin represents this as an ``<input type="text">`` (a single-line input). 
     135 
     136A 64 bit type like an ``IntegerField``, except that it fits numbers from 
     137-9223372036854775808 to 9223372036854775807 
     138 
    129139``BooleanField`` 
    130140~~~~~~~~~~~~~~~~ 
    131141