meshcode 2.10.70__tar.gz → 2.10.71__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.
- {meshcode-2.10.70 → meshcode-2.10.71}/PKG-INFO +1 -1
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/__init__.py +1 -1
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/server.py +4 -1
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode.egg-info/PKG-INFO +1 -1
- {meshcode-2.10.70 → meshcode-2.10.71}/pyproject.toml +1 -1
- {meshcode-2.10.70 → meshcode-2.10.71}/README.md +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/ascii_art.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/cli.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/comms_v4.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/compat.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/error_hints.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/exceptions.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/invites.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/launcher.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/launcher_install.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/__init__.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/__main__.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/backend.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/realtime.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/test_backend.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/test_realtime.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/meshcode_mcp/test_server_wrapper.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/preferences.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/protocol_v2.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/quickstart.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/run_agent.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/secrets.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/self_update.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/setup_clients.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/supervisor.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode/upload.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode.egg-info/SOURCES.txt +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode.egg-info/dependency_links.txt +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode.egg-info/entry_points.txt +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode.egg-info/requires.txt +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/meshcode.egg-info/top_level.txt +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/setup.cfg +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_core.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_cross_agent_messaging.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_esc_deaf_state.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_exceptions.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_mark_read_batch.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_migration_integrity.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_realtime_event_freshness.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_rls_cross_tenant.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_rpc_migrations.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_security_regressions.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_sentinel.py +0 -0
- {meshcode-2.10.70 → meshcode-2.10.71}/tests/test_status_enum_coverage.py +0 -0
|
@@ -2574,7 +2574,10 @@ def meshcode_check(include_acks: bool = False, since: Optional[str] = None, mark
|
|
|
2574
2574
|
# When mark_read=True, update tracking state so messages aren't re-processed
|
|
2575
2575
|
if mark_read and deduped:
|
|
2576
2576
|
for m in deduped:
|
|
2577
|
-
_SEEN_MSG_IDS
|
|
2577
|
+
# _SEEN_MSG_IDS is a dict (key -> monotonic ts); use the helper so
|
|
2578
|
+
# eviction/ordering invariants are preserved. .add() was a regression
|
|
2579
|
+
# that crashed mark_read with: 'dict' object has no attribute 'add'.
|
|
2580
|
+
_mark_seen(_seen_key(m))
|
|
2578
2581
|
latest_ts = max((str(m.get("ts", "")) for m in deduped), default=None)
|
|
2579
2582
|
if latest_ts and (not _LAST_SEEN_TS or latest_ts > _LAST_SEEN_TS):
|
|
2580
2583
|
_LAST_SEEN_TS = latest_ts
|
|
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
|
|
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
|