meshcode 2.10.4__tar.gz → 2.10.6__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.4 → meshcode-2.10.6}/PKG-INFO +1 -1
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/__init__.py +1 -1
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/comms_v4.py +28 -12
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/backend.py +2 -1
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/server.py +2 -1
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/run_agent.py +16 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/PKG-INFO +1 -1
- {meshcode-2.10.4 → meshcode-2.10.6}/pyproject.toml +1 -1
- {meshcode-2.10.4 → meshcode-2.10.6}/README.md +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/ascii_art.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/cli.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/invites.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/launcher.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/launcher_install.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/__init__.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/__main__.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/realtime.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/test_backend.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/test_realtime.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/test_server_wrapper.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/preferences.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/protocol_v2.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/secrets.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/self_update.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/setup_clients.py +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/SOURCES.txt +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/dependency_links.txt +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/entry_points.txt +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/requires.txt +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/top_level.txt +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/setup.cfg +0 -0
- {meshcode-2.10.4 → meshcode-2.10.6}/tests/test_status_enum_coverage.py +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
"""MeshCode — Real-time communication between AI agents."""
|
|
2
|
-
__version__ = "2.10.
|
|
2
|
+
__version__ = "2.10.6"
|
|
@@ -407,23 +407,39 @@ _ACTIONABLE_FIELDS = {"task", "ask", "q", "question", "need", "request", "please
|
|
|
407
407
|
|
|
408
408
|
def _find_claude():
|
|
409
409
|
"""Locate the claude CLI binary. PATH lookup first, then common install
|
|
410
|
-
locations. Critical for daemons (launchd/systemd) which
|
|
411
|
-
PATH and won't find claude via plain `claude` invocation."""
|
|
410
|
+
locations. Critical for daemons (launchd/systemd/Windows services) which
|
|
411
|
+
run with stripped PATH and won't find claude via plain `claude` invocation."""
|
|
412
412
|
import shutil as _sh
|
|
413
413
|
p = _sh.which("claude")
|
|
414
414
|
if p:
|
|
415
415
|
return p
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
"
|
|
419
|
-
os.
|
|
420
|
-
os.
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
416
|
+
if sys.platform == "win32":
|
|
417
|
+
# Windows: npm global installs, AppData locations, Program Files
|
|
418
|
+
appdata = os.environ.get("APPDATA", "")
|
|
419
|
+
localappdata = os.environ.get("LOCALAPPDATA", "")
|
|
420
|
+
userprofile = os.environ.get("USERPROFILE", "")
|
|
421
|
+
candidates = [
|
|
422
|
+
os.path.join(appdata, "npm", "claude.cmd"),
|
|
423
|
+
os.path.join(appdata, "npm", "claude"),
|
|
424
|
+
os.path.join(localappdata, "Programs", "claude", "claude.exe"),
|
|
425
|
+
os.path.join(localappdata, "Microsoft", "WinGet", "Packages", "Anthropic.Claude", "claude.exe"),
|
|
426
|
+
os.path.join(userprofile, "AppData", "Local", "npm-cache", "_npx", "claude.cmd"),
|
|
427
|
+
os.path.join(os.environ.get("ProgramFiles", r"C:\Program Files"), "nodejs", "claude.cmd"),
|
|
428
|
+
os.path.join(os.environ.get("ProgramFiles", r"C:\Program Files"), "Claude", "claude.exe"),
|
|
429
|
+
]
|
|
430
|
+
else:
|
|
431
|
+
candidates = [
|
|
432
|
+
"/opt/homebrew/bin/claude",
|
|
433
|
+
"/usr/local/bin/claude",
|
|
434
|
+
os.path.expanduser("~/.local/bin/claude"),
|
|
435
|
+
os.path.expanduser("~/anaconda3/bin/claude"),
|
|
436
|
+
"/opt/anaconda3/bin/claude",
|
|
437
|
+
"/Applications/Claude Code.app/Contents/MacOS/claude",
|
|
438
|
+
]
|
|
424
439
|
for c in candidates:
|
|
425
|
-
if
|
|
426
|
-
|
|
440
|
+
if c and os.path.isfile(c):
|
|
441
|
+
if sys.platform == "win32" or os.access(c, os.X_OK):
|
|
442
|
+
return c
|
|
427
443
|
return "claude" # last resort — will fail with -127, logged clearly
|
|
428
444
|
|
|
429
445
|
|
|
@@ -572,12 +572,13 @@ def task_create(api_key, project_id, creator_agent, title, description="", assig
|
|
|
572
572
|
})
|
|
573
573
|
|
|
574
574
|
|
|
575
|
-
def task_list(api_key, project_id, agent, status_filter=None):
|
|
575
|
+
def task_list(api_key, project_id, agent, status_filter=None, include_done=False):
|
|
576
576
|
return sb_rpc("mc_task_list", {
|
|
577
577
|
"p_api_key": api_key,
|
|
578
578
|
"p_project_id": project_id,
|
|
579
579
|
"p_agent": agent,
|
|
580
580
|
"p_status_filter": status_filter,
|
|
581
|
+
"p_include_done": include_done,
|
|
581
582
|
})
|
|
582
583
|
|
|
583
584
|
|
|
@@ -1869,7 +1869,8 @@ def meshcode_tasks(status_filter: Optional[str] = None) -> Dict[str, Any]:
|
|
|
1869
1869
|
Returns: {"ok": true, "tasks": [...]}
|
|
1870
1870
|
"""
|
|
1871
1871
|
api_key = _get_api_key()
|
|
1872
|
-
|
|
1872
|
+
include_done = status_filter == "done"
|
|
1873
|
+
return be.task_list(api_key, _PROJECT_ID, AGENT_NAME, status_filter=status_filter, include_done=include_done)
|
|
1873
1874
|
|
|
1874
1875
|
|
|
1875
1876
|
@mcp.tool()
|
|
@@ -353,6 +353,22 @@ def _detect_editor() -> Optional[str]:
|
|
|
353
353
|
for cmd in ("claude", "cursor", "code", "windsurf", "codex"):
|
|
354
354
|
if shutil.which(cmd):
|
|
355
355
|
return cmd
|
|
356
|
+
|
|
357
|
+
# Windows fallback: check common install locations not in PATH
|
|
358
|
+
if sys.platform == "win32":
|
|
359
|
+
appdata = os.environ.get("APPDATA", "")
|
|
360
|
+
localappdata = os.environ.get("LOCALAPPDATA", "")
|
|
361
|
+
win_candidates = [
|
|
362
|
+
os.path.join(appdata, "npm", "claude.cmd"),
|
|
363
|
+
os.path.join(appdata, "npm", "claude"),
|
|
364
|
+
os.path.join(localappdata, "Programs", "claude", "claude.exe"),
|
|
365
|
+
os.path.join(localappdata, "Programs", "cursor", "Cursor.exe"),
|
|
366
|
+
os.path.join(os.environ.get("ProgramFiles", r"C:\Program Files"), "Claude", "claude.exe"),
|
|
367
|
+
]
|
|
368
|
+
for c in win_candidates:
|
|
369
|
+
if c and os.path.isfile(c):
|
|
370
|
+
return c
|
|
371
|
+
|
|
356
372
|
return None
|
|
357
373
|
|
|
358
374
|
|
|
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
|