"vllm/vscode:/vscode.git/clone" did not exist on "b6a248bdd7bff91a15c4f2395762f8ce4c19c759"
utils.py 2.55 KB
Newer Older
1
from collections.abc import Sequence
2
from contextlib import contextmanager
3
4
from typing import (Any, Generic, Iterator, List, Optional, TypeVar, Union,
                    overload)
5
6
7
8
9
10

import zmq

from vllm.logger import init_logger

logger = init_logger(__name__)
11
12
13
14

T = TypeVar("T")


15
class ConstantList(Generic[T], Sequence):
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37

    def __init__(self, x: List[T]) -> None:
        self._x = x

    def append(self, item):
        raise Exception("Cannot append to a constant list")

    def extend(self, item):
        raise Exception("Cannot extend a constant list")

    def insert(self, item):
        raise Exception("Cannot insert into a constant list")

    def pop(self, item):
        raise Exception("Cannot pop from a constant list")

    def remove(self, item):
        raise Exception("Cannot remove from a constant list")

    def clear(self):
        raise Exception("Cannot clear a constant list")

38
39
40
41
42
43
    def index(self,
              item: T,
              start: int = 0,
              stop: Optional[int] = None) -> int:
        return self._x.index(item, start,
                             stop if stop is not None else len(self._x))
44
45

    @overload
46
    def __getitem__(self, item: int) -> T:
47
48
49
50
51
52
        ...

    @overload
    def __getitem__(self, s: slice, /) -> List[T]:
        ...

53
    def __getitem__(self, item: Union[int, slice]) -> Union[T, List[T]]:
54
55
56
        return self._x[item]

    @overload
57
    def __setitem__(self, item: int, value: T):
58
59
60
        ...

    @overload
61
    def __setitem__(self, s: slice, value: T, /):
62
63
        ...

64
    def __setitem__(self, item: Union[int, slice], value: Union[T, List[T]]):
65
66
67
68
69
70
71
72
73
74
75
76
77
        raise Exception("Cannot set item in a constant list")

    def __delitem__(self, item):
        raise Exception("Cannot delete item from a constant list")

    def __iter__(self):
        return iter(self._x)

    def __contains__(self, item):
        return item in self._x

    def __len__(self):
        return len(self._x)
78
79
80


@contextmanager
81
82
83
def make_zmq_socket(
        path: str,
        type: Any) -> Iterator[zmq.Socket]:  # type: ignore[name-defined]
84
85
    """Context manager for a ZMQ socket"""

86
    ctx = zmq.Context()  # type: ignore[attr-defined]
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
    try:
        socket = ctx.socket(type)

        if type == zmq.constants.PULL:
            socket.connect(path)
        elif type == zmq.constants.PUSH:
            socket.bind(path)
        else:
            raise ValueError(f"Unknown Socket Type: {type}")

        yield socket

    except KeyboardInterrupt:
        logger.debug("Worker had Keyboard Interrupt.")

    finally:
        ctx.destroy(linger=0)