惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
The Exploit Database - CXSecurity.com
D
Darknet – Hacking Tools, Hacker News & Cyber Security
V
Vulnerabilities – Threatpost
Blog — PlanetScale
Blog — PlanetScale
G
Google Developers Blog
M
MIT News - Artificial intelligence
C
Cybersecurity and Infrastructure Security Agency CISA
MyScale Blog
MyScale Blog
P
Privacy International News Feed
MongoDB | Blog
MongoDB | Blog
Know Your Adversary
Know Your Adversary
P
Palo Alto Networks Blog
AWS News Blog
AWS News Blog
Cisco Talos Blog
Cisco Talos Blog
Malwarebytes
Malwarebytes
aimingoo的专栏
aimingoo的专栏
T
Threat Research - Cisco Blogs
Last Week in AI
Last Week in AI
量子位
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
C
CERT Recently Published Vulnerability Notes
Hugging Face - Blog
Hugging Face - Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Y
Y Combinator Blog
L
LangChain Blog
L
LINUX DO - 热门话题
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
Simon Willison's Weblog
Simon Willison's Weblog
V
Visual Studio Blog
S
Security @ Cisco Blogs
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
O
OpenAI News
N
News | PayPal Newsroom
Stack Overflow Blog
Stack Overflow Blog
H
Hackread – Cybersecurity News, Data Breaches, AI and More
V
V2EX - 技术
李成银的技术随笔
Recent Announcements
Recent Announcements
C
Check Point Blog
Attack and Defense Labs
Attack and Defense Labs
Recent Commits to openclaw:main
Recent Commits to openclaw:main
S
Security Archives - TechRepublic
小众软件
小众软件
博客园 - 聂微东
月光博客
月光博客
GbyAI
GbyAI
T
Troy Hunt's Blog
S
Securelist
雷峰网
雷峰网

Recent Commits to openclaw:main

