Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
"""A module containing 'SummarizationResult' and 'SummarizeExtractor' models."""

import json
import logging
import traceback
from dataclasses import dataclass
from typing import TYPE_CHECKING

Expand All @@ -13,6 +15,8 @@
from graphrag_llm.completion import LLMCompletion
from graphrag_llm.types import LLMCompletionResponse

logger = logging.getLogger(__name__)

# these tokens are used in the prompt
ENTITY_NAME_KEY = "entity_name"
DESCRIPTION_LIST_KEY = "description_list"
Expand Down Expand Up @@ -59,18 +63,33 @@ async def __call__(
descriptions: list[str],
) -> SummarizationResult:
"""Call method definition."""
result = ""
if len(descriptions) == 0:
try:
result = ""
elif len(descriptions) == 1:
result = descriptions[0]
else:
result = await self._summarize_descriptions(id, descriptions)

return SummarizationResult(
id=id,
description=result or "",
)
if len(descriptions) == 0:
result = ""
elif len(descriptions) == 1:
result = descriptions[0]
else:
result = await self._summarize_descriptions(id, descriptions)

return SummarizationResult(
id=id,
description=result or "",
)
except Exception as e: # pragma: no cover - defensive logging
logger.exception("error summarizing descriptions")
self._on_error(
e,
traceback.format_exc(),
{
"id": id,
"descriptions": descriptions,
},
)
return SummarizationResult(
id=id,
description="",
)

async def _summarize_descriptions(
self, id: str | tuple[str, str], descriptions: list[str]
Expand Down
Loading