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.
Files changed (32) hide show
  1. {meshcode-2.10.4 → meshcode-2.10.6}/PKG-INFO +1 -1
  2. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/__init__.py +1 -1
  3. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/comms_v4.py +28 -12
  4. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/backend.py +2 -1
  5. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/server.py +2 -1
  6. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/run_agent.py +16 -0
  7. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/PKG-INFO +1 -1
  8. {meshcode-2.10.4 → meshcode-2.10.6}/pyproject.toml +1 -1
  9. {meshcode-2.10.4 → meshcode-2.10.6}/README.md +0 -0
  10. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/ascii_art.py +0 -0
  11. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/cli.py +0 -0
  12. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/invites.py +0 -0
  13. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/launcher.py +0 -0
  14. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/launcher_install.py +0 -0
  15. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/__init__.py +0 -0
  16. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/__main__.py +0 -0
  17. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/realtime.py +0 -0
  18. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/test_backend.py +0 -0
  19. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/test_realtime.py +0 -0
  20. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/meshcode_mcp/test_server_wrapper.py +0 -0
  21. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/preferences.py +0 -0
  22. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/protocol_v2.py +0 -0
  23. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/secrets.py +0 -0
  24. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/self_update.py +0 -0
  25. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode/setup_clients.py +0 -0
  26. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/SOURCES.txt +0 -0
  27. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/dependency_links.txt +0 -0
  28. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/entry_points.txt +0 -0
  29. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/requires.txt +0 -0
  30. {meshcode-2.10.4 → meshcode-2.10.6}/meshcode.egg-info/top_level.txt +0 -0
  31. {meshcode-2.10.4 → meshcode-2.10.6}/setup.cfg +0 -0
  32. {meshcode-2.10.4 → meshcode-2.10.6}/tests/test_status_enum_coverage.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: meshcode
3
- Version: 2.10.4
3
+ Version: 2.10.6
4
4
  Summary: Real-time communication between AI agents — Supabase-backed CLI
5
5
  Author-email: MeshCode <hello@meshcode.io>
6
6
  License: MIT
@@ -1,2 +1,2 @@
1
1
  """MeshCode — Real-time communication between AI agents."""
2
- __version__ = "2.10.4"
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 run with stripped
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
- candidates = [
417
- "/opt/homebrew/bin/claude",
418
- "/usr/local/bin/claude",
419
- os.path.expanduser("~/.local/bin/claude"),
420
- os.path.expanduser("~/anaconda3/bin/claude"),
421
- "/opt/anaconda3/bin/claude",
422
- "/Applications/Claude Code.app/Contents/MacOS/claude",
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 os.path.isfile(c) and os.access(c, os.X_OK):
426
- return c
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
- return be.task_list(api_key, _PROJECT_ID, AGENT_NAME, status_filter=status_filter)
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
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: meshcode
3
- Version: 2.10.4
3
+ Version: 2.10.6
4
4
  Summary: Real-time communication between AI agents — Supabase-backed CLI
5
5
  Author-email: MeshCode <hello@meshcode.io>
6
6
  License: MIT
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "meshcode"
7
- version = "2.10.4"
7
+ version = "2.10.6"
8
8
  description = "Real-time communication between AI agents — Supabase-backed CLI"
9
9
  readme = "README.md"
10
10
  license = {text = "MIT"}
File without changes
File without changes
File without changes
File without changes
File without changes