fix(gateway): restore WebChat image understanding routing fix(anthropic): migrate 1M context to GA handling test(ci): harden installer smoke coverage · openclaw/openclaw@68bcd4e fix(status): bound deep docker audit probes (#85476) · openclaw/openclaw@f7c05dc docs: expand meeting notes docs · openclaw/openclaw@a7e0fa0 fix(cli): validate tasks audit limit (#84901) · openclaw/openclaw@44d470f fix(twitch): preserve newer message handler during cleanup (#85425) · openclaw/openclaw@71ddc01 fix(ci): require live docker credentials by resource · openclaw/openclaw@1e21121 fix(diagnostics): drop snake case otel ids (#72645) · openclaw/openclaw@e0bafc5 fix(ci): clear signal and docs guard blockers (#85693) · openclaw/openclaw@3a1d4dd fix(ci): require factory auth for droid live docker · openclaw/openclaw@cc6c372 fix: honor disabled synthetic auth lookup · openclaw/openclaw@a4a1abb fix(scripts): repair live docker auth shellcheck · openclaw/openclaw@4e34ac4 fix(docker): avoid printing gateway token · openclaw/openclaw@5db773f fix(cli): keep logs follow on live gateway state · openclaw/openclaw@6e3b318 fix(e2e): prefer x64 MinGit on Windows · openclaw/openclaw@15d9134 feat: add meeting notes plugin docs: update changelog for memory artifacts (#85060) (thanks @brokema… · openclaw/openclaw@9e55383 fix(memory-lancedb): expose public memory artifacts · openclaw/openclaw@aac1abe fix(memory): preserve sidecar capability hooks · openclaw/openclaw@e6288ca fix(e2e): scrub Windows update config on PowerShell 5.1 · openclaw/openclaw@6657b49 docs: absorb documentation PR sweep · openclaw/openclaw@2c536a8 fix(agents): stabilize Linux fallback tests · openclaw/openclaw@6b04170 fix(codex): preserve native web search action metadata (#85378) · openclaw/openclaw@bcf756c test: refresh Codex prompt snapshots · openclaw/openclaw@492d656 docs: absorb hook and subagent guidance PRs fix(agents): audit tool policy blocks (#85673) · openclaw/openclaw@09dd051 ci: fix plugin npm bundled dependency install · openclaw/openclaw@d485464 feat(diagnostics): classify skill and tool usage (#80370) docs(skills): clarify control ui recording proof (#85568) · openclaw/openclaw@0b476b9 test(agents): repair main failure fixtures · openclaw/openclaw@c29967b feat(diagnostics): trace gateway secret preparation (#83019) · openclaw/openclaw@4f0c902 fix(diagnostics): harden observability exports and smokes (#85371) · openclaw/openclaw@7f05be0 fix(stepfun): drop stale auth choice metadata · openclaw/openclaw@0b2ab6c test(e2e): sample kitchen sink RSS on Windows · openclaw/openclaw@73c1e37 test(plugins): fail gauntlet on load diagnostics fix(build): preserve tsdown heap floor · openclaw/openclaw@9ff1a43 fix(tools): honor config apiKey in media tool preflight (#85570) · openclaw/openclaw@31c269f fix(e2e): support macOS script wrappers fix(ci): scope changed shrinkwrap checks · openclaw/openclaw@743fd4c chore(ui): refresh fa control ui locale chore(ui): refresh nl control ui locale · openclaw/openclaw@908464b chore(ui): refresh vi control ui locale · openclaw/openclaw@62b75f4 chore(ui): refresh th control ui locale · openclaw/openclaw@fc4ba31 chore(ui): refresh id control ui locale · openclaw/openclaw@5b1bdd1 chore(ui): refresh pl control ui locale · openclaw/openclaw@534d4b1 chore(ui): refresh uk control ui locale · openclaw/openclaw@055c3bd chore(ui): refresh ar control ui locale · openclaw/openclaw@89c5a68 chore(ui): refresh it control ui locale · openclaw/openclaw@44ca805 chore(ui): refresh tr control ui locale chore(ui): refresh fr control ui locale · openclaw/openclaw@2240b0e chore(ui): refresh ko control ui locale · openclaw/openclaw@5fa250b chore(ui): refresh ja-JP control ui locale · openclaw/openclaw@f4ea401 chore(ui): refresh es control ui locale · openclaw/openclaw@751dde0 chore(ui): refresh de control ui locale · openclaw/openclaw@72a9b5b chore(ui): refresh pt-BR control ui locale · openclaw/openclaw@501b6e0 chore(ui): refresh zh-CN control ui locale chore(ui): refresh zh-TW control ui locale · openclaw/openclaw@88dee79 Add Slack approval QA checkpoints (#85141) fix(agents): mirror internal ui message tool replies (#85564) perf(whatsapp): narrow runtime setter entry (#85589) · openclaw/openclaw@463929d fix: smooth chat focus mode layout · openclaw/openclaw@bb5abef Fix Telegram missing harness spool poison (#85605) · openclaw/openclaw@b745082 fix(session): surface previous-transcript archive failures on /new ro… · openclaw/openclaw@679a46d Policy: add agent workspace conformance checks (#85096) · openclaw/openclaw@a94f344 fix(installer): fail failed Windows git builds · openclaw/openclaw@2edd6e2 fix(codex): honor node exec policy for native surfaces (#85534) · openclaw/openclaw@e0405ec fix(qa-lab): stabilize codex runtime parity fixtures fix(github): preserve sufficient proof against negative relabel (#85567) · openclaw/openclaw@6b52dff docs: add changelog for context pressure preflight · openclaw/openclaw@5ca734f Fix context pressure preflight for tool-heavy sessions (#85541) · openclaw/openclaw@c08400e fix(doctor): classify codex asset notice as info (#85119) · openclaw/openclaw@959b935 fix(ui): keep chat picker search current (#85547) fix: preserve message-tool delivery evidence · openclaw/openclaw@f022b05 fix(codex): add API key paste auth (#85533) fix: satisfy openai video test typecheck · openclaw/openclaw@743caed fix: route openai video edits to edits endpoint · openclaw/openclaw@6c3fcb8 fix(qmd): normalize direct file collection paths (#65212) · openclaw/openclaw@227b4bf fix(testbox): preserve clean sparse checkouts · openclaw/openclaw@58e9628 fix(ui): run ui script through junction paths (#85525) · openclaw/openclaw@ad19dd8 docs: fix troubleshooting logs link (#85545) · openclaw/openclaw@60582b6 Revert chat session picker inline search (#85527) · openclaw/openclaw@d69bcfd fix: preserve guarded video operation cleanup · openclaw/openclaw@ed7d99a fix: honor openai video provider request network policy fix: retry guarded video downloads · openclaw/openclaw@efbf9f3 fix: thread openai video request policy · openclaw/openclaw@31b5145 docs(changelog): note heartbeat message-tool fix · openclaw/openclaw@c127334 fix: use fs-safe trash for agent delete (#84394) · openclaw/openclaw@951bbe6 Fix heartbeat message-tool delivery policy (#85357) · openclaw/openclaw@bd9c78f Scope config preflight note suppression (#84439) · openclaw/openclaw@91d85e7 fix(cron): document best-effort edit delivery mode (#84526) fix(dreaming): open report cards from memory palace (#85144) · openclaw/openclaw@2e15830 fix(openai-codex): preserve image input capability (#85393) · openclaw/openclaw@49ce171 fix(codex): stabilize heartbeat dynamic tool schema (#84681) · openclaw/openclaw@c52daa4 docs: absorb small documentation PRs · openclaw/openclaw@658be7f fix(scripts): preserve bws resolver parse errors (#85528) · openclaw/openclaw@13a4c57 fix(telegram): honor outbound media max bytes (#83478) · openclaw/openclaw@f2d4f93 fix(skills): restore executable bit on bundled whisper script + relea… · openclaw/openclaw@1dd3b52 fix(google): print Gemini OAuth URL before browser launch (#71469) · openclaw/openclaw@2d5bda9 docs: absorb contributor documentation fixes
fix(scripts): resolve Crabbox shims on Windows · openclaw/openclaw@5c535df
vincentkoc · 2026-05-23 · via Recent Commits to openclaw:main

@@ -1,13 +1,14 @@

11

#!/usr/bin/env node

22

import { spawn, spawnSync } from "node:child_process";

3-

import { existsSync, mkdtempSync, readFileSync, rmSync } from "node:fs";

3+

import { mkdtempSync, readFileSync, rmSync, statSync } from "node:fs";

44

import { tmpdir } from "node:os";

5-

import { dirname, isAbsolute, relative, resolve } from "node:path";

5+

import { delimiter, dirname, extname, isAbsolute, relative, resolve } from "node:path";

66

import { fileURLToPath } from "node:url";

7+

import { resolvePathEnvKey } from "./windows-cmd-helpers.mjs";

7889

const repoRoot = resolve(dirname(fileURLToPath(import.meta.url)), "..");

9-

const repoLocal = resolve(repoRoot, "../crabbox/bin/crabbox");

10-

const binary = existsSync(repoLocal) ? repoLocal : "crabbox";

10+

const repoLocal = resolveCrabboxBinary(process.env, process.platform);

11+

const binary = repoLocal ?? resolvePathBinary("crabbox", process.env, process.platform);

1112

const args = process.argv.slice(2);

12131314

if (args[0] === "--") {

@@ -18,11 +19,95 @@ if (args[userArgStart] === "--") {

1819

args.splice(userArgStart, 1);

1920

}

202122+

function commandCandidates(command, platform) {

23+

if (platform !== "win32") {

24+

return [command];

25+

}

26+

if (extname(command)) {

27+

return [command];

28+

}

29+

return [`${command}.exe`, `${command}.cmd`, `${command}.bat`, `${command}.com`, command];

30+

}

31+32+

function resolveCrabboxBinary(env, platform) {

33+

const base = resolve(repoRoot, "../crabbox/bin/crabbox");

34+

for (const candidate of commandCandidates(base, platform)) {

35+

if (isFile(candidate)) {

36+

return candidate;

37+

}

38+

}

39+

return null;

40+

}

41+42+

function resolvePathBinary(command, env, platform) {

43+

if (platform !== "win32") {

44+

return command;

45+

}

46+

for (const candidate of commandCandidates(command, platform)) {

47+

if (isFile(candidate)) {

48+

return candidate;

49+

}

50+

}

51+

const pathValue = env[resolvePathEnvKey(env)] ?? "";

52+

for (const dir of pathValue.split(delimiter).filter(Boolean)) {

53+

for (const candidate of commandCandidates(command, platform)) {

54+

const fullPath = resolve(dir, candidate);

55+

if (isFile(fullPath)) {

56+

return fullPath;

57+

}

58+

}

59+

}

60+

return command;

61+

}

62+63+

function isFile(path) {

64+

try {

65+

return statSync(path).isFile();

66+

} catch {

67+

return false;

68+

}

69+

}

70+71+

function spawnInvocation(command, commandArgs, env, platform) {

72+

const extension = extname(command).toLowerCase();

73+

if (platform === "win32" && (extension === ".cmd" || extension === ".bat")) {

74+

return {

75+

command: env.ComSpec ?? "cmd.exe",

76+

args: ["/d", "/s", "/c", buildBatchCommandLine(command, commandArgs)],

77+

windowsVerbatimArguments: true,

78+

};

79+

}

80+

return { command, args: commandArgs };

81+

}

82+83+

const cmdMetaCharactersRe = /([()\][%!^"`<>&|;, *?])/g;

84+85+

function escapeBatchCommand(command) {

86+

return `${command}`.replace(cmdMetaCharactersRe, "^$1");

87+

}

88+89+

function escapeBatchArgument(arg) {

90+

let escaped = `${arg}`;

91+

escaped = escaped.replace(/(?=(\\+?)?)\1"/g, '$1$1\\"');

92+

escaped = escaped.replace(/(?=(\\+?)?)\1$/, "$1$1");

93+

escaped = `"${escaped}"`;

94+

escaped = escaped.replace(cmdMetaCharactersRe, "^$1");

95+

return escaped.replace(cmdMetaCharactersRe, "^$1");

96+

}

97+98+

function buildBatchCommandLine(command, commandArgs) {

99+

const escapedCommand = escapeBatchCommand(command);

100+

const escapedArgs = commandArgs.map(escapeBatchArgument);

101+

return `"${[escapedCommand, ...escapedArgs].join(" ")}"`;

102+

}

103+21104

function checkedOutput(command, commandArgs) {

22-

const result = spawnSync(command, commandArgs, {

105+

const invocation = spawnInvocation(command, commandArgs, process.env, process.platform);

106+

const result = spawnSync(invocation.command, invocation.args, {

23107

cwd: repoRoot,

24108

encoding: "utf8",

25109

stdio: ["ignore", "pipe", "pipe"],

110+

windowsVerbatimArguments: invocation.windowsVerbatimArguments,

26111

});

27112

return {

28113

status: result.status ?? 1,

@@ -31,10 +116,13 @@ function checkedOutput(command, commandArgs) {

31116

}

3211733118

function gitOutput(commandArgs) {

34-

const result = spawnSync("git", commandArgs, {

119+

const gitBinary = resolvePathBinary("git", process.env, process.platform);

120+

const invocation = spawnInvocation(gitBinary, commandArgs, process.env, process.platform);

121+

const result = spawnSync(invocation.command, invocation.args, {

35122

cwd: repoRoot,

36123

encoding: "utf8",

37124

stdio: ["ignore", "pipe", "pipe"],

125+

windowsVerbatimArguments: invocation.windowsVerbatimArguments,

38126

});

39127

return {

40128

status: result.status ?? 1,

@@ -609,10 +697,12 @@ if (

609697

}

610698611699

const childArgs = childCwd === repoRoot ? args : absolutizeLocalRunPaths(args);

612-

const child = spawn(binary, childArgs, {

700+

const childInvocation = spawnInvocation(binary, childArgs, childEnv, process.platform);

701+

const child = spawn(childInvocation.command, childInvocation.args, {

613702

cwd: childCwd,

614703

stdio: "inherit",

615704

env: childEnv,

705+

windowsVerbatimArguments: childInvocation.windowsVerbatimArguments,

616706

});

617707618708

const signalExitCodes = new Map([