arcade-core 3.3.0__tar.gz → 3.3.2__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {arcade_core-3.3.0 → arcade_core-3.3.2}/PKG-INFO +1 -1
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/catalog.py +13 -3
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/toolkit.py +20 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/pyproject.toml +1 -1
- {arcade_core-3.3.0 → arcade_core-3.3.2}/.gitignore +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/README.md +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/__init__.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/annotations.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/auth.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/config.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/config_model.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/constants.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/context.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/converters/openai.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/discovery.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/errors.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/executor.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/output.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/parse.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/py.typed +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/schema.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/usage/__init__.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/usage/__main__.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/usage/constants.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/usage/identity.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/usage/usage_service.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/usage/utils.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/utils.py +0 -0
- {arcade_core-3.3.0 → arcade_core-3.3.2}/arcade_core/version.py +0 -0
|
@@ -203,9 +203,18 @@ class ToolCatalog(BaseModel):
|
|
|
203
203
|
tool_func: Callable,
|
|
204
204
|
toolkit_or_name: str | Toolkit,
|
|
205
205
|
module: ModuleType | None = None,
|
|
206
|
+
toolkit_version: str | None = None,
|
|
207
|
+
toolkit_description: str | None = None,
|
|
206
208
|
) -> None:
|
|
207
209
|
"""
|
|
208
210
|
Add a function to the catalog as a tool.
|
|
211
|
+
|
|
212
|
+
Args:
|
|
213
|
+
tool_func: The function to add to the catalog.
|
|
214
|
+
toolkit_or_name: The toolkit or name of the toolkit.
|
|
215
|
+
module: The module to add the tool from.
|
|
216
|
+
toolkit_version: The version of the toolkit. Overrides the version of the toolkit if provided.
|
|
217
|
+
toolkit_description: The description of the toolkit. Overrides the description of the toolkit if provided.
|
|
209
218
|
"""
|
|
210
219
|
|
|
211
220
|
input_model, output_model = create_func_models(tool_func)
|
|
@@ -213,6 +222,8 @@ class ToolCatalog(BaseModel):
|
|
|
213
222
|
if isinstance(toolkit_or_name, Toolkit):
|
|
214
223
|
toolkit = toolkit_or_name
|
|
215
224
|
toolkit_name = toolkit.name
|
|
225
|
+
toolkit_version = toolkit_version or toolkit.version
|
|
226
|
+
toolkit_description = toolkit_description or toolkit.description
|
|
216
227
|
elif isinstance(toolkit_or_name, str):
|
|
217
228
|
toolkit = None
|
|
218
229
|
toolkit_name = toolkit_or_name
|
|
@@ -223,8 +234,8 @@ class ToolCatalog(BaseModel):
|
|
|
223
234
|
definition = ToolCatalog.create_tool_definition(
|
|
224
235
|
tool_func,
|
|
225
236
|
toolkit_name,
|
|
226
|
-
|
|
227
|
-
|
|
237
|
+
toolkit_version,
|
|
238
|
+
toolkit_description,
|
|
228
239
|
)
|
|
229
240
|
|
|
230
241
|
fully_qualified_name = definition.get_fully_qualified_name()
|
|
@@ -283,7 +294,6 @@ class ToolCatalog(BaseModel):
|
|
|
283
294
|
module = import_module(module_name)
|
|
284
295
|
tool_func = getattr(module, tool_name)
|
|
285
296
|
self.add_tool(tool_func, toolkit, module)
|
|
286
|
-
|
|
287
297
|
except ToolDefinitionError as e:
|
|
288
298
|
raise e.with_context(tool_name) from e
|
|
289
299
|
except ToolkitLoadError as e:
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
+
import contextlib
|
|
1
2
|
import importlib.metadata
|
|
2
3
|
import importlib.util
|
|
3
4
|
import logging
|
|
4
5
|
import os
|
|
6
|
+
import sys
|
|
5
7
|
import types
|
|
6
8
|
from collections import defaultdict
|
|
7
9
|
from pathlib import Path, PurePosixPath, PureWindowsPath
|
|
@@ -293,9 +295,27 @@ class Toolkit(BaseModel):
|
|
|
293
295
|
f"Failed to locate Python files in package directory for '{package_name}'."
|
|
294
296
|
) from e
|
|
295
297
|
|
|
298
|
+
# Get the currently executing file (the entrypoint file) so that we can skip it when loading tools.
|
|
299
|
+
# Skipping this file is necessary because tools are discovered via AST parsing, but those tools
|
|
300
|
+
# aren't in the module's namespace yet since the file is still executing.
|
|
301
|
+
current_file = None
|
|
302
|
+
main_module = sys.modules.get("__main__")
|
|
303
|
+
if main_module and hasattr(main_module, "__file__") and main_module.__file__:
|
|
304
|
+
with contextlib.suppress(Exception):
|
|
305
|
+
current_file = Path(main_module.__file__).resolve()
|
|
306
|
+
|
|
296
307
|
tools: dict[str, list[str]] = {}
|
|
297
308
|
|
|
298
309
|
for module_path in modules:
|
|
310
|
+
# Skip adding tools from the currently executing file
|
|
311
|
+
if current_file:
|
|
312
|
+
try:
|
|
313
|
+
module_path_resolved = module_path.resolve()
|
|
314
|
+
if module_path_resolved == current_file:
|
|
315
|
+
continue
|
|
316
|
+
except Exception: # noqa: S110
|
|
317
|
+
pass
|
|
318
|
+
|
|
299
319
|
relative_path = module_path.relative_to(package_dir)
|
|
300
320
|
cls.validate_file(module_path)
|
|
301
321
|
# Build import path and avoid duplicating the package prefix if it already exists
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|