diff --git a/docs/html/reference/pip_install.rst b/docs/html/reference/pip_install.rst
index 294e969f3e1..f33e279373d 100644
--- a/docs/html/reference/pip_install.rst
+++ b/docs/html/reference/pip_install.rst
@@ -156,18 +156,7 @@ To interpret the requirements file in UTF-8 format add a comment
The following options are supported:
- * :ref:`-i, --index-url `
- * :ref:`--extra-index-url `
- * :ref:`--no-index `
- * :ref:`-c, --constraint `
- * :ref:`-r, --requirement `
- * :ref:`-e, --editable `
- * :ref:`-f, --find-links `
- * :ref:`--no-binary `
- * :ref:`--only-binary `
- * :ref:`--require-hashes `
- * :ref:`--pre `
- * :ref:`--trusted-host <--trusted-host>`
+.. pip-requirements-file-options-ref-list::
For example, to specify :ref:`--no-index ` and two
:ref:`--find-links ` locations:
diff --git a/docs/pip_sphinxext.py b/docs/pip_sphinxext.py
index 29ca34c7289..6cc7a2c82ec 100644
--- a/docs/pip_sphinxext.py
+++ b/docs/pip_sphinxext.py
@@ -9,7 +9,8 @@
from docutils.statemachine import ViewList
from pip._internal.cli import cmdoptions
-from pip._internal.commands import create_command
+from pip._internal.commands import commands_dict, create_command
+from pip._internal.req.req_file import SUPPORTED_OPTIONS
class PipCommandUsage(rst.Directive):
@@ -108,9 +109,50 @@ def process_options(self):
)
+class PipReqFileOptionsReference(PipOptions):
+
+ def determine_opt_prefix(self, opt_name):
+ for command in commands_dict:
+ cmd = create_command(command)
+ if cmd.cmd_opts.has_option(opt_name):
+ return command
+
+ raise KeyError('Could not identify prefix of opt {}'.format(opt_name))
+
+ def process_options(self):
+ for option in SUPPORTED_OPTIONS:
+ if getattr(option, 'deprecated', False):
+ continue
+
+ opt = option()
+ opt_name = opt._long_opts[0]
+ if opt._short_opts:
+ short_opt_name = '{}, '.format(opt._short_opts[0])
+ else:
+ short_opt_name = ''
+
+ if option in cmdoptions.general_group['options']:
+ prefix = ''
+ else:
+ prefix = '{}_'.format(self.determine_opt_prefix(opt_name))
+
+ self.view_list.append(
+ ' * :ref:`{short}{long}<{prefix}{opt_name}>`'.format(
+ short=short_opt_name,
+ long=opt_name,
+ prefix=prefix,
+ opt_name=opt_name
+ ),
+ "\n"
+ )
+
+
def setup(app):
app.add_directive('pip-command-usage', PipCommandUsage)
app.add_directive('pip-command-description', PipCommandDescription)
app.add_directive('pip-command-options', PipCommandOptions)
app.add_directive('pip-general-options', PipGeneralOptions)
app.add_directive('pip-index-options', PipIndexOptions)
+ app.add_directive(
+ 'pip-requirements-file-options-ref-list', PipReqFileOptionsReference
+ )
diff --git a/news/7908.doc b/news/7908.doc
new file mode 100644
index 00000000000..ec5ee72ac2e
--- /dev/null
+++ b/news/7908.doc
@@ -0,0 +1,2 @@
+List of options supported in requirements file are extracted from source of truth,
+instead of being maintained manually.
diff --git a/src/pip/_internal/cli/cmdoptions.py b/src/pip/_internal/cli/cmdoptions.py
index 5b5647d64f4..adfc81767c4 100644
--- a/src/pip/_internal/cli/cmdoptions.py
+++ b/src/pip/_internal/cli/cmdoptions.py
@@ -832,6 +832,10 @@ def _handle_no_use_pep517(option, opt, value, parser):
action='store_true',
help=SUPPRESS_HELP,
) # type: Callable[..., Option]
+# TODO: Move into a class that inherits from partial, currently does not
+# work as mypy complains functools.partial is a generic class.
+# This way we know we can ignore this option in docs auto generation
+setattr(always_unzip, 'deprecated', True)
def _handle_merge_hash(option, opt_str, value, parser):