From 0d7a295f28003f6c6adc138549d6f56d2a3d8806 Mon Sep 17 00:00:00 2001 From: Matt Robenolt Date: Mon, 11 May 2015 23:24:03 -0700 Subject: [PATCH] Allowed runserver sublcasses to easily override the default port. --- django/core/management/commands/runserver.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/django/core/management/commands/runserver.py b/django/core/management/commands/runserver.py index c4cd874051..e2d447147b 100644 --- a/django/core/management/commands/runserver.py +++ b/django/core/management/commands/runserver.py @@ -16,13 +16,13 @@ from django.db.migrations.executor import MigrationExecutor from django.utils import autoreload, six from django.utils.encoding import force_text, get_system_encoding + naiveip_re = re.compile(r"""^(?: (?P (?P\d{1,3}(?:\.\d{1,3}){3}) | # IPv4 address (?P\[[a-fA-F0-9:]+\]) | # IPv6 address (?P[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*) # FQDN ):)?(?P\d+)$""", re.X) -DEFAULT_PORT = "8000" class Command(BaseCommand): @@ -32,6 +32,8 @@ class Command(BaseCommand): requires_system_checks = False leave_locale_alone = True + default_port = '8000' + def add_arguments(self, parser): parser.add_argument('addrport', nargs='?', help='Optional port number, or ipaddr:port') @@ -68,7 +70,7 @@ class Command(BaseCommand): self._raw_ipv6 = False if not options.get('addrport'): self.addr = '' - self.port = DEFAULT_PORT + self.port = self.default_port else: m = re.match(naiveip_re, options['addrport']) if m is None: