prompty 0.1.40__py3-none-any.whl → 0.1.45__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,24 +1,27 @@
1
- import azure.identity
2
1
  import importlib.metadata
3
- from typing import Iterator
4
- from azure.core.credentials import AzureKeyCredential
2
+ import typing
3
+ from collections.abc import Iterator
4
+
5
+ import azure.identity
5
6
  from azure.ai.inference import (
6
7
  ChatCompletionsClient,
7
8
  EmbeddingsClient,
8
9
  )
9
-
10
10
  from azure.ai.inference.aio import (
11
11
  ChatCompletionsClient as AsyncChatCompletionsClient,
12
+ )
13
+ from azure.ai.inference.aio import (
12
14
  EmbeddingsClient as AsyncEmbeddingsClient,
13
15
  )
14
16
  from azure.ai.inference.models import (
15
- StreamingChatCompletions,
16
17
  AsyncStreamingChatCompletions,
18
+ StreamingChatCompletions,
17
19
  )
20
+ from azure.core.credentials import AzureKeyCredential
18
21
 
19
- from ..tracer import Tracer
22
+ from ..core import AsyncPromptyStream, Prompty, PromptyStream
20
23
  from ..invoker import Invoker, InvokerFactory
21
- from ..core import Prompty, PromptyStream, AsyncPromptyStream
24
+ from ..tracer import Tracer
22
25
 
23
26
  VERSION = importlib.metadata.version("prompty")
24
27
 
@@ -29,13 +32,20 @@ class ServerlessExecutor(Invoker):
29
32
 
30
33
  def __init__(self, prompty: Prompty) -> None:
31
34
  super().__init__(prompty)
35
+ self.kwargs = {
36
+ key: value
37
+ for key, value in self.prompty.model.configuration.items()
38
+ if key != "type"
39
+ }
32
40
 
33
41
  self.endpoint = self.prompty.model.configuration["endpoint"]
34
42
  self.model = self.prompty.model.configuration["model"]
35
43
 
36
44
  # no key, use default credentials
37
45
  if "key" not in self.kwargs:
