import json
import re
from typing import Optional, List, Dict, Any


def strip_reasoning(response: str) -> str:
    """
    Strips the reasoning part from the LLM response by finding the last occurrence
    of a final answer marker and returning the text that follows.
    """
    markers = [
        "final<|message|>",
        "</think>",
        "assistantfinal",
    ]
    response_lower = response.lower()

    last_marker_pos = -1
    marker_len = 0

    for marker in markers:
        pos = response_lower.rfind(marker)
        if pos > last_marker_pos:
            last_marker_pos = pos
            marker_len = len(marker)

    if last_marker_pos != -1:
        return response[last_marker_pos + marker_len :].strip()

    return response


def parse_sensitivity_rating(response: str) -> Optional[int]:
    """
    Parses the sensitivity rating from an LLM's text response.

    It looks for patterns like "4)", "rating: 3", or the full text description
    and returns the corresponding integer.

    Args:
        response (str): The text response from the language model.

    Returns:
        An integer from 1 to 4 if a rating is found, otherwise None.
    """
    response_lower = response.lower()

    if "very sensitive" in response_lower:
        return 4
    if "somewhat sensitive" in response_lower:
        return 3
    if "not too sensitive" in response_lower:
        return 2
    if "not at all sensitive" in response_lower:
        return 1

    match = re.search(r"(?<!\d)[1-4](?!\d)", response_lower)
    if match:
        return int(match.group(0))

    return None


def parse_sensitive_objects_list(response: str) -> List[str]:
    """
    Parses the LLM response for a numbered list of sensitive objects.

    The function first checks if the model explicitly states no sensitive objects were found.
    If not, it finds the last occurrence of a numbered list starting with "1)" and
    extracts PDDL object names from that point onwards. This approach is taken to
    robustly handle conversational text or other content preceding the final list.
    """
    response_lower = response.lower()

    if (
        "no_object_is_sensitive" in response_lower
        or "no sensitive objects" in response_lower
    ):
        return []

    start_pos = response.rfind("1)")

    if start_pos == -1:
        return []

    text_to_parse = response[start_pos:]

    pddl_objects = re.findall(
        r"\d+\)\s*([a-zA-Z0-9_]+\.n\.\d+_\d+)", text_to_parse.lower()
    )

    return pddl_objects
