main.py 1.73 KB
Newer Older
1
# SPDX-License-Identifier: Apache-2.0
2
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
3
"""The CLI entrypoints of vLLM
4

5
Note that all future modules must be lazily loaded within main
6
7
to avoid certain eager import breakage."""

8
9
10
from __future__ import annotations

import importlib.metadata
11
12
13


def main():
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
    import vllm.entrypoints.cli.benchmark.main
    import vllm.entrypoints.cli.collect_env
    import vllm.entrypoints.cli.openai
    import vllm.entrypoints.cli.run_batch
    import vllm.entrypoints.cli.serve
    from vllm.entrypoints.utils import VLLM_SUBCMD_PARSER_EPILOG, cli_env_setup
    from vllm.utils import FlexibleArgumentParser

    CMD_MODULES = [
        vllm.entrypoints.cli.openai,
        vllm.entrypoints.cli.serve,
        vllm.entrypoints.cli.benchmark.main,
        vllm.entrypoints.cli.collect_env,
        vllm.entrypoints.cli.run_batch,
    ]

30
    cli_env_setup()
31

32
33
    parser = FlexibleArgumentParser(
        description="vLLM CLI",
34
        epilog=VLLM_SUBCMD_PARSER_EPILOG.format(subcmd="[subcommand]"),
35
    )
36
    parser.add_argument(
37
38
39
40
        "-v",
        "--version",
        action="version",
        version=importlib.metadata.version("vllm"),
41
    )
42
43
44
45
46
    subparsers = parser.add_subparsers(required=False, dest="subparser")
    cmds = {}
    for cmd_module in CMD_MODULES:
        new_cmds = cmd_module.cmd_init()
        for cmd in new_cmds:
47
            cmd.subparser_init(subparsers).set_defaults(dispatch_function=cmd.cmd)
48
49
50
51
52
53
54
55
56
57
58
59
60
            cmds[cmd.name] = cmd
    args = parser.parse_args()
    if args.subparser in cmds:
        cmds[args.subparser].validate(args)

    if hasattr(args, "dispatch_function"):
        args.dispatch_function(args)
    else:
        parser.print_help()


if __name__ == "__main__":
    main()