@dmsdc-ai/aterm-darwin-arm64 0.1.42 → 0.1.44

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.
Binary file
@@ -77,9 +77,9 @@ try:
77
77
  name = s.get("name") or os.path.basename(s.get("cwd", "")) or s.get("id", "?")
78
78
  cli = s.get("cli", "")
79
79
  cwd = s.get("cwd", "")
80
- status = s.get("status", "")
81
- rows.append((name, cli, cwd, status))
82
- cols = ["NAME", "CLI", "CWD", "STATUS"]
80
+ terminal = s.get("terminal", "aterm")
81
+ rows.append((name, cli, cwd, terminal))
82
+ cols = ["NAME", "CLI", "CWD", "TERMINAL"]
83
83
  widths = [max(len(c), *(len(r[i]) for r in rows)) for i, c in enumerate(cols)]
84
84
  fmt = " ".join(f"{{:<{w}}}" for w in widths)
85
85
  print(fmt.format(*cols))
@@ -100,11 +100,106 @@ finally:
100
100
 
101
101
  case "${1:-help}" in
102
102
  list)
103
- if [[ -z "$ATERM_IPC_SOCKET" ]]; then exec telepty list "${@:2}"; fi
104
103
  if [[ "${2:-}" == "--json" ]]; then
105
- ATERM_LIST_JSON=1 aterm_ipc list
104
+ # JSON mode: output merged JSON
105
+ python3 -c '
106
+ import json, sys, os, subprocess, os.path
107
+
108
+ sessions = []
109
+
110
+ # 1. aterm internal sessions
111
+ sock = os.environ.get("ATERM_IPC_SOCKET", "")
112
+ if sock:
113
+ import socket as S
114
+ try:
115
+ s = S.socket(S.AF_UNIX, S.SOCK_STREAM)
116
+ s.settimeout(5)
117
+ s.connect(sock)
118
+ s.sendall(json.dumps({"action": "ListWorkspaces"}).encode() + b"\n")
119
+ s.shutdown(S.SHUT_WR)
120
+ data = b""
121
+ while True:
122
+ chunk = s.recv(4096)
123
+ if not chunk: break
124
+ data += chunk
125
+ if b"\n" in data: break
126
+ s.close()
127
+ resp = json.loads(data.decode().strip().split("\n")[0])
128
+ for ws in resp.get("data", []):
129
+ ws["terminal"] = "aterm"
130
+ ws.setdefault("name", os.path.basename(ws.get("cwd", "")) or ws.get("id", "?"))
131
+ sessions.append(ws)
132
+ except: pass
133
+
134
+ # 2. telepty external sessions (only if installed)
135
+ try:
136
+ result = subprocess.run(["telepty", "list", "--json"], capture_output=True, text=True, timeout=5)
137
+ if result.returncode == 0:
138
+ tdata = json.loads(result.stdout)
139
+ for ts in (tdata if isinstance(tdata, list) else tdata.get("sessions", [])):
140
+ ts.setdefault("terminal", ts.get("terminal", "external"))
141
+ ts.setdefault("name", ts.get("id", "?"))
142
+ sessions.append(ts)
143
+ except (FileNotFoundError, subprocess.TimeoutExpired, json.JSONDecodeError): pass
144
+
145
+ print(json.dumps({"sessions": sessions}))
146
+ '
106
147
  else
