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

推荐订阅源

Simon Willison's Weblog
Simon Willison's Weblog
L
LangChain Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
S
SegmentFault 最新的问题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
博客园 - 【当耐特】
Hugging Face - Blog
Hugging Face - Blog
小众软件
小众软件
T
Tailwind CSS Blog
IT之家
IT之家
WordPress大学
WordPress大学
The Cloudflare Blog
大猫的无限游戏
大猫的无限游戏
W
WeLiveSecurity
阮一峰的网络日志
阮一峰的网络日志
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Jina AI
Jina AI
C
Cyber Attacks, Cyber Crime and Cyber Security
美团技术团队
Hacker News - Newest:
Hacker News - Newest: "LLM"
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
A
Arctic Wolf
量子位
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
博客园 - Franky
李成银的技术随笔
C
CXSECURITY Database RSS Feed - CXSecurity.com
酷 壳 – CoolShell
酷 壳 – CoolShell
Schneier on Security
Schneier on Security
博客园 - 聂微东
博客园 - 司徒正美
宝玉的分享
宝玉的分享
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
V
V2EX
www.infosecurity-magazine.com
www.infosecurity-magazine.com
P
Palo Alto Networks Blog
雷峰网
雷峰网
J
Java Code Geeks
博客园 - 叶小钗
F
Full Disclosure
博客园 - 三生石上(FineUI控件)
O
OpenAI News
T
Tenable Blog
C
Cisco Blogs
人人都是产品经理
人人都是产品经理
S
Securelist
NISL@THU
NISL@THU

Recent Commits to openclaw:main

