projectdavid 1.33.8__py3-none-any.whl → 1.33.10__py3-none-any.whl

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.

Potentially problematic release.


This version of projectdavid might be problematic. Click here for more details.

@@ -14,6 +14,9 @@ class SynchronousInferenceStream:
14
14
  _GLOBAL_LOOP = asyncio.new_event_loop()
15
15
  asyncio.set_event_loop(_GLOBAL_LOOP)
16
16
 
17
+ # --------------------------------------------------------------
18
+ # ctor / setup
19
+ # --------------------------------------------------------------
17
20
  def __init__(self, inference) -> None:
18
21
  self.inference_client = inference
19
22
  self.user_id: Optional[str] = None
@@ -39,6 +42,9 @@ class SynchronousInferenceStream:
39
42
  self.run_id = run_id
40
43
  self.api_key = api_key
41
44
 
45
+ # --------------------------------------------------------------
46
+ # main streaming entry-point
47
+ # --------------------------------------------------------------
42
48
  def stream_chunks(
43
49
  self,
44
50
  provider: str,
@@ -65,6 +71,7 @@ class SynchronousInferenceStream:
65
71
 
66
72
  agen = _stream_chunks_async().__aiter__()
67
73
 
74
+ # ---------- suppression chain ----------
68
75
  if suppress_fc:
69
76
  _suppressor = FunctionCallSuppressor()
70
77
  _peek_gate = PeekGate(_suppressor)
@@ -74,28 +81,10 @@ class SynchronousInferenceStream:
74
81
 
75
82
  else:
76
83
 
77
- def _filter_text(txt: str) -> str:
84
+ def _filter_text(txt: str) -> str: # no-op
78
85
  return txt
79
86
 
80
- def _drain_filters() -> Optional[dict]:
81
- if not suppress_fc:
82
- return None
83
- parts: list[str] = []
84
- while True:
85
- out = _filter_text("")
86
- if not out:
87
- break
88
- parts.append(out)
89
- if not _peek_gate.suppressing and _peek_gate.buf:
90
- parts.append(_peek_gate.buf)
91
- _peek_gate.buf = ""
92
- if parts:
93
- return {
94
- "type": "content",
95
- "content": "".join(parts),
96
- "run_id": self.run_id,
97
- }
98
- return None
87
+ # ---------------------------------------
99
88
 
100
89
  while True:
101
90
  try:
@@ -103,52 +92,40 @@ class SynchronousInferenceStream:
103
92
  asyncio.wait_for(agen.__anext__(), timeout=timeout_per_chunk)
104
93
  )
105
94
 
106
- # Always attach run_id
107
- chunk["run_id"] = self.run_id
108
-
109
- # ------------------------------------------------------
110
- # allow status chunks to bypass suppression suppression
111
- # -------------------------------------------------------
112
- if chunk.get("type") == "status":
113
- yield chunk
114
- continue
115
-
116
- if chunk.get("type") in ("hot_code", "hot_code_output"):
117
- yield chunk
118
- continue
119
-
120
- if (
121
- chunk.get("stream_type") == "code_execution"
122
- and chunk.get("chunk", {}).get("type") == "code_interpreter_stream"
123
- ):
124
- yield chunk
95
+ # provider-labelled function_call
96
+ if suppress_fc and chunk.get("type") == "function_call":
97
+ LOG.debug("[SUPPRESSOR] blocked provider-labelled function_call")
125
98
  continue
126
99
 
100
+ # inline content
127
101
  if isinstance(chunk.get("content"), str):
128
102
  chunk["content"] = _filter_text(chunk["content"])
129
103
  if chunk["content"] == "":
104
+ continue # fully suppressed (or still peeking)
105
+
106
+ # additional raw inline suppression for partial JSON
107
+ if (
108
+ '"name": "code_interpreter"' in chunk["content"]
109
+ and '"arguments": {"code"' in chunk["content"]
110
+ ):
111
+ LOG.debug("[SUPPRESSOR] inline code_interpreter match blocked")
130
112
  continue
131
113
 
132
114
  yield chunk
133
115
 
134
116
  except StopAsyncIteration:
135
- if tail := _drain_filters():
136
- yield tail
137
117
  LOG.info("Stream completed normally.")
138
118
  break
139
-
140
119
  except asyncio.TimeoutError:
141
- if tail := _drain_filters():
142
- yield tail
143
- LOG.error("[TimeoutError] Chunk wait expired – aborting stream.")
120
+ LOG.error("[TimeoutError] Timeout occurred, stopping stream.")
144
121
  break