107
- aterm_ipc list
148
+ # Table mode: merged display
149
+ python3 -c '
150
+ import json, sys, os, subprocess, os.path
151
+
152
+ sessions = []
153
+
154
+ # 1. aterm internal sessions
155
+ sock = os.environ.get("ATERM_IPC_SOCKET", "")
156
+ if sock:
157
+ import socket as S
158
+ try:
159
+ s = S.socket(S.AF_UNIX, S.SOCK_STREAM)
160
+ s.settimeout(5)
161
+ s.connect(sock)
162
+ s.sendall(json.dumps({"action": "ListWorkspaces"}).encode() + b"\n")
163
+ s.shutdown(S.SHUT_WR)
164
+ data = b""
165
+ while True:
166
+ chunk = s.recv(4096)
167
+ if not chunk: break
168
+ data += chunk
169
+ if b"\n" in data: break
170
+ s.close()
171
+ resp = json.loads(data.decode().strip().split("\n")[0])
172
+ for ws in resp.get("data", []):
173
+ name = ws.get("name") or os.path.basename(ws.get("cwd", "")) or ws.get("id", "?")
174
+ cli = ws.get("cli", "")
175
+ cwd = ws.get("cwd", "")
176
+ sessions.append((name, cli, cwd, "aterm"))
177
+ except: pass
178
+
179
+ # 2. telepty external sessions (only if installed)
180
+ try:
181
+ result = subprocess.run(["telepty", "list", "--json"], capture_output=True, text=True, timeout=5)
182
+ if result.returncode == 0:
183
+ tdata = json.loads(result.stdout)
184
+ for ts in (tdata if isinstance(tdata, list) else tdata.get("sessions", [])):
185
+ name = ts.get("name") or ts.get("id", "?")
186
+ cli = ts.get("cli", "")
187
+ cwd = ts.get("cwd", "")
188
+ terminal = ts.get("terminal", "external")
189
+ sessions.append((name, cli, cwd, terminal))
190
+ except (FileNotFoundError, subprocess.TimeoutExpired, json.JSONDecodeError): pass
191
+
192
+ if not sessions:
193
+ print("(no reachable sessions)")
194
+ else:
195
+ cols = ["NAME", "CLI", "CWD", "TERMINAL"]
196
+ widths = [max(len(c), *(len(r[i]) for r in sessions)) for i, c in enumerate(cols)]
197
+ fmt = " ".join(f"{{:<{w}}}" for w in widths)
198
+ print(fmt.format(*cols))
199
+ print(" ".join("\u2500" * w for w in widths))
200
+ for r in sessions:
201
+ print(fmt.format(*r))
202
+ '
108
203
  fi ;;
109
204
  inject)
110
205
  if [[ -z "$ATERM_IPC_SOCKET" ]]; then exec telepty inject "${@:2}"; fi
@@ -208,7 +303,7 @@ print(json.dumps({"status":"ok","type": ltype}))
208
303
 
209
304
  | Command | Description |
210
305
  |---------|-------------|
211
- | `aterm list` | List all workspaces (JSON) |
306
+ | `aterm list` | List workspaces (NAME, CLI, CWD, TERMINAL) |
212
307
  | `aterm inject <workspace> <text>` | Send text to a workspace |
213
308
  | `aterm status <workspace>` | Check workspace status |
214
309
  | `aterm focus <workspace>` | Focus a workspace tab |
@@ -240,6 +335,11 @@ print(json.dumps({"status":"ok","type": ltype}))
240
335
  | 'list external sessions' / '외부 세션 목록' | `telepty list` |
241
336
  | 'message deliberation session' | `telepty inject aigentry-deliberation-claude 'message'` |
242
337
 
338
+ ## Session Detection Priority
339
+ 1. `aterm list` — internal sessions (project names + terminal=aterm)
340
+ 2. `telepty list` — external sessions (project names + terminal type)
341
+ 3. NEVER use `ps aux | grep` as primary (no project names, no terminal info)
342
+
243
343
  ## Detection Rules
244
344
  - `$ATERM_IPC_SOCKET` set → inside aterm. Use `aterm` commands.
245
345
  - `$ATERM_IPC_SOCKET` unset → outside aterm. Use `telepty` commands.
@@ -6,7 +6,7 @@
6
6
  <dict>
7
7
  <key>Resources/bin/aterm</key>
8
8
  <data>
9
- gCSvUlukYdFw7e5CEaiBmwTblYQ=
9
+ Eo30lOm6tQOBit8cEckLNf2wOfk=
10
10
  </data>
11
11
  </dict>
12
12
  <key>files2</key>
@@ -24,7 +24,7 @@
24
24
  <dict>
25
25
  <key>hash2</key>
26
26
  <data>
27
- GC8l6O6WnDcgzRItQVXGDO4R0YvrkuR70RugB4H7NRs=
27
+ dIHFn0s4fzTy9zKMZ9mb35TwtC8y7AHoIbJhnFciR3Y=
28
28
  </data>
29
29
  </dict>
30
30
  </dict>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dmsdc-ai/aterm-darwin-arm64",
3
- "version": "0.1.42",
3
+ "version": "0.1.44",
4
4
  "description": "darwin-arm64 native bundle for @dmsdc-ai/aterm",
5
5
  "type": "module",
6
6
  "files": [