fix(docker): alias main images to latest release · openclaw/openclaw@3cb7ae5 fix(matrix): bound bootstrap output capture fix(agents): bound search tool stderr fix(process): bound command output capture fix(test): keep btw fs promises mock partial · openclaw/openclaw@56302f7 ci(docker): publish browser release images · openclaw/openclaw@dc31f73 fix(test): detect signaled memory fd gateway exits · openclaw/openclaw@5809bdf fix(test): detect signaled kitchen sink gateway exits · openclaw/openclaw@97ed582 docs: add release verification skill · openclaw/openclaw@6eedc83 fix(test): detect signaled test gateway exits test: stabilize code mode wait timeout · openclaw/openclaw@d7e62a8 fix(test): detect signaled cross-os gateway exits · openclaw/openclaw@f48a89c fix(test): detect signaled bundled smoke exits fix(test): hard kill boundary prep timeouts · openclaw/openclaw@a854331 fix(test): hard kill boundary step timeouts · openclaw/openclaw@3fb6746 docs: tune clawdtributor refresh summaries · openclaw/openclaw@51e57d4 fix(test): handle extension memory spawn errors · openclaw/openclaw@e5a687f chore(release): update appcast for 2026.5.27 · openclaw/openclaw@17c1b06 fix(test): bound startup build helpers · openclaw/openclaw@bda3531 test: speed up slow test suite (#87611) · openclaw/openclaw@aab5410 fix(release): bound npm release checks · openclaw/openclaw@e0635eb fix: reduce gateway warning noise · openclaw/openclaw@4252f07 fix(test): rebuild startup memory artifacts · openclaw/openclaw@4ce3c3e fix(release): bound prepack subprocesses · openclaw/openclaw@653e8d1 fix(release): bound release check commands · openclaw/openclaw@98d6331 fix(release): bound npm verifier commands · openclaw/openclaw@2b0e399 fix(e2e): bound bundled plugin selection · openclaw/openclaw@b234aa0 fix(docker): bound package capture output · openclaw/openclaw@cee364e fix(agent-sessions): fail oversized exec output · openclaw/openclaw@da55146 fix(supervisor): bound captured process output · openclaw/openclaw@2252cf6 fix(file-transfer): bound dir fetch tar listings · openclaw/openclaw@9a7f808 fix(brave): bound search error bodies · openclaw/openclaw@eb273a8 fix(test): bound package candidate command output · openclaw/openclaw@259796d fix(test): bound extension memory profiler output · openclaw/openclaw@d64b394 fix(test): wait for credential timeout cleanup · openclaw/openclaw@88c395c fix(qa-lab): bound plugin tools stderr tail · openclaw/openclaw@9085d17 fix(qa-lab): bound child process output · openclaw/openclaw@4a2b02e fix(test): escalate e2e watchdog termination · openclaw/openclaw@beb25d6 fix(security): avoid fetching untrusted proof refs · openclaw/openclaw@4bd711e fix(security): avoid CodeQL legacy auth patterns · openclaw/openclaw@3844e03 fix(test): keep upgrade survivor runtime state local · openclaw/openclaw@9fef53c Tighten phone-control mutation authorization [AI] (#87150) · openclaw/openclaw@91a4635 fix(voice-call): bound ngrok diagnostics · openclaw/openclaw@629fc2f fix(qa): expose credential fingerprints in admin list · openclaw/openclaw@1bc32e5 fix(memory): bound remote error bodies · openclaw/openclaw@93577ad Clarify directive persistence authorization policy [AI] (#86369) · openclaw/openclaw@bb418a8 fix(install): harden Windows git installs · openclaw/openclaw@dc5671e fix(qa): stabilize live transport lanes · openclaw/openclaw@f9aec04 fix(security): address OpenClaw CodeQL alerts · openclaw/openclaw@b008989 fix(parallels): guard release target harness mismatch · openclaw/openclaw@7275304 docs(skills): add OpenClaw release announcement guide · openclaw/openclaw@9805202 docs(skills): refine beta release announcement guidance · openclaw/openclaw@9ebf51e fix(release): bound cross-os fetch bodies · openclaw/openclaw@13dcded Fix Claude live tool progress for watchdog recovery (#87546) · openclaw/openclaw@4c3a029 test: avoid platform-specific transcript stat assertion · openclaw/openclaw@bd02977 fix(scripts): bound audit advisory error bodies · openclaw/openclaw@9f70064 fix: ignore leading transcript bytes in tail scan · openclaw/openclaw@b005f01 fix: avoid direct transcript stat fallback · openclaw/openclaw@e397636 fix(scripts): bound docker preflight capture fix(scripts): bound gh read error bodies · openclaw/openclaw@744da7e perf: avoid runtime catalog load for reasoning defaults fix(release): pin ClawHub publish workdir · openclaw/openclaw@a0cf185 perf: reuse preflight transcript scan size · openclaw/openclaw@8d5f6c8 fix(scripts): bound labeler error bodies perf: skip recent transcript read after final usage · openclaw/openclaw@39bc43c fix(scripts): bound memory fd ready output perf: reuse transcript scan size · openclaw/openclaw@bd6a404 fix(scripts): bound gateway watch log capture fix(agents): cancel failed skill download bodies · openclaw/openclaw@00fb152 fix(agents): suppress abandoned requester completion handoff (#87541) fix(qa): keep live transport artifacts local fix(release): speed windows upgrade fallback · openclaw/openclaw@1342727 fix(release): close cross-os artifact sockets · openclaw/openclaw@9771727 test(release): satisfy cross-os socket lint chore(ui): refresh nl control ui locale · openclaw/openclaw@43deaf4 chore(ui): refresh fa control ui locale · openclaw/openclaw@c16620c chore(ui): refresh vi control ui locale · openclaw/openclaw@55e1878 chore(ui): refresh th control ui locale · openclaw/openclaw@47c67e3 chore(ui): refresh pl control ui locale · openclaw/openclaw@062d429 chore(ui): refresh id control ui locale · openclaw/openclaw@580e95f chore(ui): refresh tr control ui locale · openclaw/openclaw@dcb00f3 chore(ui): refresh uk control ui locale · openclaw/openclaw@748015b chore(ui): refresh it control ui locale · openclaw/openclaw@ae0f469 chore(ui): refresh ar control ui locale · openclaw/openclaw@5f3012b chore(ui): refresh fr control ui locale · openclaw/openclaw@b0517f1 chore(ui): refresh ja-JP control ui locale · openclaw/openclaw@5058fc9 chore(ui): refresh ko control ui locale · openclaw/openclaw@d4ffac4 chore(ui): refresh es control ui locale · openclaw/openclaw@384dd12 chore(ui): refresh de control ui locale · openclaw/openclaw@6c858ac chore(ui): refresh pt-BR control ui locale · openclaw/openclaw@d3751e4 chore(ui): refresh zh-CN control ui locale · openclaw/openclaw@831bb45 chore(ui): refresh zh-TW control ui locale · openclaw/openclaw@71781b8 test(cron): speed up isolated fallback tests (#87520) · openclaw/openclaw@127c0ad refactor(openai): centralize codex oauth flow (#87411) · openclaw/openclaw@e805ffd test(agents): prove active live subagent steering · openclaw/openclaw@d1bca0c test(agents): narrow bounded error assertions · openclaw/openclaw@44027e7 chore: clarify bug report issue scope · openclaw/openclaw@8f6a2f0 fix(agents): preserve signed thinking payloads (#87493) · openclaw/openclaw@4a45a25 fix(test): harden startup benchmark harness · openclaw/openclaw@d10d30c fix(agents): bound minimax vlm error bodies · openclaw/openclaw@4f26cc9
perf: reduce agent turn CPU overhead · openclaw/openclaw@b58786c
steipete · 2026-05-28 · via Recent Commits to openclaw:main

@@ -1277,13 +1277,44 @@ const shouldSkipWatchRuntimeSync = (deps, requirement) =>

12771277

!hasMissingRequiredRuntimePostBuildOutput(deps);

1278127812791279

const isGatewayClientCommand = (args) =>

1280-

args[0] === "gateway" && (args[1] === "call" || args[1] === "status");

1280+

(args[0] === "gateway" && (args[1] === "call" || args[1] === "status")) ||

1281+

(args[0] === "agent" && !args.includes("--local"));

128112821282-

const shouldUseExistingDistForGatewayClient = (deps, buildRequirement) =>

1283-

buildRequirement.reason === "dirty_watched_tree" &&

1283+

const shouldFastPathExistingDistForGatewayClient = (deps) =>

12841284

isGatewayClientCommand(deps.args) &&

12851285

deps.env.OPENCLAW_FORCE_BUILD !== "1" &&

1286-

statMtime(deps.distEntry, deps.fs) != null;

1286+

statMtime(deps.distEntry, deps.fs) != null &&

1287+

canUseStampedGatewayClientDist(deps);

1288+1289+

const canUseStampedGatewayClientDist = (deps) => {

1290+

const currentHead = resolveGitHead(deps);

1291+

if (!currentHead) {

1292+

return false;

1293+

}

1294+

const buildStamp = readBuildStamp(deps);

1295+

if (buildStamp.mtime == null || buildStamp.head !== currentHead) {

1296+

return false;

1297+

}

1298+

for (const filePath of deps.configFiles) {

1299+

const mtime = statMtime(filePath, deps.fs);

1300+

if (mtime != null && mtime > buildStamp.mtime) {

1301+

return false;

1302+

}

1303+

}

1304+

if (hasMissingBuiltBundledPluginRuntimeEntryOutput(deps)) {

1305+

return false;

1306+

}

1307+

const runtimeStamp = readRuntimePostBuildStamp(deps);

1308+

if (

1309+

runtimeStamp.mtime == null ||

1310+

runtimeStamp.mtime < buildStamp.mtime ||

1311+

runtimeStamp.head !== currentHead ||

1312+

deps.env.OPENCLAW_FORCE_RUNTIME_POSTBUILD === "1"

1313+

) {

1314+

return false;

1315+

}

1316+

return !resolveRuntimePostBuildRequirement(deps).shouldSync;

1317+

};

1287131812881319

const isQaParityReportCommand = (args) => args[0] === "qa" && args[1] === "parity-report";

12891320

const isQaCoverageReportCommand = (args) => args[0] === "qa" && args[1] === "coverage";

@@ -1374,16 +1405,13 @@ export async function runNodeMain(params = {}) {

1374140513751406

try {

13761407

let exitCode = 1;

1377-

let buildRequirement = resolveBuildRequirement(deps);

1378-

const useExistingGatewayClientDist = shouldUseExistingDistForGatewayClient(

1379-

deps,

1380-

buildRequirement,

1381-

);

1408+

if (shouldFastPathExistingDistForGatewayClient(deps)) {

1409+

exitCode = await runOpenClaw(deps);

1410+

return await closeRunNodeOutputTee(deps, exitCode);

1411+

}

1412+

const buildRequirement = resolveBuildRequirement(deps);

13821413

const useQaParityReportSource = shouldRunQaParityReportFromSource(deps, buildRequirement);

13831414

const useQaCoverageReportSource = shouldRunQaCoverageReportFromSource(deps, buildRequirement);

1384-

if (useExistingGatewayClientDist) {

1385-

buildRequirement = { shouldBuild: false, reason: "gateway_client_existing_dist" };

1386-

}

13871415

if (useQaParityReportSource) {

13881416

logRunner("Running QA parity report from source without rebuilding private QA dist.", deps);

13891417

exitCode = await runQaParityReportFromSource(deps);

@@ -1395,26 +1423,24 @@ export async function runNodeMain(params = {}) {

13951423

return await closeRunNodeOutputTee(deps, exitCode);

13961424

}

13971425

if (!buildRequirement.shouldBuild) {

1398-

if (!useExistingGatewayClientDist) {

1399-

const runtimePostBuildRequirement = resolveRuntimePostBuildRequirement(deps);

1400-

if (

1401-

runtimePostBuildRequirement.shouldSync &&

1402-

!shouldSkipWatchRuntimeSync(deps, runtimePostBuildRequirement)

1403-

) {

1404-

const synced = await withRunNodeBuildLock(deps, async () => {

1405-

const lockedRuntimePostBuildRequirement = resolveRuntimePostBuildRequirement(deps);

1406-

if (!lockedRuntimePostBuildRequirement.shouldSync) {

1407-

return true;

1408-

}

1409-

logRunner(

1410-

`Syncing runtime artifacts (${lockedRuntimePostBuildRequirement.reason} - ${formatRuntimePostBuildReason(lockedRuntimePostBuildRequirement.reason)}).`,

1411-

deps,

1412-

);

1413-

return await syncRuntimeArtifactsAndStamp(deps);

1414-

});

1415-

if (!synced) {

1416-

return await closeRunNodeOutputTee(deps, 1);

1426+

const runtimePostBuildRequirement = resolveRuntimePostBuildRequirement(deps);

1427+

if (

1428+

runtimePostBuildRequirement.shouldSync &&

1429+

!shouldSkipWatchRuntimeSync(deps, runtimePostBuildRequirement)

1430+

) {

1431+

const synced = await withRunNodeBuildLock(deps, async () => {

1432+

const lockedRuntimePostBuildRequirement = resolveRuntimePostBuildRequirement(deps);

1433+

if (!lockedRuntimePostBuildRequirement.shouldSync) {

1434+

return true;

14171435

}

1436+

logRunner(

1437+

`Syncing runtime artifacts (${lockedRuntimePostBuildRequirement.reason} - ${formatRuntimePostBuildReason(lockedRuntimePostBuildRequirement.reason)}).`,

1438+

deps,

1439+

);

1440+

return await syncRuntimeArtifactsAndStamp(deps);

1441+

});

1442+

if (!synced) {

1443+

return await closeRunNodeOutputTee(deps, 1);

14181444

}

14191445

}

14201446

exitCode = await runOpenClaw(deps);