145
-
146
- except Exception as exc:
147
- if tail := _drain_filters():
148
- yield tail
149
- LOG.error("Unexpected streaming error: %s", exc, exc_info=True)
122
+ except Exception as e:
123
+ LOG.error("Unexpected error during streaming completions: %s", e)
150
124
  break
151
125
 
126
+ # --------------------------------------------------------------
127
+ # housekeeping
128
+ # --------------------------------------------------------------
152
129
  @classmethod
153
130
  def shutdown_loop(cls) -> None:
154
131
  if cls._GLOBAL_LOOP and not cls._GLOBAL_LOOP.is_closed():
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: projectdavid
3
- Version: 1.33.8
3
+ Version: 1.33.10
4
4
  Summary: Python SDK for interacting with the Entities Assistant API.
5
5
  Author-email: Francis Neequaye Armah <francis.neequaye@projectdavid.co.uk>
6
6
  License: PolyForm Noncommercial License 1.0.0
@@ -16,7 +16,7 @@ projectdavid/clients/files_client.py,sha256=XkIDzbQFGDrd88taf0Kouc_4YJOPIYEHiIyW
16
16
  projectdavid/clients/inference_client.py,sha256=xz4ACPv5Tkis604QxO5mJX1inH_TGDfQP-31geETYpE,6609
17
17
  projectdavid/clients/messages_client.py,sha256=467xeIt3VYs6cG8-bl-eDRi_auWOPmfd5tSJDmQSJUI,17232
18
18
  projectdavid/clients/runs.py,sha256=-fXOq5L9w2efDPmZkNxb0s2yjl6oN0XN4_aLXqaeceo,25270
19
- projectdavid/clients/synchronous_inference_wrapper.py,sha256=mN5WAHmv0aRoeMIb7XPgv3cuqrMPzu378UsZ02jEvRY,5090
19
+ projectdavid/clients/synchronous_inference_wrapper.py,sha256=Rv7TGZBnzMOBDw3BwguDOHcVmwLvcjHp7j6V8OAqpwM,4686
20
20
  projectdavid/clients/threads_client.py,sha256=ekzU5w14zftmtmFkiec3NC90Of-_KVSUY1qH9cmfSFg,6771
21
21
  projectdavid/clients/tools_client.py,sha256=GkCVOmwpAoPqVt6aYmH0G1HIFha3iEwR9IIf9teR0j8,11487
22
22
  projectdavid/clients/users_client.py,sha256=eCuUb9qvyH1GUFhZu6TRL9zdoK-qzHSs8-Vmrk_0mmg,13729
@@ -35,8 +35,8 @@ projectdavid/utils/monitor_launcher.py,sha256=3YAgJdeuaUvq3JGvpA4ymqFsAnk29nH5q9
35
35
  projectdavid/utils/peek_gate.py,sha256=5whMRnDOQjATRpThWDJkvY9ScXuJ7Sd_-9rvGgXeTAQ,2532
36
36
  projectdavid/utils/run_monitor.py,sha256=F_WkqIP-qnWH-4llIbileWWLfRj2Q1Cg-ni23SR1rec,3786
37
37
  projectdavid/utils/vector_search_formatter.py,sha256=YTe3HPGec26qGY7uxY8_GS8lc4QaN6aNXMzkl29nZpI,1735
38
- projectdavid-1.33.8.dist-info/licenses/LICENSE,sha256=_8yjiEGttpS284BkfhXxfERqTRZW_tUaHiBB0GTJTMg,4563
39
- projectdavid-1.33.8.dist-info/METADATA,sha256=lDG845Tp-MpK_JwZKPX9v8V5gbEo5rkTPjHntaAfg5Q,11554
40
- projectdavid-1.33.8.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
41
- projectdavid-1.33.8.dist-info/top_level.txt,sha256=kil8GU4s7qYRfNnzGnFHhZnSNRSxgNG-J4HLgQMmMtw,13
42
- projectdavid-1.33.8.dist-info/RECORD,,
38
+ projectdavid-1.33.10.dist-info/licenses/LICENSE,sha256=_8yjiEGttpS284BkfhXxfERqTRZW_tUaHiBB0GTJTMg,4563
39
+ projectdavid-1.33.10.dist-info/METADATA,sha256=fLLv7ywPdpBY5QMaooyy9CEFhx2cnVIY_Z8E-rvfgvk,11555
40
+ projectdavid-1.33.10.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
41
+ projectdavid-1.33.10.dist-info/top_level.txt,sha256=kil8GU4s7qYRfNnzGnFHhZnSNRSxgNG-J4HLgQMmMtw,13
42
+ projectdavid-1.33.10.dist-info/RECORD,,