{
  "root": {
    "name": "add_agenda_slide_with_bullet_list",
    "description": "Evaluates if a new 'Agenda' slide is correctly added with specified bullet points between slides 1 and 2.",
    "is_critical": true,
    "metadata": {},
    "children": [
      {
        "name": "agenda_slide_added_correctly",
        "description": "Checks if a slide titled 'Agenda' is added at the correct position (between slide 1 and 2).",
        "is_critical": true,
        "metadata": {},
        "children": [
          {
            "name": "agenda_slide_position",
            "description": "Verifies 'Agenda' slide is inserted at index 2 (between original slides 1 and 2).",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    modified = Presentation(modified_ppt_path)\n    original = Presentation(original_ppt_path)\n    modified_slides = modified.slides\n    original_slides = original.slides\n    modified_slide_ids = [slide.slide_id for slide in modified_slides]\n    original_slide_ids = [slide.slide_id for slide in original_slides]\n    new_slides = [slide for slide in modified_slides if slide.slide_id not in original_slide_ids]\n    deleted_slides = [slide for slide in original_slides if slide.slide_id not in modified_slide_ids]\n\n    # Check if title exists before accessing text\n    if not modified_slides[1].shapes.title:\n        return (\"'Agenda' slide not found at position 2.\", 0.0)\n    # Check that the title has a text attribute\n    if not hasattr(modified_slides[1].shapes.title, \"text\"):\n        return (\"'Agenda' slide not found at position 2.\", 0.0)\n    # Check if the title text matches \"Agenda\"\n    if modified_slides[1].shapes.title.text.lower().strip() != \"agenda\":\n        return (\"'Agenda' slide not found at position 2.\", 0.0)\n    return (\"'Agenda' slide correctly added at position 2.\", 1.0)\n\n\nif __name__ == \"__main__\":\n    global original_ppt_path, modified_ppt_path\n    original_ppt_path = \"data/files/PowerPoint/Obesity.pptx\"\n    modified_ppt_path = \"data/files/PowerPoint/Obesity-2.pptx\"\n    score, reason = compute_score()\n    print(f\"Score: {score}, Reason: {reason}\")\n"
            }
          },
          {
            "name": "slide_present",
            "description": "Verifies a slide titled 'Agenda' exists in the modified presentation.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    modified = Presentation(modified_ppt_path)\n    original = Presentation(original_ppt_path)\n    modified_slides = modified.slides\n    original_slides = original.slides\n    modified_slide_ids = [slide.slide_id for slide in modified_slides]\n    original_slide_ids = [slide.slide_id for slide in original_slides]\n    new_slides = [slide for slide in modified_slides if slide.slide_id not in original_slide_ids]\n    deleted_slides = [slide for slide in original_slides if slide.slide_id not in modified_slide_ids]\n    for slide in new_slides:\n        # Check if title exists before accessing text\n        if not slide.shapes.title:\n            continue\n        # Check that the title has a text attribute\n        if not hasattr(slide.shapes.title, \"text\"):\n            continue\n        # Check if the title text matches \"Agenda\"\n        if slide.shapes.title.text.lower().strip() != \"agenda\":\n            continue\n        else:\n            return 'Agenda slide found in added slides.', 1.0\n    return 'Agenda slide not found.', 0.0\n"
            }
          },
          {
            "name": "agenda_slide_title",
            "description": "Checks if the new slide is titled 'Agenda'.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    modified = Presentation(modified_ppt_path)\n    original = Presentation(original_ppt_path)\n    modified_slides = modified.slides\n    original_slides = original.slides\n    modified_slide_ids = [slide.slide_id for slide in modified_slides]\n    original_slide_ids = [slide.slide_id for slide in original_slides]\n    new_slides = [slide for slide in modified_slides if slide.slide_id not in original_slide_ids]\n    for slide in new_slides:\n        # Check if title exists before accessing text\n        if not slide.shapes.title:\n            continue\n        # Check that the title has a text attribute\n        if not hasattr(slide.shapes.title, \"text\"):\n            continue\n        # Check if the title text matches \"Agenda\"\n        if slide.shapes.title.text.lower().strip() == \"agenda\":\n            return 'Agenda slide found in added slides.', 1.0\n    return (\"No slide titled 'Agenda' found.\", 0.0)\n"
            }
          }
        ]
      },
      {
        "name": "agenda_bullet_content_correct",
        "description": "Verifies that the Agenda slide contains the correct bullet points as required.",
        "is_critical": true,
        "metadata": {},
        "children": [
          {
            "name": "agenda_bullet_count",
            "description": "Checks that there are exactly 3 bullet points in the Agenda slide.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    prs = Presentation(modified_ppt_path)\n    # Find Agenda slide by title\n    agenda_slide = None\n\n    # First try title placeholders:\n    for slide in prs.slides:\n        if slide.shapes.title and slide.shapes.title.text.strip().lower() == 'agenda':\n            agenda_slide = slide\n            break\n    # If not found, check all shapes for text 'Agenda'\n    if not agenda_slide:\n        for slide in prs.slides:\n            title_shapes = [sh for sh in slide.shapes if sh.has_text_frame and sh.text_frame.text.strip().lower() == 'agenda']\n            if title_shapes:\n                agenda_slide = slide\n                break\n    if not agenda_slide:\n        return 'Agenda slide not found in modified presentation.', 0.0\n    # Find all bullet points in the slide (exclude title)\n    bullet_count = 0\n    for shape in agenda_slide.shapes:\n        if shape.has_text_frame and shape.text_frame.text.strip().lower() != 'agenda':\n            for para in shape.text_frame.paragraphs:\n                if para.level == 0 and para.text.strip():\n                    bullet_count += 1\n    if bullet_count == 3:\n        return 'Agenda slide has 3 bullet points.', 1.0\n    return f'Agenda slide has {bullet_count} bullet points.', 0.0\n"
            }
          },
          {
            "name": "agenda_bullet_texts",
            "description": "Checks that the bullet texts match the required items ('Obesity definition', 'Global statistics', 'Impact on health').",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    required = ['obesity definition', 'global statistics', 'impact on health']\n    prs = Presentation(modified_ppt_path)\n    # Find Agenda slide by title\n    # First try title placeholders:\n    for slide in prs.slides:\n        if slide.shapes.title and slide.shapes.title.text.strip().lower() == 'agenda':\n            agenda_slide = slide\n            break\n    # If not found, check all shapes for text 'Agenda'\n    if not agenda_slide:\n        for slide in prs.slides:\n            title_shapes = [sh for sh in slide.shapes if sh.has_text_frame and sh.text_frame.text.strip().lower() == 'agenda']\n            if title_shapes:\n                agenda_slide = slide\n                break\n    if not agenda_slide:\n        return 'Agenda slide not found in modified presentation.', 0.0\n    \n    found = []\n    for shape in agenda_slide.shapes:\n        if shape.has_text_frame and shape.text_frame.text.strip().lower() != 'agenda':\n            for para in shape.text_frame.paragraphs:\n                text = para.text.strip().lower()\n                if text:\n                    found.append(text)\n    missing = [item for item in required if item not in found]\n    if not missing:\n        return 'All required bullet points present on Agenda slide.', 1.0\n    return f'Missing bullet points: {missing}', 0.0\n"
            }
          }
        ]
      },
      {
        "name": "agenda_slide_content_correct",
        "description": "Verifies the content of the 'Agenda' slide: three bullets: 'Obesity definition', 'Global statistics', 'Impact on health'.",
        "is_critical": true,
        "metadata": {},
        "children": [
          {
            "name": "agenda_slide_bullet_points",
            "description": "Checks if bullet list contains exactly the three required items.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    import os\n    prs = Presentation(modified_ppt_path)\n    \n    # First try title placeholders:\n    for slide in prs.slides:\n        if slide.shapes.title and slide.shapes.title.text.strip().lower() == 'agenda':\n            agenda_slide = slide\n            break\n    # If not found, check all shapes for text 'Agenda'\n    if not agenda_slide:\n        for slide in prs.slides:\n            title_shapes = [sh for sh in slide.shapes if sh.has_text_frame and sh.text_frame.text.strip().lower() == 'agenda']\n            if title_shapes:\n                agenda_slide = slide\n                break\n    if not agenda_slide:\n        return 'Agenda slide not found in modified presentation.', 0.0\n    \n    slide = agenda_slide  # slide_number is 1-based\n    # Find all paragraphs in all shapes\n    for shape in slide.shapes:\n        # Skip title shape\n        if shape == slide.shapes.title:\n            continue\n        bullet_texts = []\n    \n        if hasattr(shape, \"text_frame\") and shape.text_frame:\n            for para in shape.text_frame.paragraphs:\n                if para.level == 0 or para.level == 1:   # Accept both top-level and first indent\n                    text = para.text.strip()\n                    if text:\n                        bullet_texts.append(text.lower())\n        required_bullets = [\n            \"obesity definition\",\n            \"global statistics\",\n            \"impact on health\"\n        ]\n        found = [any(rb == bt for bt in bullet_texts) for rb in required_bullets]\n        if any(found) and not all(found):\n            missing = [rb for rb, f in zip(required_bullets, found) if not f]\n            return (f\"Missing bullet points: {', '.join(missing)}.\", 0.0)\n        \n        elif all(found):\n            # Ensure no extra bullet points\n            if len([x for x in bullet_texts if x.strip()]) != 3:\n                return (f\"Agenda slide has {len(bullet_texts)} bullet points instead of 3.\", 0.0)\n            else:\n                return (\"Agenda slide has exactly the required bullet points.\", 1.0)\n    return 'No bullet points found on Agenda slide.', 0.0\n"
            }
          }
        ]
      },
      {
        "name": "no_extraneous_modifications",
        "description": "Checks for absence of unintended changes: no extra slides, bullets, or unrelated edits.",
        "is_critical": false,
        "metadata": {},
        "children": [
          {
            "name": "no_extra_slides_added",
            "description": "Verifies no slides (except 'Agenda') were added.",
            "is_critical": false,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    modified = Presentation(modified_ppt_path)\n    original = Presentation(original_ppt_path)\n    modified_slides = modified.slides\n    original_slides = original.slides\n    modified_slide_ids = [slide.slide_id for slide in modified_slides]\n    original_slide_ids = [slide.slide_id for slide in original_slides]\n    new_slides = [slide for slide in modified_slides if slide.slide_id not in original_slide_ids]\n    deleted_slides = [slide for slide in original_slides if slide.slide_id not in modified_slide_ids]\n\n    extra = []\n    for slide in new_slides:\n        if slide.shapes.title:\n            if slide.shapes.title and slide.shapes.title.text.lower().strip() == \"agenda\":\n                continue\n            else:\n                extra.append(slide.shapes.title.text or f\"Slide {slide.slide_number}\")\n    if extra:\n        return (f\"Extra slides added: {', '.join(extra)}.\", 0.0)\n    return (\"No extra slides added.\", 1.0)\n"
            }
          },
          {
            "name": "no_unintended_slide_modifications",
            "description": "Checks that slides other than the new 'Agenda' are not modified.",
            "is_critical": false,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    if len(ppt_diff.modified_slides) > 0:\n        return \"Unintended slide modifications detected.\", 0.0\n    return \"No unintended slide modifications detected.\", 1.0\n"
            }
          }
        ]
      }
    ]
  },
  "metadata": {
    "task": "Add a bullet point list with three items: 'Obesity definition', 'Global statistics', and 'Impact on health' as a new slide between 1 and 2, titled \"Agenda\""
  }
}