Source code for tooluniverse.tools.ToolMetadataStandardizer

"""
ToolMetadataStandardizer

Standardizes and groups semantically equivalent metadata strings (e.g., sources, tags) into canon...
"""

from typing import Any, Optional, Callable
from ._shared_client import get_shared_client


[docs] def ToolMetadataStandardizer( metadata_list: list[str], limit: Optional[int] = None, *, stream_callback: Optional[Callable[[str], None]] = None, use_cache: bool = False, validate: bool = True, ) -> dict[str, Any]: """ Standardizes and groups semantically equivalent metadata strings (e.g., sources, tags) into canon... Parameters ---------- metadata_list : list[str] List of raw metadata strings (e.g., sources, tags) to standardize and group. limit : int If provided, the maximum number of canonical strings to return. The LLM will ... stream_callback : Callable, optional Callback for streaming output use_cache : bool, default False Enable caching validate : bool, default True Validate parameters Returns ------- dict[str, Any] """ # Handle mutable defaults to avoid B006 linting error # Strip None values so optional parameters don't trigger schema validation errors _args = { k: v for k, v in {"metadata_list": metadata_list, "limit": limit}.items() if v is not None } return get_shared_client().run_one_function( { "name": "ToolMetadataStandardizer", "arguments": _args, }, stream_callback=stream_callback, use_cache=use_cache, validate=validate, )
__all__ = ["ToolMetadataStandardizer"]