import logging
from pathlib import Path
from typing import List, Optional, Set

from pddl.core import Formula

from tp_lodge.motion_planning.motion_validator import MotionValidator
from tp_lodge.task_planning.models.pddl.pddl_domain import PDDLDomain
from tp_lodge.task_planning.models.pddl.pddl_problem import PDDLProblem

logger = logging.getLogger(__name__)


class DummyMotionValidator(MotionValidator):

    def get_supported_predicates(self) -> List[str]:
        return []

    def _run_motion(self, motion: str):
        return

    def validate(
        self,
        motion: str,
        problem: PDDLProblem,
        domain: PDDLDomain,
        env_hash: str,
        out_dir: Path,
        post_env_hash: Optional[str] = None,
    ) -> str:
        return env_hash

    def get_predicates_evaluation(self, domain: PDDLDomain, problem: PDDLProblem) -> Formula:
        return problem.goal_state

    def validate_predicates(self, predicates: Set[Formula], domain: PDDLDomain, problem: PDDLProblem):
        return

    def reset(self, seed: int):
        pass

    def get_env_hash(self) -> str:
        return ""

    def set_env_hash(self, hash: str):
        pass

    def inject_init_predicates(self, domain: PDDLDomain, problem: PDDLProblem):
        return problem
