mirror of
https://github.com/anomalyco/opencode-sdk-python.git
synced 2026-05-17 12:42:25 +00:00
chore(internal): codegen related update
This commit is contained in:
parent
cc65c0df9a
commit
fc0f0178bf
5 changed files with 19 additions and 43 deletions
|
|
@ -3,7 +3,7 @@
|
|||
<!-- prettier-ignore -->
|
||||
[)](https://pypi.org/project/opencode-ai/)
|
||||
|
||||
The Opencode Python library provides convenient access to the Opencode REST API from any Python 3.8+
|
||||
The Opencode Python library provides convenient access to the Opencode REST API from any Python 3.9+
|
||||
application. The library includes type definitions for all request params and response fields,
|
||||
and offers both synchronous and asynchronous clients powered by [httpx](https://github.com/encode/httpx).
|
||||
|
||||
|
|
@ -392,7 +392,7 @@ print(opencode_ai.__version__)
|
|||
|
||||
## Requirements
|
||||
|
||||
Python 3.8 or higher.
|
||||
Python 3.9 or higher.
|
||||
|
||||
## Contributing
|
||||
|
||||
|
|
|
|||
|
|
@ -15,11 +15,10 @@ dependencies = [
|
|||
"distro>=1.7.0, <2",
|
||||
"sniffio",
|
||||
]
|
||||
requires-python = ">= 3.8"
|
||||
requires-python = ">= 3.9"
|
||||
classifiers = [
|
||||
"Typing :: Typed",
|
||||
"Intended Audience :: Developers",
|
||||
"Programming Language :: Python :: 3.8",
|
||||
"Programming Language :: Python :: 3.9",
|
||||
"Programming Language :: Python :: 3.10",
|
||||
"Programming Language :: Python :: 3.11",
|
||||
|
|
@ -141,7 +140,7 @@ filterwarnings = [
|
|||
# there are a couple of flags that are still disabled by
|
||||
# default in strict mode as they are experimental and niche.
|
||||
typeCheckingMode = "strict"
|
||||
pythonVersion = "3.8"
|
||||
pythonVersion = "3.9"
|
||||
|
||||
exclude = [
|
||||
"_dev",
|
||||
|
|
|
|||
|
|
@ -2,6 +2,7 @@ from __future__ import annotations
|
|||
|
||||
import os
|
||||
import inspect
|
||||
import weakref
|
||||
from typing import TYPE_CHECKING, Any, Type, Union, Generic, TypeVar, Callable, Optional, cast
|
||||
from datetime import date, datetime
|
||||
from typing_extensions import (
|
||||
|
|
@ -573,6 +574,9 @@ class CachedDiscriminatorType(Protocol):
|
|||
__discriminator__: DiscriminatorDetails
|
||||
|
||||
|
||||
DISCRIMINATOR_CACHE: weakref.WeakKeyDictionary[type, DiscriminatorDetails] = weakref.WeakKeyDictionary()
|
||||
|
||||
|
||||
class DiscriminatorDetails:
|
||||
field_name: str
|
||||
"""The name of the discriminator field in the variant class, e.g.
|
||||
|
|
@ -615,8 +619,9 @@ class DiscriminatorDetails:
|
|||
|
||||
|
||||
def _build_discriminated_union_meta(*, union: type, meta_annotations: tuple[Any, ...]) -> DiscriminatorDetails | None:
|
||||
if isinstance(union, CachedDiscriminatorType):
|
||||
return union.__discriminator__
|
||||
cached = DISCRIMINATOR_CACHE.get(union)
|
||||
if cached is not None:
|
||||
return cached
|
||||
|
||||
discriminator_field_name: str | None = None
|
||||
|
||||
|
|
@ -669,7 +674,7 @@ def _build_discriminated_union_meta(*, union: type, meta_annotations: tuple[Any,
|
|||
discriminator_field=discriminator_field_name,
|
||||
discriminator_alias=discriminator_alias,
|
||||
)
|
||||
cast(CachedDiscriminatorType, union).__discriminator__ = details
|
||||
DISCRIMINATOR_CACHE.setdefault(union, details)
|
||||
return details
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -1,10 +1,8 @@
|
|||
from __future__ import annotations
|
||||
|
||||
import sys
|
||||
import asyncio
|
||||
import functools
|
||||
import contextvars
|
||||
from typing import Any, TypeVar, Callable, Awaitable
|
||||
from typing import TypeVar, Callable, Awaitable
|
||||
from typing_extensions import ParamSpec
|
||||
|
||||
import anyio
|
||||
|
|
@ -15,34 +13,11 @@ T_Retval = TypeVar("T_Retval")
|
|||
T_ParamSpec = ParamSpec("T_ParamSpec")
|
||||
|
||||
|
||||
if sys.version_info >= (3, 9):
|
||||
_asyncio_to_thread = asyncio.to_thread
|
||||
else:
|
||||
# backport of https://docs.python.org/3/library/asyncio-task.html#asyncio.to_thread
|
||||
# for Python 3.8 support
|
||||
async def _asyncio_to_thread(
|
||||
func: Callable[T_ParamSpec, T_Retval], /, *args: T_ParamSpec.args, **kwargs: T_ParamSpec.kwargs
|
||||
) -> Any:
|
||||
"""Asynchronously run function *func* in a separate thread.
|
||||
|
||||
Any *args and **kwargs supplied for this function are directly passed
|
||||
to *func*. Also, the current :class:`contextvars.Context` is propagated,
|
||||
allowing context variables from the main thread to be accessed in the
|
||||
separate thread.
|
||||
|
||||
Returns a coroutine that can be awaited to get the eventual result of *func*.
|
||||
"""
|
||||
loop = asyncio.events.get_running_loop()
|
||||
ctx = contextvars.copy_context()
|
||||
func_call = functools.partial(ctx.run, func, *args, **kwargs)
|
||||
return await loop.run_in_executor(None, func_call)
|
||||
|
||||
|
||||
async def to_thread(
|
||||
func: Callable[T_ParamSpec, T_Retval], /, *args: T_ParamSpec.args, **kwargs: T_ParamSpec.kwargs
|
||||
) -> T_Retval:
|
||||
if sniffio.current_async_library() == "asyncio":
|
||||
return await _asyncio_to_thread(func, *args, **kwargs)
|
||||
return await asyncio.to_thread(func, *args, **kwargs)
|
||||
|
||||
return await anyio.to_thread.run_sync(
|
||||
functools.partial(func, *args, **kwargs),
|
||||
|
|
@ -53,10 +28,7 @@ async def to_thread(
|
|||
def asyncify(function: Callable[T_ParamSpec, T_Retval]) -> Callable[T_ParamSpec, Awaitable[T_Retval]]:
|
||||
"""
|
||||
Take a blocking function and create an async one that receives the same
|
||||
positional and keyword arguments. For python version 3.9 and above, it uses
|
||||
asyncio.to_thread to run the function in a separate thread. For python version
|
||||
3.8, it uses locally defined copy of the asyncio.to_thread function which was
|
||||
introduced in python 3.9.
|
||||
positional and keyword arguments.
|
||||
|
||||
Usage:
|
||||
|
||||
|
|
|
|||
|
|
@ -9,7 +9,7 @@ from pydantic import Field
|
|||
|
||||
from opencode_ai._utils import PropertyInfo
|
||||
from opencode_ai._compat import PYDANTIC_V1, parse_obj, model_dump, model_json
|
||||
from opencode_ai._models import BaseModel, construct_type
|
||||
from opencode_ai._models import DISCRIMINATOR_CACHE, BaseModel, construct_type
|
||||
|
||||
|
||||
class BasicModel(BaseModel):
|
||||
|
|
@ -809,7 +809,7 @@ def test_discriminated_unions_invalid_data_uses_cache() -> None:
|
|||
|
||||
UnionType = cast(Any, Union[A, B])
|
||||
|
||||
assert not hasattr(UnionType, "__discriminator__")
|
||||
assert not DISCRIMINATOR_CACHE.get(UnionType)
|
||||
|
||||
m = construct_type(
|
||||
value={"type": "b", "data": "foo"}, type_=cast(Any, Annotated[UnionType, PropertyInfo(discriminator="type")])
|
||||
|
|
@ -818,7 +818,7 @@ def test_discriminated_unions_invalid_data_uses_cache() -> None:
|
|||
assert m.type == "b"
|
||||
assert m.data == "foo" # type: ignore[comparison-overlap]
|
||||
|
||||
discriminator = UnionType.__discriminator__
|
||||
discriminator = DISCRIMINATOR_CACHE.get(UnionType)
|
||||
assert discriminator is not None
|
||||
|
||||
m = construct_type(
|
||||
|
|
@ -830,7 +830,7 @@ def test_discriminated_unions_invalid_data_uses_cache() -> None:
|
|||
|
||||
# if the discriminator details object stays the same between invocations then
|
||||
# we hit the cache
|
||||
assert UnionType.__discriminator__ is discriminator
|
||||
assert DISCRIMINATOR_CACHE.get(UnionType) is discriminator
|
||||
|
||||
|
||||
@pytest.mark.skipif(PYDANTIC_V1, reason="TypeAliasType is not supported in Pydantic v1")
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue