mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #26021 -- Applied hanging indentation to docs.
This commit is contained in:
		| @@ -106,11 +106,13 @@ options can be added in the :meth:`~BaseCommand.add_arguments` method like this: | ||||
|             parser.add_argument('poll_id', nargs='+', type=int) | ||||
|  | ||||
|             # Named (optional) arguments | ||||
|             parser.add_argument('--delete', | ||||
|             parser.add_argument( | ||||
|                 '--delete', | ||||
|                 action='store_true', | ||||
|                 dest='delete', | ||||
|                 default=False, | ||||
|                 help='Delete poll instead of closing it') | ||||
|                 help='Delete poll instead of closing it', | ||||
|             ) | ||||
|  | ||||
|         def handle(self, *args, **options): | ||||
|             # ... | ||||
|   | ||||
| @@ -202,10 +202,12 @@ filtered out of error reports in a production environment (that is, where | ||||
|  | ||||
|         @sensitive_post_parameters('pass_word', 'credit_card_number') | ||||
|         def record_user_profile(request): | ||||
|             UserProfile.create(user=request.user, | ||||
|             UserProfile.create( | ||||
|                 user=request.user, | ||||
|                 password=request.POST['pass_word'], | ||||
|                 credit_card=request.POST['credit_card_number'], | ||||
|                                name=request.POST['name']) | ||||
|                 name=request.POST['name'], | ||||
|             ) | ||||
|             ... | ||||
|  | ||||
|     In the above example, the values for the ``pass_word`` and | ||||
|   | ||||
| @@ -104,9 +104,9 @@ Here's how this might look in a fabfile:: | ||||
|     def deploy_static(): | ||||
|         local('./manage.py collectstatic') | ||||
|         project.rsync_project( | ||||
|             remote_dir = env.remote_static_root, | ||||
|             local_dir = env.local_static_root, | ||||
|             delete = True | ||||
|             remote_dir=env.remote_static_root, | ||||
|             local_dir=env.local_static_root, | ||||
|             delete=True, | ||||
|         ) | ||||
|  | ||||
| .. _staticfiles-from-cdn: | ||||
|   | ||||
| @@ -462,8 +462,7 @@ class: | ||||
|         in the past, positive for questions that have yet to be published). | ||||
|         """ | ||||
|         time = timezone.now() + datetime.timedelta(days=days) | ||||
|         return Question.objects.create(question_text=question_text, | ||||
|                                        pub_date=time) | ||||
|         return Question.objects.create(question_text=question_text, pub_date=time) | ||||
|  | ||||
|  | ||||
|     class QuestionViewTests(TestCase): | ||||
| @@ -495,8 +494,7 @@ class: | ||||
|             """ | ||||
|             create_question(question_text="Future question.", days=30) | ||||
|             response = self.client.get(reverse('polls:index')) | ||||
|             self.assertContains(response, "No polls are available.", | ||||
|                                 status_code=200) | ||||
|             self.assertContains(response, "No polls are available.") | ||||
|             self.assertQuerysetEqual(response.context['latest_question_list'], []) | ||||
|  | ||||
|         def test_index_view_with_future_question_and_past_question(self): | ||||
| @@ -580,10 +578,9 @@ in the future is not: | ||||
|             The detail view of a question with a pub_date in the future should | ||||
|             return a 404 not found. | ||||
|             """ | ||||
|             future_question = create_question(question_text='Future question.', | ||||
|                                               days=5) | ||||
|             response = self.client.get(reverse('polls:detail', | ||||
|                                        args=(future_question.id,))) | ||||
|             future_question = create_question(question_text='Future question.', days=5) | ||||
|             url = reverse('polls:detail', args=(future_question.id,)) | ||||
|             response = self.client.get(url) | ||||
|             self.assertEqual(response.status_code, 404) | ||||
|  | ||||
|         def test_detail_view_with_a_past_question(self): | ||||
| @@ -591,13 +588,10 @@ in the future is not: | ||||
|             The detail view of a question with a pub_date in the past should | ||||
|             display the question's text. | ||||
|             """ | ||||
|             past_question = create_question(question_text='Past Question.', | ||||
|                                             days=-5) | ||||
|             response = self.client.get(reverse('polls:detail', | ||||
|                                        args=(past_question.id,))) | ||||
|             self.assertContains(response, past_question.question_text, | ||||
|                                 status_code=200) | ||||
|  | ||||
|             past_question = create_question(question_text='Past Question.', days=-5) | ||||
|             url = reverse('polls:detail', args=(past_question.id,)) | ||||
|             response = self.client.get(url) | ||||
|             self.assertContains(response, past_question.question_text) | ||||
|  | ||||
| Ideas for more tests | ||||
| -------------------- | ||||
|   | ||||
| @@ -615,10 +615,12 @@ subclass:: | ||||
|               color_code = models.CharField(max_length=6) | ||||
|  | ||||
|               def colored_name(self): | ||||
|                   return format_html('<span style="color: #{};">{} {}</span>', | ||||
|                   return format_html( | ||||
|                       '<span style="color: #{};">{} {}</span>', | ||||
|                       self.color_code, | ||||
|                       self.first_name, | ||||
|                                      self.last_name) | ||||
|                       self.last_name, | ||||
|                   ) | ||||
|  | ||||
|           class PersonAdmin(admin.ModelAdmin): | ||||
|               list_display = ('first_name', 'last_name', 'colored_name') | ||||
| @@ -700,9 +702,11 @@ subclass:: | ||||
|             color_code = models.CharField(max_length=6) | ||||
|  | ||||
|             def colored_first_name(self): | ||||
|                 return format_html('<span style="color: #{};">{}</span>', | ||||
|                 return format_html( | ||||
|                     '<span style="color: #{};">{}</span>', | ||||
|                     self.color_code, | ||||
|                                    self.first_name) | ||||
|                     self.first_name, | ||||
|                 ) | ||||
|  | ||||
|             colored_first_name.admin_order_field = 'first_name' | ||||
|  | ||||
| @@ -906,13 +910,11 @@ subclass:: | ||||
|  | ||||
|                   def lookups(self, request, model_admin): | ||||
|                       if request.user.is_superuser: | ||||
|                           return super(AuthDecadeBornListFilter, | ||||
|                               self).lookups(request, model_admin) | ||||
|                           return super(AuthDecadeBornListFilter, self).lookups(request, model_admin) | ||||
|  | ||||
|                   def queryset(self, request, queryset): | ||||
|                       if request.user.is_superuser: | ||||
|                           return super(AuthDecadeBornListFilter, | ||||
|                               self).queryset(request, queryset) | ||||
|                           return super(AuthDecadeBornListFilter, self).queryset(request, queryset) | ||||
|  | ||||
|           Also as a convenience, the ``ModelAdmin`` object is passed to | ||||
|           the ``lookups`` method, for example if you want to base the | ||||
| @@ -1268,8 +1270,8 @@ subclass:: | ||||
|  | ||||
|         class PersonAdmin(admin.ModelAdmin): | ||||
|             def view_on_site(self, obj): | ||||
|                 return 'https://example.com' + reverse('person-detail', | ||||
|                                                        kwargs={'slug': obj.slug}) | ||||
|                 url = reverse('person-detail', kwargs={'slug': obj.slug}) | ||||
|                 return 'https://example.com' + url | ||||
|  | ||||
| Custom template options | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
| @@ -1875,8 +1877,9 @@ provided some extra mapping data that would not otherwise be available:: | ||||
|         def change_view(self, request, object_id, form_url='', extra_context=None): | ||||
|             extra_context = extra_context or {} | ||||
|             extra_context['osm_data'] = self.get_osm_info() | ||||
|             return super(MyModelAdmin, self).change_view(request, object_id, | ||||
|                 form_url, extra_context=extra_context) | ||||
|             return super(MyModelAdmin, self).change_view( | ||||
|                 request, object_id, form_url, extra_context=extra_context, | ||||
|             ) | ||||
|  | ||||
| These views return :class:`~django.template.response.TemplateResponse` | ||||
| instances which allow you to easily customize the response data before | ||||
|   | ||||
| @@ -120,7 +120,7 @@ raster models:: | ||||
|  | ||||
|     >>> from django.contrib.gis.gdal import GDALRaster | ||||
|     >>> rast = GDALRaster({'width': 10, 'height': 10, 'name': 'Canyon', 'srid': 4326, | ||||
|     ...                    'scale': [0.1, -0.1]'bands': [{"data": range(100)}]} | ||||
|     ...                    'scale': [0.1, -0.1], 'bands': [{"data": range(100)}]}) | ||||
|     >>> dem = Elevation(name='Canyon', rast=rast) | ||||
|     >>> dem.save() | ||||
|  | ||||
| @@ -129,7 +129,7 @@ Note that this equivalent to:: | ||||
|     >>> dem = Elevation.objects.create( | ||||
|     ...     name='Canyon', | ||||
|     ...     rast={'width': 10, 'height': 10, 'name': 'Canyon', 'srid': 4326, | ||||
|     ...           'scale': [0.1, -0.1]'bands': [{"data": range(100)}]} | ||||
|     ...           'scale': [0.1, -0.1], 'bands': [{"data": range(100)}]}, | ||||
|     ... ) | ||||
|  | ||||
| .. _spatial-lookups-intro: | ||||
|   | ||||
| @@ -452,12 +452,15 @@ with the following code:: | ||||
|         'mpoly' : 'MULTIPOLYGON', | ||||
|     } | ||||
|  | ||||
|     world_shp = os.path.abspath(os.path.join(os.path.dirname(__file__), 'data', 'TM_WORLD_BORDERS-0.3.shp')) | ||||
|     world_shp = os.path.abspath( | ||||
|         os.path.join(os.path.dirname(__file__), 'data', 'TM_WORLD_BORDERS-0.3.shp'), | ||||
|     ) | ||||
|  | ||||
|     def run(verbose=True): | ||||
|         lm = LayerMapping(WorldBorder, world_shp, world_mapping, | ||||
|                           transform=False, encoding='iso-8859-1') | ||||
|  | ||||
|         lm = LayerMapping( | ||||
|             WorldBorder, world_shp, world_mapping, | ||||
|             transform=False, encoding='iso-8859-1', | ||||
|         ) | ||||
|         lm.save(strict=True, verbose=verbose) | ||||
|  | ||||
| A few notes about what's going on: | ||||
|   | ||||
| @@ -320,8 +320,7 @@ Adding extra message tags | ||||
| For more direct control over message tags, you can optionally provide a string | ||||
| containing extra tags to any of the add methods:: | ||||
|  | ||||
|     messages.add_message(request, messages.INFO, 'Over 9000!', | ||||
|                          extra_tags='dragonball') | ||||
|     messages.add_message(request, messages.INFO, 'Over 9000!', extra_tags='dragonball') | ||||
|     messages.error(request, 'Email box full', extra_tags='email') | ||||
|  | ||||
| Extra tags are added before the default tag for that level and are space | ||||
| @@ -336,8 +335,10 @@ if they don't want to, you may pass an additional keyword argument | ||||
| ``fail_silently=True`` to any of the ``add_message`` family of methods. For | ||||
| example:: | ||||
|  | ||||
|     messages.add_message(request, messages.SUCCESS, 'Profile details updated.', | ||||
|                          fail_silently=True) | ||||
|     messages.add_message( | ||||
|         request, messages.SUCCESS, 'Profile details updated.', | ||||
|         fail_silently=True, | ||||
|     ) | ||||
|     messages.info(request, 'Hello world.', fail_silently=True) | ||||
|  | ||||
| .. note:: | ||||
|   | ||||
| @@ -197,10 +197,14 @@ Here's an example of what the form-handling view looks like:: | ||||
|         # ... | ||||
|  | ||||
|         current_site = get_current_site(request) | ||||
|         send_mail('Thanks for subscribing to %s alerts' % current_site.name, | ||||
|             'Thanks for your subscription. We appreciate it.\n\n-The %s team.' % current_site.name, | ||||
|         send_mail( | ||||
|             'Thanks for subscribing to %s alerts' % current_site.name, | ||||
|             'Thanks for your subscription. We appreciate it.\n\n-The %s team.' % ( | ||||
|                 current_site.name, | ||||
|             ), | ||||
|             'editor@%s' % current_site.domain, | ||||
|             [user.email]) | ||||
|             [user.email], | ||||
|         ) | ||||
|  | ||||
|         # ... | ||||
|  | ||||
|   | ||||
| @@ -998,16 +998,25 @@ Slightly complex built-in ``Field`` classes | ||||
|                     } | ||||
|                     # Or define a different message for each field. | ||||
|                     fields = ( | ||||
|                         CharField(error_messages={'incomplete': 'Enter a country calling code.'}, | ||||
|                                   validators=[RegexValidator(r'^[0-9]+$', 'Enter a valid country calling code.')]), | ||||
|                         CharField(error_messages={'incomplete': 'Enter a phone number.'}, | ||||
|                                   validators=[RegexValidator(r'^[0-9]+$', 'Enter a valid phone number.')]), | ||||
|                         CharField(validators=[RegexValidator(r'^[0-9]+$', 'Enter a valid extension.')], | ||||
|                                   required=False), | ||||
|                         CharField( | ||||
|                             error_messages={'incomplete': 'Enter a country calling code.'}, | ||||
|                             validators=[ | ||||
|                                 RegexValidator(r'^[0-9]+$', 'Enter a valid country calling code.'), | ||||
|                             ], | ||||
|                         ), | ||||
|                         CharField( | ||||
|                             error_messages={'incomplete': 'Enter a phone number.'}, | ||||
|                             validators=[RegexValidator(r'^[0-9]+$', 'Enter a valid phone number.')], | ||||
|                         ), | ||||
|                         CharField( | ||||
|                             validators=[RegexValidator(r'^[0-9]+$', 'Enter a valid extension.')], | ||||
|                             required=False, | ||||
|                         ), | ||||
|                     ) | ||||
|                     super(PhoneField, self).__init__( | ||||
|                         error_messages=error_messages, fields=fields, | ||||
|                         require_all_fields=False, *args, **kwargs) | ||||
|                         require_all_fields=False, *args, **kwargs | ||||
|                     ) | ||||
|  | ||||
|     .. attribute:: MultiValueField.widget | ||||
|  | ||||
|   | ||||
| @@ -62,8 +62,11 @@ widget on the field. In the following example, the | ||||
|  | ||||
|     class SimpleForm(forms.Form): | ||||
|         birth_year = forms.DateField(widget=forms.SelectDateWidget(years=BIRTH_YEAR_CHOICES)) | ||||
|         favorite_colors = forms.MultipleChoiceField(required=False, | ||||
|             widget=forms.CheckboxSelectMultiple, choices=FAVORITE_COLORS_CHOICES) | ||||
|         favorite_colors = forms.MultipleChoiceField( | ||||
|             required=False, | ||||
|             widget=forms.CheckboxSelectMultiple, | ||||
|             choices=FAVORITE_COLORS_CHOICES, | ||||
|         ) | ||||
|  | ||||
| See the :ref:`built-in widgets` for more information about which widgets | ||||
| are available and which arguments they accept. | ||||
|   | ||||
| @@ -371,7 +371,8 @@ SQL that is generated. Here's a brief example:: | ||||
|                 expression, | ||||
|                 distinct='DISTINCT ' if distinct else '', | ||||
|                 output_field=IntegerField(), | ||||
|                 **extra) | ||||
|                 **extra | ||||
|             ) | ||||
|  | ||||
|  | ||||
| ``Value()`` expressions | ||||
|   | ||||
| @@ -112,9 +112,11 @@ define a suitably-named constant for each value:: | ||||
|             (JUNIOR, 'Junior'), | ||||
|             (SENIOR, 'Senior'), | ||||
|         ) | ||||
|         year_in_school = models.CharField(max_length=2, | ||||
|         year_in_school = models.CharField( | ||||
|             max_length=2, | ||||
|             choices=YEAR_IN_SCHOOL_CHOICES, | ||||
|                                           default=FRESHMAN) | ||||
|             default=FRESHMAN, | ||||
|         ) | ||||
|  | ||||
|         def is_upperclass(self): | ||||
|             return self.year_in_school in (self.JUNIOR, self.SENIOR) | ||||
|   | ||||
| @@ -967,9 +967,10 @@ authentication app:: | ||||
|             Creates and saves a superuser with the given email, date of | ||||
|             birth and password. | ||||
|             """ | ||||
|             user = self.create_user(email, | ||||
|             user = self.create_user( | ||||
|                 email, | ||||
|                 password=password, | ||||
|                 date_of_birth=date_of_birth | ||||
|                 date_of_birth=date_of_birth, | ||||
|             ) | ||||
|             user.is_admin = True | ||||
|             user.save(using=self._db) | ||||
|   | ||||
| @@ -249,9 +249,11 @@ in ``myapp``:: | ||||
|     from django.contrib.contenttypes.models import ContentType | ||||
|  | ||||
|     content_type = ContentType.objects.get_for_model(BlogPost) | ||||
|     permission = Permission.objects.create(codename='can_publish', | ||||
|     permission = Permission.objects.create( | ||||
|         codename='can_publish', | ||||
|         name='Can Publish Posts', | ||||
|                                            content_type=content_type) | ||||
|         content_type=content_type, | ||||
|     ) | ||||
|  | ||||
| The permission can then be assigned to a | ||||
| :class:`~django.contrib.auth.models.User` via its ``user_permissions`` | ||||
|   | ||||
| @@ -849,14 +849,16 @@ precede the definition of any keyword arguments. For example:: | ||||
|  | ||||
|     Poll.objects.get( | ||||
|         Q(pub_date=date(2005, 5, 2)) | Q(pub_date=date(2005, 5, 6)), | ||||
|         question__startswith='Who') | ||||
|         question__startswith='Who', | ||||
|     ) | ||||
|  | ||||
| ... would be a valid query, equivalent to the previous example; but:: | ||||
|  | ||||
|     # INVALID QUERY | ||||
|     Poll.objects.get( | ||||
|         question__startswith='Who', | ||||
|         Q(pub_date=date(2005, 5, 2)) | Q(pub_date=date(2005, 5, 6))) | ||||
|         Q(pub_date=date(2005, 5, 2)) | Q(pub_date=date(2005, 5, 6)) | ||||
|     ) | ||||
|  | ||||
| ... would not be valid. | ||||
|  | ||||
|   | ||||
| @@ -20,8 +20,13 @@ In two lines:: | ||||
|  | ||||
|     from django.core.mail import send_mail | ||||
|  | ||||
|     send_mail('Subject here', 'Here is the message.', 'from@example.com', | ||||
|         ['to@example.com'], fail_silently=False) | ||||
|     send_mail( | ||||
|         'Subject here', | ||||
|         'Here is the message.', | ||||
|         'from@example.com', | ||||
|         ['to@example.com'], | ||||
|         fail_silently=False, | ||||
|     ) | ||||
|  | ||||
| Mail is sent using the SMTP host and port specified in the | ||||
| :setting:`EMAIL_HOST` and :setting:`EMAIL_PORT` settings. The | ||||
| @@ -149,8 +154,12 @@ Examples | ||||
| This sends a single email to john@example.com and jane@example.com, with them | ||||
| both appearing in the "To:":: | ||||
|  | ||||
|     send_mail('Subject', 'Message.', 'from@example.com', | ||||
|         ['john@example.com', 'jane@example.com']) | ||||
|     send_mail( | ||||
|         'Subject', | ||||
|         'Message.', | ||||
|         'from@example.com', | ||||
|         ['john@example.com', 'jane@example.com'], | ||||
|     ) | ||||
|  | ||||
| This sends a message to john@example.com and jane@example.com, with them both | ||||
| receiving a separate email:: | ||||
| @@ -281,9 +290,15 @@ For example:: | ||||
|  | ||||
|     from django.core.mail import EmailMessage | ||||
|  | ||||
|     email = EmailMessage('Hello', 'Body goes here', 'from@example.com', | ||||
|                 ['to1@example.com', 'to2@example.com'], ['bcc@example.com'], | ||||
|                 reply_to=['another@example.com'], headers={'Message-ID': 'foo'}) | ||||
|     email = EmailMessage( | ||||
|         'Hello', | ||||
|         'Body goes here', | ||||
|         'from@example.com', | ||||
|         ['to1@example.com', 'to2@example.com'], | ||||
|         ['bcc@example.com'], | ||||
|         reply_to=['another@example.com'], | ||||
|         headers={'Message-ID': 'foo'}, | ||||
|     ) | ||||
|  | ||||
| The class has the following methods: | ||||
|  | ||||
| @@ -405,10 +420,14 @@ It can also be used as a context manager, which will automatically call | ||||
|     from django.core import mail | ||||
|  | ||||
|     with mail.get_connection() as connection: | ||||
|         mail.EmailMessage(subject1, body1, from1, [to1], | ||||
|                           connection=connection).send() | ||||
|         mail.EmailMessage(subject2, body2, from2, [to2], | ||||
|                           connection=connection).send() | ||||
|         mail.EmailMessage( | ||||
|             subject1, body1, from1, [to1], | ||||
|             connection=connection, | ||||
|         ).send() | ||||
|         mail.EmailMessage( | ||||
|             subject2, body2, from2, [to2], | ||||
|             connection=connection, | ||||
|         ).send() | ||||
|  | ||||
| Obtaining an instance of an email backend | ||||
| ----------------------------------------- | ||||
| @@ -592,15 +611,28 @@ manually open the connection, you can control when it is closed. For example:: | ||||
|     connection.open() | ||||
|  | ||||
|     # Construct an email message that uses the connection | ||||
|     email1 = mail.EmailMessage('Hello', 'Body goes here', 'from@example.com', | ||||
|                               ['to1@example.com'], connection=connection) | ||||
|     email1 = mail.EmailMessage( | ||||
|         'Hello', | ||||
|         'Body goes here', | ||||
|         'from@example.com', | ||||
|         ['to1@example.com'], | ||||
|         connection=connection, | ||||
|     ) | ||||
|     email1.send() # Send the email | ||||
|  | ||||
|     # Construct two more messages | ||||
|     email2 = mail.EmailMessage('Hello', 'Body goes here', 'from@example.com', | ||||
|                               ['to2@example.com']) | ||||
|     email3 = mail.EmailMessage('Hello', 'Body goes here', 'from@example.com', | ||||
|                               ['to3@example.com']) | ||||
|     email2 = mail.EmailMessage( | ||||
|         'Hello', | ||||
|         'Body goes here', | ||||
|         'from@example.com', | ||||
|         ['to2@example.com'], | ||||
|     ) | ||||
|     email3 = mail.EmailMessage( | ||||
|         'Hello', | ||||
|         'Body goes here', | ||||
|         'from@example.com', | ||||
|         ['to3@example.com'], | ||||
|     ) | ||||
|  | ||||
|     # Send the two emails in a single call - | ||||
|     connection.send_messages([email2, email3]) | ||||
|   | ||||
| @@ -195,8 +195,10 @@ we'll discuss in a moment.):: | ||||
|  | ||||
|     class AuthorForm(forms.Form): | ||||
|         name = forms.CharField(max_length=100) | ||||
|         title = forms.CharField(max_length=3, | ||||
|                     widget=forms.Select(choices=TITLE_CHOICES)) | ||||
|         title = forms.CharField( | ||||
|             max_length=3, | ||||
|             widget=forms.Select(choices=TITLE_CHOICES), | ||||
|         ) | ||||
|         birth_date = forms.DateField(required=False) | ||||
|  | ||||
|     class BookForm(forms.Form): | ||||
| @@ -585,8 +587,12 @@ the field declaratively and setting its ``validators`` parameter:: | ||||
|     For example, if the ``Article`` model looks like this:: | ||||
|  | ||||
|         class Article(models.Model): | ||||
|             headline = models.CharField(max_length=200, null=True, blank=True, | ||||
|                                         help_text="Use puns liberally") | ||||
|             headline = models.CharField( | ||||
|                 max_length=200, | ||||
|                 null=True, | ||||
|                 blank=True, | ||||
|                 help_text='Use puns liberally', | ||||
|             ) | ||||
|             content = models.TextField() | ||||
|  | ||||
|     and you want to do some custom validation for ``headline``, while keeping | ||||
| @@ -594,8 +600,11 @@ the field declaratively and setting its ``validators`` parameter:: | ||||
|     ``ArticleForm`` like this:: | ||||
|  | ||||
|         class ArticleForm(ModelForm): | ||||
|             headline = MyFormField(max_length=200, required=False, | ||||
|                                    help_text="Use puns liberally") | ||||
|             headline = MyFormField( | ||||
|                 max_length=200, | ||||
|                 required=False, | ||||
|                 help_text='Use puns liberally', | ||||
|             ) | ||||
|  | ||||
|             class Meta: | ||||
|                 model = Article | ||||
| @@ -1018,8 +1027,10 @@ formset:: | ||||
|     def manage_authors(request): | ||||
|         AuthorFormSet = modelformset_factory(Author, fields=('name', 'title')) | ||||
|         if request.method == "POST": | ||||
|             formset = AuthorFormSet(request.POST, request.FILES, | ||||
|                                     queryset=Author.objects.filter(name__startswith='O')) | ||||
|             formset = AuthorFormSet( | ||||
|                 request.POST, request.FILES, | ||||
|                 queryset=Author.objects.filter(name__startswith='O'), | ||||
|             ) | ||||
|             if formset.is_valid(): | ||||
|                 formset.save() | ||||
|                 # Do something. | ||||
|   | ||||
| @@ -66,8 +66,9 @@ MIME type :mimetype:`application/xhtml+xml`:: | ||||
|  | ||||
|     def my_view(request): | ||||
|         # View code here... | ||||
|         return render(request, 'myapp/index.html', {"foo": "bar"}, | ||||
|             content_type="application/xhtml+xml") | ||||
|         return render(request, 'myapp/index.html', { | ||||
|             'foo': 'bar', | ||||
|         }, content_type='application/xhtml+xml') | ||||
|  | ||||
| This example is equivalent to:: | ||||
|  | ||||
| @@ -78,8 +79,7 @@ This example is equivalent to:: | ||||
|         # View code here... | ||||
|         t = loader.get_template('myapp/index.html') | ||||
|         c = {'foo': 'bar'} | ||||
|         return HttpResponse(t.render(c, request), | ||||
|             content_type="application/xhtml+xml") | ||||
|         return HttpResponse(t.render(c, request), content_type='application/xhtml+xml') | ||||
|  | ||||
| ``render_to_response()`` | ||||
| ======================== | ||||
|   | ||||
| @@ -435,7 +435,8 @@ traceback by adding the following to your settings file:: | ||||
|     import warnings | ||||
|     warnings.filterwarnings( | ||||
|         'error', r"DateTimeField .* received a naive datetime", | ||||
|             RuntimeWarning, r'django\.db\.models\.fields') | ||||
|         RuntimeWarning, r'django\.db\.models\.fields', | ||||
|     ) | ||||
|  | ||||
| Fixtures | ||||
| -------- | ||||
|   | ||||
| @@ -468,8 +468,10 @@ If the string contains exactly one unnamed placeholder, you can interpolate | ||||
| directly with the ``number`` argument:: | ||||
|  | ||||
|     class MyForm(forms.Form): | ||||
|         error_message = ungettext_lazy("You provided %d argument", | ||||
|             "You provided %d arguments") | ||||
|         error_message = ungettext_lazy( | ||||
|             "You provided %d argument", | ||||
|             "You provided %d arguments", | ||||
|         ) | ||||
|  | ||||
|         def clean(self): | ||||
|             # ... | ||||
| @@ -1817,8 +1819,11 @@ If you need more flexibility, you could also add a new argument to your custom | ||||
|  | ||||
|         def add_arguments(self, parser): | ||||
|             super(Command, self).add_arguments(parser) | ||||
|             parser.add_argument('--extra-keyword', dest='xgettext_keywords', | ||||
|                                 action='append') | ||||
|             parser.add_argument( | ||||
|                 '--extra-keyword', | ||||
|                 dest='xgettext_keywords', | ||||
|                 action='append', | ||||
|             ) | ||||
|  | ||||
|         def handle(self, *args, **options): | ||||
|             xgettext_keywords = options.pop('xgettext_keywords') | ||||
|   | ||||
		Reference in New Issue
	
	Block a user