2023-06-30 02:48:22 +02:00
|
|
|
"""
|
|
|
|
This module partly exists to prevent circular dependencies.
|
|
|
|
|
|
|
|
It also isolates some fairly yucky code related to the fact
|
|
|
|
that we have to support two formats of narrow specifications
|
|
|
|
from users:
|
|
|
|
|
|
|
|
legacy:
|
|
|
|
[["stream", "devel"], ["is", mentioned"]
|
|
|
|
|
|
|
|
modern:
|
|
|
|
[
|
|
|
|
{"operator": "stream", "operand": "devel", "negated": "false"},
|
|
|
|
{"operator": "is", "operand": "mentioned", "negated": "false"},
|
|
|
|
]
|
|
|
|
|
|
|
|
And then on top of that, we want to represent narrow
|
|
|
|
specification internally as dataclasses.
|
|
|
|
"""
|
2024-01-29 00:32:21 +01:00
|
|
|
|
2023-06-30 02:48:22 +02:00
|
|
|
from dataclasses import dataclass
|
|
|
|
from typing import Collection, Sequence
|
|
|
|
|
|
|
|
|
|
|
|
@dataclass
|
|
|
|
class NarrowTerm:
|
|
|
|
# In our current use case we don't yet handle negated narrow terms.
|
|
|
|
operator: str
|
|
|
|
operand: str
|
|
|
|
|
|
|
|
|
|
|
|
def narrow_dataclasses_from_tuples(tups: Collection[Sequence[str]]) -> Collection[NarrowTerm]:
|
|
|
|
"""
|
|
|
|
This method assumes that the callers are in our event-handling codepath, and
|
|
|
|
therefore as of summer 2023, they do not yet support the "negated" flag.
|
|
|
|
"""
|
|
|
|
return [NarrowTerm(operator=tup[0], operand=tup[1]) for tup in tups]
|