"""
Convenience factory that assembles S2B rule-based speaker/listener pairs for
the meta-rg-s2b evaluation pipeline.
"""
from __future__ import annotations

from meta_rg.s2b_import import ensure_s2b_importable

ensure_s2b_importable()

from symbolic_behaviour_benchmark.rule_based_agents.positionally_disentangled_speaker_agent import (  # noqa: E402
    PositionallyDisentangledSpeakerAgent,
)
from symbolic_behaviour_benchmark.rule_based_agents.positionally_disentangled_listener_agent import (  # noqa: E402
    PositionallyDisentangledListenerAgent,
)
from symbolic_behaviour_benchmark.rule_based_agents.vocab_partitioned_speaker_agent import (  # noqa: E402
    VocabPartitionedSpeakerAgent,
)
from symbolic_behaviour_benchmark.rule_based_agents.verbalize import (  # noqa: E402
    HypothesisListenerAgent,
)


def build_rule_based_agents(
    vocab_size: int = 6,
    max_sentence_length: int = 3,
    nbr_communication_rounds: int = 1,
    nbr_latents: int = 3,
    max_nbr_values_per_latent: int = 5,
    vocab_partition: bool = False,
    use_hypothesis_listener: bool = False,
    slim_verbaliser: bool = True,
    inductive_verbaliser: bool = False,
):
    common = dict(
        action_space=None,
        vocab_size=vocab_size,
        max_sentence_length=max_sentence_length,
        nbr_communication_rounds=nbr_communication_rounds,
        nbr_latents=nbr_latents,
    )
    if vocab_partition:
        speaker = VocabPartitionedSpeakerAgent(
            **common, max_nbr_values_per_latent=max_nbr_values_per_latent
        )
    else:
        speaker = PositionallyDisentangledSpeakerAgent(**common)
    if use_hypothesis_listener:
        listener = HypothesisListenerAgent(
            **common, slim=slim_verbaliser, inductive=inductive_verbaliser
        )
    else:
        listener = PositionallyDisentangledListenerAgent(**common)
    return speaker, listener
