mirror of
https://github.com/davidhalter/jedi.git
synced 2025-12-06 22:14:27 +08:00
Fix another django modelfield issue
This commit is contained in:
@@ -58,13 +58,13 @@ def _infer_scalar_field(inference_state, field_name, field_tree_instance):
|
|||||||
else:
|
else:
|
||||||
module = inference_state.import_module((module_name,))
|
module = inference_state.import_module((module_name,))
|
||||||
|
|
||||||
attribute, = module.py__getattribute__(attribute_name)
|
for attribute in module.py__getattribute__(attribute_name):
|
||||||
return DjangoModelField(attribute, field_name)
|
return DjangoModelField(attribute, field_name)
|
||||||
|
|
||||||
|
|
||||||
def _infer_field(cls, field_name):
|
def _infer_field(cls, field_name):
|
||||||
inference_state = cls.inference_state
|
inference_state = cls.inference_state
|
||||||
field_tree_instance, = field_name.infer()
|
for field_tree_instance in field_name.infer():
|
||||||
scalar_field = _infer_scalar_field(inference_state, field_name, field_tree_instance)
|
scalar_field = _infer_scalar_field(inference_state, field_name, field_tree_instance)
|
||||||
if scalar_field:
|
if scalar_field:
|
||||||
return scalar_field
|
return scalar_field
|
||||||
@@ -78,7 +78,8 @@ def _infer_field(cls, field_name):
|
|||||||
for value in lazy_values.infer():
|
for value in lazy_values.infer():
|
||||||
if value.py__name__() == 'str':
|
if value.py__name__() == 'str':
|
||||||
foreign_key_class_name = value.get_safe_value()
|
foreign_key_class_name = value.get_safe_value()
|
||||||
for v in cls.get_root_context().py__getattribute__(foreign_key_class_name):
|
module = cls.get_root_context()
|
||||||
|
for v in module.py__getattribute__(foreign_key_class_name):
|
||||||
if v.is_class():
|
if v.is_class():
|
||||||
return DjangoModelField(v, field_name)
|
return DjangoModelField(v, field_name)
|
||||||
elif value.is_class():
|
elif value.is_class():
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ class BusinessModel(models.Model):
|
|||||||
category_fk2 = models.ForeignKey('Category')
|
category_fk2 = models.ForeignKey('Category')
|
||||||
category_fk3 = models.ForeignKey(1)
|
category_fk3 = models.ForeignKey(1)
|
||||||
category_fk4 = models.ForeignKey('models')
|
category_fk4 = models.ForeignKey('models')
|
||||||
|
category_fk5 = models.ForeignKey()
|
||||||
integer_field = models.IntegerField()
|
integer_field = models.IntegerField()
|
||||||
big_integer_field = models.BigIntegerField()
|
big_integer_field = models.BigIntegerField()
|
||||||
positive_integer_field = models.PositiveIntegerField()
|
positive_integer_field = models.PositiveIntegerField()
|
||||||
@@ -34,6 +35,8 @@ class BusinessModel(models.Model):
|
|||||||
date_time_field = models.DateTimeField()
|
date_time_field = models.DateTimeField()
|
||||||
tags_m2m = models.ManyToManyField(Tag)
|
tags_m2m = models.ManyToManyField(Tag)
|
||||||
|
|
||||||
|
unidentifiable = NOT_FOUND
|
||||||
|
|
||||||
|
|
||||||
model_instance = BusinessModel()
|
model_instance = BusinessModel()
|
||||||
#? int()
|
#? int()
|
||||||
@@ -79,6 +82,13 @@ model_instance.category_fk2.category_name
|
|||||||
model_instance.category_fk3
|
model_instance.category_fk3
|
||||||
#? models.ForeignKey()
|
#? models.ForeignKey()
|
||||||
model_instance.category_fk4
|
model_instance.category_fk4
|
||||||
|
#? models.ForeignKey()
|
||||||
|
model_instance.category_fk5
|
||||||
|
|
||||||
#? models.ManyToManyField()
|
#? models.ManyToManyField()
|
||||||
model_instance.tags_m2m
|
model_instance.tags_m2m
|
||||||
|
|
||||||
|
#?
|
||||||
|
model_instance.unidentifiable
|
||||||
|
#! ['unidentifiable = NOT_FOUND']
|
||||||
|
model_instance.unidentifiable
|
||||||
|
|||||||
Reference in New Issue
Block a user