38
- self.credential = azure.identity.DefaultAzureCredential(
46
+ self.credential: typing.Union[
47
+ azure.identity.DefaultAzureCredential, AzureKeyCredential
48
+ ] = azure.identity.DefaultAzureCredential(
39
49
  exclude_shared_token_cache_credential=True
40
50
  )
41
51
  else:
@@ -46,11 +56,13 @@ class ServerlessExecutor(Invoker):
46
56
  # api type
47
57
  self.api = self.prompty.model.api
48
58
 
49
- def _response(self, response: any) -> any:
59
+ def _response(self, response: typing.Any) -> typing.Any:
50
60
  # stream response
51
61
  if isinstance(response, Iterator):
52
62
  if isinstance(response, StreamingChatCompletions):
53
- stream = PromptyStream("ServerlessExecutor", response)
63
+ stream: typing.Union[PromptyStream, AsyncPromptyStream] = PromptyStream(
64
+ "ServerlessExecutor", response
65
+ )
54
66
  return stream
55
67
  elif isinstance(response, AsyncStreamingChatCompletions):
56
68
  stream = AsyncPromptyStream("ServerlessExecutor", response)
@@ -62,7 +74,7 @@ class ServerlessExecutor(Invoker):
62
74
  else:
63
75
  return response
64
76
 
65
- def invoke(self, data: any) -> any:
77
+ def invoke(self, data: typing.Any) -> typing.Any:
66
78
  """Invoke the Serverless SDK
67
79
 
68
80
  Parameters
@@ -89,7 +101,7 @@ class ServerlessExecutor(Invoker):
89
101
  "description", "Azure Unified Inference SDK Chat Completions Client"
90
102
  )
91
103
  trace("inputs", cargs)
92
- client = ChatCompletionsClient(
104
+ client: typing.Any = ChatCompletionsClient(
93
105
  user_agent=f"prompty/{VERSION}",
94
106
  **cargs,
95
107
  )
@@ -174,10 +186,11 @@ class ServerlessExecutor(Invoker):
174
186
  trace("type", "LLM")
175
187
  trace("signature", "azure.ai.inference.aio.ChatCompletionsClient.ctor")
176
188
  trace(
177
- "description", "Azure Unified Inference SDK Async Chat Completions Client"
189
+ "description",
190
+ "Azure Unified Inference SDK Async Chat Completions Client",
178
191
  )
179
192
  trace("inputs", cargs)
180
- client = AsyncChatCompletionsClient(
193
+ client: typing.Any = AsyncChatCompletionsClient(
181
194
  user_agent=f"prompty/{VERSION}",
182
195
  **cargs,
183
196
  )
@@ -187,7 +200,8 @@ class ServerlessExecutor(Invoker):
187
200
  trace("type", "LLM")
188
201
  trace("signature", "azure.ai.inference.ChatCompletionsClient.complete")
189
202
  trace(
190
- "description", "Azure Unified Inference SDK Async Chat Completions Client"
203
+ "description",
204
+ "Azure Unified Inference SDK Async Chat Completions Client",
191
205
  )
192
206
  eargs = {
193
207
  "model": self.model,
@@ -209,7 +223,9 @@ class ServerlessExecutor(Invoker):
209
223
  with Tracer.start("EmbeddingsClient") as trace:
210
224
  trace("type", "LLM")
211
225
  trace("signature", "azure.ai.inference.aio.EmbeddingsClient.ctor")
212
- trace("description", "Azure Unified Inference SDK Async Embeddings Client")
226
+ trace(
227
+ "description", "Azure Unified Inference SDK Async Embeddings Client"
228
+ )
213
229
  trace("inputs", cargs)
214
230
  client = AsyncEmbeddingsClient(
215
231
  user_agent=f"prompty/{VERSION}",
@@ -1,9 +1,11 @@
1
- from typing import AsyncIterator, Iterator
2
- from ..invoker import Invoker, InvokerFactory
3
- from ..core import AsyncPromptyStream, Prompty, PromptyStream, ToolCall
1
+ import typing
2
+ from collections.abc import AsyncIterator, Iterator
4
3
 
5
4
  from azure.ai.inference.models import ChatCompletions, EmbeddingsResult
6
5
 
6
+ from ..core import AsyncPromptyStream, Prompty, PromptyStream, ToolCall
7
+ from ..invoker import Invoker, InvokerFactory
8
+
7
9
 
8
10
  @InvokerFactory.register_processor("serverless")
9
11
  class ServerlessProcessor(Invoker):
@@ -12,7 +14,9 @@ class ServerlessProcessor(Invoker):
12
14
  def __init__(self, prompty: Prompty) -> None:
13
15
  super().__init__(prompty)
14
16
 
15
- def invoke(self, data: any) -> any:
17
+ def invoke(
18
+ self, data: typing.Any
19
+ ) -> typing.Any:
16
20
  """Invoke the OpenAI API
17
21
 
18
22
  Parameters
@@ -53,7 +57,7 @@ class ServerlessProcessor(Invoker):
53
57
  for chunk in data:
54
58
  if (
55
59
  len(chunk.choices) == 1
56
- and chunk.choices[0].delta.content != None
60
+ and chunk.choices[0].delta.content is not None
57
61
  ):
58
62
  content = chunk.choices[0].delta.content
59
63
  yield content
@@ -62,7 +66,7 @@ class ServerlessProcessor(Invoker):
62
66
  else:
63
67
  return data
64
68
 
65
- async def invoke_async(self, data: str) -> str:
69
+ async def invoke_async(self, data: str) -> typing.Union[str, AsyncPromptyStream]:
66
70
  """Invoke the Prompty Chat Parser (Async)
67
71
 
68
72
  Parameters
@@ -103,7 +107,7 @@ class ServerlessProcessor(Invoker):
103
107
  async for chunk in data:
104
108
  if (
105
109
  len(chunk.choices) == 1
106
- and chunk.choices[0].delta.content != None
110
+ and chunk.choices[0].delta.content is not None
107
111
  ):
108
112
  content = chunk.choices[0].delta.content
109
113
  yield content
prompty/tracer.py CHANGED
@@ -1,16 +1,17 @@
1
- import os
2
- import json
1
+ import contextlib
2
+ import importlib
3
3
  import inspect
4
- import numbers
4
+ import json
5
+ import os
5
6
  import traceback
6
- import importlib
7
- import contextlib
8
- from pathlib import Path
9
- from numbers import Number
7
+ from collections.abc import Iterator
10
8
  from datetime import datetime
9
+ from functools import partial, wraps
10
+ from numbers import Number
11
+ from pathlib import Path
12
+ from typing import Any, Callable, Union
13
+
11
14
  from pydantic import BaseModel
12
- from functools import wraps, partial
13
- from typing import Any, Callable, Dict, Iterator, List
14
15
 
15
16
 
16
17
  # clean up key value pairs for sensitive values
@@ -26,7 +27,12 @@ def sanitize(key: str, value: Any) -> Any:
26
27
 
27
28
 
28
29
  class Tracer:
29
- _tracers: Dict[str, Callable[[str], Iterator[Callable[[str, Any], None]]]] = {}
30
+ _tracers: dict[
31
+ str,
32
+ Callable[
33
+ [str], contextlib._GeneratorContextManager[Callable[[str, Any], None]]
34
+ ],
35
+ ] = {}
30
36
 
31
37
  SIGNATURE = "signature"
32
38
  INPUTS = "inputs"
@@ -34,7 +40,11 @@ class Tracer:
34
40
 
35
41
  @classmethod
36
42
  def add(
37
- cls, name: str, tracer: Callable[[str], Iterator[Callable[[str, Any], None]]]
43
+ cls,
44
+ name: str,
45
+ tracer: Callable[
46
+ [str], contextlib._GeneratorContextManager[Callable[[str, Any], None]]
47
+ ],
38
48
  ) -> None:
39
49
  cls._tracers[name] = tracer
40
50
 
@@ -44,9 +54,11 @@ class Tracer:
44
54
 
45
55
  @classmethod
46
56
  @contextlib.contextmanager
47
- def start(cls, name: str, attributes: Dict[str, Any] = None) -> Iterator[Callable[[str, Any], None]]:
57
+ def start(
58
+ cls, name: str, attributes: Union[dict[str, Any], None] = None
59
+ ) -> Iterator[Callable[[str, Any], list[None]]]:
48
60
  with contextlib.ExitStack() as stack:
49
- traces = [
61
+ traces: list[Callable[[str, Any], None]] = [
50
62
  stack.enter_context(tracer(name)) for tracer in cls._tracers.values()
51
63
  ]
52
64
 
@@ -62,7 +74,7 @@ class Tracer:
62
74
  ]
63
75
 
64
76
 
65
- def to_dict(obj: Any) -> Dict[str, Any]:
77
+ def to_dict(obj: Any) -> Any:
66
78
  # simple json types
67
79
  if isinstance(obj, str) or isinstance(obj, Number) or isinstance(obj, bool):
68
80
  return obj
@@ -123,18 +135,16 @@ def _inputs(func: Callable, args, kwargs) -> dict:
123
135
  return inputs
124
136
 
125
137
 
126
- def _results(result: Any) -> dict:
138
+ def _results(result: Any) -> Any:
127
139
  return to_dict(result) if result is not None else "None"
128
140
 
129
141
 
130
- def _trace_sync(
131
- func: Callable = None, **okwargs: Any
132
- ) -> Callable:
142
+ def _trace_sync(func: Callable, **okwargs: Any) -> Callable:
133
143
 
134
144
  @wraps(func)
135
145
  def wrapper(*args, **kwargs):
136
146
  name, signature = _name(func, args)
137
- altname: str = None
147
+ altname: Union[str, None] = None
138
148
  # special case
139
149
  if "name" in okwargs:
140
150
  altname = name
@@ -142,7 +152,7 @@ def _trace_sync(
142
152
  del okwargs["name"]
143
153
 
144
154
  with Tracer.start(name) as trace:
145
- if altname != None:
155
+ if altname is not None:
146
156
  trace("function", altname)
147
157
 
148
158
  trace("signature", signature)
@@ -181,14 +191,12 @@ def _trace_sync(
181
191
  return wrapper
182
192
 
183
193
 
184
- def _trace_async(
185
- func: Callable = None, **okwargs: Any
186
- ) -> Callable:
194
+ def _trace_async(func: Callable, **okwargs: Any) -> Callable:
187
195
 
188
196
  @wraps(func)
189
197
  async def wrapper(*args, **kwargs):
190
198
  name, signature = _name(func, args)
191
- altname: str = None
199
+ altname: Union[str, None] = None
192
200
  # special case
193
201
  if "name" in okwargs:
194
202
  altname = name
@@ -196,9 +204,9 @@ def _trace_async(
196
204
  del okwargs["name"]
197
205
 
198
206
  with Tracer.start(name) as trace:
199
- if altname != None:
207
+ if altname is not None:
200
208
  trace("function", altname)
201
-
209
+
202
210
  trace("signature", signature)
203
211
 
204
212
  # support arbitrary keyword
@@ -234,7 +242,7 @@ def _trace_async(
234
242
  return wrapper
235
243
 
236
244
 
237
- def trace(func: Callable = None, **kwargs: Any) -> Callable:
245
+ def trace(func: Union[Callable, None] = None, **kwargs: Any) -> Callable:
238
246
  if func is None:
239
247
  return partial(trace, **kwargs)
240
248
  wrapped_method = _trace_async if inspect.iscoroutinefunction(func) else _trace_sync
@@ -242,7 +250,7 @@ def trace(func: Callable = None, **kwargs: Any) -> Callable:
242
250
 
243
251
 
244
252
  class PromptyTracer:
245
- def __init__(self, output_dir: str = None) -> None:
253
+ def __init__(self, output_dir: Union[str, None] = None) -> None:
246
254
  if output_dir:
247
255
  self.output = Path(output_dir).resolve().absolute()
248
256
  else:
@@ -251,7 +259,7 @@ class PromptyTracer:
251
259
  if not self.output.exists():
252
260
  self.output.mkdir(parents=True, exist_ok=True)
253
261
 
254
- self.stack: List[Dict[str, Any]] = []
262
+ self.stack: list[dict[str, Any]] = []
255
263
 
256
264
  @contextlib.contextmanager
257
265
  def tracer(self, name: str) -> Iterator[Callable[[str, Any], None]]:
@@ -324,7 +332,7 @@ class PromptyTracer:
324
332
  self.stack[-1]["__frames"] = []
325
333
  self.stack[-1]["__frames"].append(frame)
326
334
 
327
- def hoist_item(self, src: Dict[str, Any], cur: Dict[str, Any]) -> None:
335
+ def hoist_item(self, src: dict[str, Any], cur: dict[str, Any]) -> dict[str, Any]:
328
336
  for key, value in src.items():
329
337
  if value is None or isinstance(value, list) or isinstance(value, dict):
330
338
  continue
@@ -333,12 +341,13 @@ class PromptyTracer:
333
341
  cur[key] = value
334
342
  else:
335
343
  cur[key] += value
336
- except:
344
+ except Exception:
345
+ # TODO: Be more specific about exceptions here
337
346
  continue
338
347
 
339
348
  return cur
340
349
 
341
- def write_trace(self, frame: Dict[str, Any]) -> None:
350
+ def write_trace(self, frame: dict[str, Any]) -> None:
342
351
  trace_file = (
343
352
  self.output
344
353
  / f"{frame['name']}.{datetime.now().strftime('%Y%m%d.%H%M%S')}.tracy"
prompty/utils.py CHANGED
@@ -1,34 +1,39 @@
1
- import re
2
- import yaml
3
1
  import json
4
- import asyncio
5
- import aiofiles
6
- from typing import Dict
2
+ import re
3
+ import typing
7
4
  from pathlib import Path
8
5
 
6
+ import aiofiles
7
+ import yaml
8
+
9
9
  _yaml_regex = re.compile(
10
10
  r"^\s*" + r"(?:---|\+\+\+)" + r"(.*?)" + r"(?:---|\+\+\+)" + r"\s*(.+)$",
11
11
  re.S | re.M,
12
12
  )
13
13
 
14
- def load_text(file_path, encoding='utf-8'):
15
- with open(file_path, 'r', encoding=encoding) as file:
14
+
15
+ def load_text(file_path, encoding="utf-8"):
16
+ with open(file_path, encoding=encoding) as file:
16
17
  return file.read()
17
18
 
18
- async def load_text_async(file_path, encoding='utf-8'):
19
- async with aiofiles.open(file_path, mode='r', encoding=encoding) as f:
19
+
20
+ async def load_text_async(file_path, encoding="utf-8"):
21
+ async with aiofiles.open(file_path, encoding=encoding) as f:
20
22
  content = await f.read()
21
23
  return content
22
24
 
23
- def load_json(file_path, encoding='utf-8'):
25
+
26
+ def load_json(file_path, encoding="utf-8"):
24
27
  return json.loads(load_text(file_path, encoding=encoding))
25
28
 
26
- async def load_json_async(file_path, encoding='utf-8'):
29
+
30
+ async def load_json_async(file_path, encoding="utf-8"):
27
31
  # async file open
28
32
  content = await load_text_async(file_path, encoding=encoding)
29
33
  return json.loads(content)
30
34
 
31
- def _find_global_config(prompty_path: Path = Path.cwd()) -> Path:
35
+
36
+ def _find_global_config(prompty_path: Path = Path.cwd()) -> typing.Union[Path, None]:
32
37
  prompty_config = list(Path.cwd().glob("**/prompty.json"))
33
38
 
34
39
  if len(prompty_config) > 0:
@@ -46,7 +51,7 @@ def _find_global_config(prompty_path: Path = Path.cwd()) -> Path:
46
51
 
47
52
  def load_global_config(
48
53
  prompty_path: Path = Path.cwd(), configuration: str = "default"
49
- ) -> Dict[str, any]:
54
+ ) -> dict[str, typing.Any]:
50
55
  # prompty.config laying around?
51
56
  config = _find_global_config(prompty_path)
52
57
 
@@ -63,7 +68,7 @@ def load_global_config(
63
68
 
64
69
  async def load_global_config_async(
65
70
  prompty_path: Path = Path.cwd(), configuration: str = "default"
66
- ) -> Dict[str, any]:
71
+ ) -> dict[str, typing.Any]:
67
72
  # prompty.config laying around?
68
73
  config = _find_global_config(prompty_path)
69
74
 
@@ -78,7 +83,7 @@ async def load_global_config_async(
78
83
  return {}
79
84
 
80
85
 
81
- def load_prompty(file_path, encoding='utf-8'):
86
+ def load_prompty(file_path, encoding="utf-8"):
82
87
  contents = load_text(file_path, encoding=encoding)
83
88
  return parse(contents)
84
89
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: prompty
3
- Version: 0.1.40
3
+ Version: 0.1.45
4
4
  Summary: Prompty is a new asset class and format for LLM prompts that aims to provide observability, understandability, and portability for developers. It includes spec, tooling, and a runtime. This Prompty runtime supports Python
5
5
  Author-Email: Seth Juarez <seth.juarez@microsoft.com>
6
6
  License: MIT
@@ -0,0 +1,25 @@
1
+ prompty-0.1.45.dist-info/METADATA,sha256=lGL_FxvFnqD5qScwk4XHKi3hSgRt8oovCeTdX2vk-q8,9164
2
+ prompty-0.1.45.dist-info/WHEEL,sha256=thaaA2w1JzcGC48WYufAs8nrYZjJm8LqNfnXFOFyCC4,90
3
+ prompty-0.1.45.dist-info/entry_points.txt,sha256=a3i7Kvf--3DOkkv9VQpstwaNKgsnXwDGaPL18lPpKeI,60
4
+ prompty-0.1.45.dist-info/licenses/LICENSE,sha256=KWSC4z9cfML_t0xThoQYjzTdcZQj86Y_mhXdatzU-KM,1052
5
+ prompty/__init__.py,sha256=geIhhprDhbqqkj5jQhy3Nv_b83T38VhleEUfB7Xkd4U,16861
6
+ prompty/azure/__init__.py,sha256=zBxzOMQCwtiz2CsI8gNWzr7T2ZJHF3TZNIUtvfuaEQI,309
7
+ prompty/azure/executor.py,sha256=UaojJ4aUObdGvR-aBRRSntrFJZynvZ0Q1z8j2XHyc3I,9269
8
+ prompty/azure/processor.py,sha256=gNmUkPBoSLPE0t7IVJUxGdwZ2otiycDE4Fu6L1vurZI,5330
9
+ prompty/azure_beta/__init__.py,sha256=-LPrqoAv2UGI29SUjiZCkPlAGARvixlYe2IW1edswWo,375
10
+ prompty/azure_beta/executor.py,sha256=bARyO2k42ZQfd5NrNKyMUd7JZ2Rcm8urUP0sJ1P1Qxk,10157
11
+ prompty/cli.py,sha256=7aDL8Lup5EONizwn1zQUhGq9vk6z62EA0lpdf80Ybdk,4836
12
+ prompty/core.py,sha256=kAREbThLiVUikvikZX27riW0jJKIldkLusidzmdOftg,13070
13
+ prompty/invoker.py,sha256=ARmyVkinm_Nk91k8mRlsDffox7MtGSVLpwNycavMSSI,9028
14
+ prompty/openai/__init__.py,sha256=aRdXZ5pL4tURFqRwVX7gNdVy3PPWE6BvUbK1o73AqQc,303
15
+ prompty/openai/executor.py,sha256=v5K8kDpGUsbtTpCb1hOVxPt7twX2p-a5yL2iC3Xm8TQ,3752
16
+ prompty/openai/processor.py,sha256=X6yfSlHoTgXxCfGvUwADACjNtzLMNumcn0SX3U4T9as,2542
17
+ prompty/parsers.py,sha256=ptET4j8Rf55Ob0uOx6A41nlQ6cwo1CHRytSjeMIp6JE,5083
18
+ prompty/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
19
+ prompty/renderers.py,sha256=UMgJOjcAWd8LXX1ynXEdT4i9bqEAaJkeFp6KOD74lqU,1453
20
+ prompty/serverless/__init__.py,sha256=ILtbqhy6E-wWodbnq-_aftruTGk1Z0EI9zURFH4FECM,297
21
+ prompty/serverless/executor.py,sha256=QZXeFTXv_aT22rbBBgBFLtdAJqGp4W8GS3H3Rtoy8bE,8936
22
+ prompty/serverless/processor.py,sha256=d42MalWRf8RUpHRiueqAPAj_nGmJSMUE2yL-Tgxrss4,3754
23
+ prompty/tracer.py,sha256=jM2nQ7Cb-tSb7wog9w9QzhmB1IGwYb0B0-TBClZOn_A,11980
24
+ prompty/utils.py,sha256=P9nW0QfY1F5PM4pLxsFVlnul1BaRBatmvC2tpqydPKQ,2836
25
+ prompty-0.1.45.dist-info/RECORD,,
@@ -1,24 +0,0 @@
1
- prompty-0.1.40.dist-info/METADATA,sha256=W1QjkCeD1gnusTefPLneqE0zXfQImfR4bV9QbDFE4-c,9164
2
- prompty-0.1.40.dist-info/WHEEL,sha256=thaaA2w1JzcGC48WYufAs8nrYZjJm8LqNfnXFOFyCC4,90
3
- prompty-0.1.40.dist-info/entry_points.txt,sha256=a3i7Kvf--3DOkkv9VQpstwaNKgsnXwDGaPL18lPpKeI,60
4
- prompty-0.1.40.dist-info/licenses/LICENSE,sha256=KWSC4z9cfML_t0xThoQYjzTdcZQj86Y_mhXdatzU-KM,1052
5
- prompty/__init__.py,sha256=HCAvInBgNcIDO54rR4-RDIF4KUmGVQ2TRam_dS7xHEk,16561
6
- prompty/azure/__init__.py,sha256=WI8qeNWfxqggj21bznL-mxGUS-v67bUrunX0Lf2hsI8,295
7
- prompty/azure/executor.py,sha256=LZG0U5AZB4H6CDfZxlsvcUnmq0LnTxMEFgLd9nzHAgc,9126
8
- prompty/azure/processor.py,sha256=-CWc_1h4xdb0nyHwUkaI40NtzTxxenCXkgjJTh76AOk,5079
9
- prompty/azure_beta/__init__.py,sha256=QF4qcILpsryBLl1nvc1AhRzkKI2uqc6OAU_fA3LISNE,361
10
- prompty/azure_beta/executor.py,sha256=PIPfeOTLk9YEM80adktL2zxpa51gO4itlQzUDoq0QVg,9896
11
- prompty/cli.py,sha256=lo9mxw9V1gkeVcZZ2wkdAo_csmKTPpGfrr7XYmxDUr8,4840
12
- prompty/core.py,sha256=haX415_MciCn6K0zU4nZ394ZaJemZe9-iOsdRbe9G6A,12985
13
- prompty/invoker.py,sha256=O77E5iQ1552wQXxL8FhZGERbCi_0O3mDTd5Ozqw-O-E,8593
14
- prompty/openai/__init__.py,sha256=XX9j2zX_qt4saFJdZYWUNnrNnetHSnHC8dJ9YyFedL0,287
15
- prompty/openai/executor.py,sha256=8i5z_OxcESSYcjkDYIZwftr6YMvOHsOypzbNSCiLQ-Q,3640
16
- prompty/openai/processor.py,sha256=l9-91_CCgRtYvkwMO-jV6rkgeCA4gV_MFamQcvoNGQ0,2499
17
- prompty/parsers.py,sha256=zHqcRpFPUDG6BOI7ipaJf6yGc6ZbKnsLmO7jKEYNct4,5013
18
- prompty/renderers.py,sha256=80HNtCp3osgaLfhKxkG4j1kiRhJ727ITzT_yL5JLjEQ,1104
19
- prompty/serverless/__init__.py,sha256=xoXOTRXO8C631swNKaa-ek5_R3X-87bJpTm0z_Rsg6A,282
20
- prompty/serverless/executor.py,sha256=PUDJsYcJLQx9JSTh-R3HdJd0ehEC6w2Ch5OEqz52uVI,8395
21
- prompty/serverless/processor.py,sha256=ZSL9y8JC-G4qbtWOSbQAqEcFMWEaLskyOr5VjLthelU,3660
22
- prompty/tracer.py,sha256=VcrXkM71VO45xWY2b7H2AdCp5bSsCtcAv1m00ycf7XM,11678
23
- prompty/utils.py,sha256=jm7HEzOGk3zz8d5aquXK3zWIQWuDpBpJTzlz5sswtdg,2836
24
- prompty-0.1.40.dist-info/RECORD,,