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

推荐订阅源

WordPress大学
WordPress大学
T
Threat Research - Cisco Blogs
D
DataBreaches.Net
Microsoft Azure Blog
Microsoft Azure Blog
D
Docker
P
Proofpoint News Feed
小众软件
小众软件
博客园 - 聂微东
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
人人都是产品经理
人人都是产品经理
J
Java Code Geeks
Martin Fowler
Martin Fowler
L
LangChain Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
李成银的技术随笔
MongoDB | Blog
MongoDB | Blog
M
MIT News - Artificial intelligence
阮一峰的网络日志
阮一峰的网络日志
Hacker News: Ask HN
Hacker News: Ask HN
C
CERT Recently Published Vulnerability Notes
H
Help Net Security
The GitHub Blog
The GitHub Blog
S
Security Archives - TechRepublic
AWS News Blog
AWS News Blog
Project Zero
Project Zero
Security Latest
Security Latest
P
Privacy International News Feed
T
Troy Hunt's Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
C
CXSECURITY Database RSS Feed - CXSecurity.com
I
Intezer
酷 壳 – CoolShell
酷 壳 – CoolShell
The Hacker News
The Hacker News
I
InfoQ
P
Proofpoint News Feed
C
Cisco Blogs
aimingoo的专栏
aimingoo的专栏
T
ThreatConnect
Recorded Future
Recorded Future
P
Palo Alto Networks Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
V
V2EX
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
G
GRAHAM CLULEY
F
Future of Privacy Forum
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
N
News and Events Feed by Topic
Engineering at Meta
Engineering at Meta

Recent Commits to openclaw:main

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 docs: tighten landable bug sweep gates · openclaw/openclaw@8f86383 fix: reuse provider auth lookup facts (#85499) · openclaw/openclaw@299ed80 fix: keep session picker focus separate · openclaw/openclaw@7e12370 feat: start onboarding for fresh CLI installs (#85519) · openclaw/openclaw@464ffc1 docs: refresh contributor docs · openclaw/openclaw@64d13c0 fix(update): prepack npm git update specs · openclaw/openclaw@84f6b5c fix: simplify chat session search · openclaw/openclaw@7e16a50 fix: use native mac settings sidebar · openclaw/openclaw@0556958 chore: ignore antigravity cli state · openclaw/openclaw@dd07fb4 fix(media): replace Gemini CLI fallback with sandboxed Antigravity (#… · openclaw/openclaw@0622fb6 docs: add bugbash landing changelog entries · openclaw/openclaw@faad2b0 fix(diffs): continue after card hydration errors (#84775) · openclaw/openclaw@9b5c281 fix(proxy): add missing clientSocket error handler in CONNECT tunnel … · openclaw/openclaw@e008bc9 fix(memory): report qmd workspace cwd probe failures (#63167) · openclaw/openclaw@7134a95 fix(agents): handle parallel tool call deltas in openai-completions s… test: align release validation package acceptance check (#85515) · openclaw/openclaw@423f525 fix: recover stuck Codex compaction · openclaw/openclaw@44d5330 docs: require visual proof for control ui e2e (#85513) · openclaw/openclaw@8174bfc Policy: add gateway exposure checks (#81981) · openclaw/openclaw@dcc5e45 ci: unblock advisory Tideclaw alpha release checks · openclaw/openclaw@dcfc7e5 fix(installer): tolerate WSL UNC launch cwd · openclaw/openclaw@684a9b2 docs: absorb docs sweep · openclaw/openclaw@bb5010b fix: cancel stale provider auth prewarms (#85503) · openclaw/openclaw@60e3749 Add TUI PTY integration coverage (#85485) · openclaw/openclaw@0a50cbd
fix(codex): preserve native web search action metadata (#85378) · openclaw/openclaw@bcf756c
vincentkoc · 2026-05-23 · via Recent Commits to openclaw:main

@@ -1528,6 +1528,32 @@ function readString(record: JsonObject, key: string): string | undefined {

15281528

return typeof value === "string" ? value : undefined;

15291529

}

153015301531+

function normalizeNonEmptyString(value: unknown): string | undefined {

1532+

if (typeof value !== "string") {

1533+

return undefined;

1534+

}

1535+

return value.trim() || undefined;

1536+

}

1537+1538+

function readNonEmptyString(record: JsonObject, key: string): string | undefined {

1539+

return normalizeNonEmptyString(record[key]);

1540+

}

1541+1542+

function readNonEmptyStringArray(record: JsonObject, key: string): string[] {

1543+

const value = record[key];

1544+

if (!Array.isArray(value)) {

1545+

return [];

1546+

}

1547+

const entries: string[] = [];

1548+

for (const entry of value) {

1549+

const normalized = normalizeNonEmptyString(entry);

1550+

if (normalized) {

1551+

entries.push(normalized);

1552+

}

1553+

}

1554+

return entries;

1555+

}

1556+15311557

function readNullableString(record: JsonObject, key: string): string | null | undefined {

15321558

const value = record[key];

15331559

if (value === null) {

@@ -1818,15 +1844,48 @@ function itemToolArgs(item: CodexThreadItem): Record<string, unknown> | undefine

18181844

changes: itemFileChanges(item),

18191845

});

18201846

}

1821-

if (item.type === "webSearch" && typeof item.query === "string") {

1822-

return sanitizeCodexAgentEventRecord({ query: item.query });

1847+

if (item.type === "webSearch") {

1848+

return webSearchToolArgs(item);

18231849

}

18241850

if (item.type === "dynamicToolCall" || item.type === "mcpToolCall") {

18251851

return sanitizeCodexToolArguments(item.arguments);

18261852

}

18271853

return undefined;

18281854

}

182918551856+

function webSearchToolArgs(item: CodexThreadItem): Record<string, unknown> {

1857+

const action = isJsonObject(item.action) ? item.action : undefined;

1858+

const actionType = action ? readNonEmptyString(action, "type") : undefined;

1859+

const queries =

1860+

action && actionType === "search" ? readNonEmptyStringArray(action, "queries") : [];

1861+

const query =

1862+

normalizeNonEmptyString(item.query) ??

1863+

(action && actionType === "search" ? readNonEmptyString(action, "query") : undefined) ??

1864+

queries[0];

1865+

const url = action ? readNonEmptyString(action, "url") : undefined;

1866+

const pattern = action ? readNonEmptyString(action, "pattern") : undefined;

1867+

const args: Record<string, unknown> = {};

1868+

if (query) {

1869+

args.query = query;

1870+

}

1871+

if (queries.length > 0) {

1872+

args.queries = queries;

1873+

}

1874+

if (actionType && actionType !== "search") {

1875+

args.action = actionType;

1876+

}

1877+

if (url) {

1878+

args.url = url;

1879+

}

1880+

if (pattern) {

1881+

args.pattern = pattern;

1882+

}

1883+

if (!query && !url && !pattern) {

1884+

args.queryUnavailable = true;

1885+

}

1886+

return sanitizeCodexAgentEventRecord(args);

1887+

}

1888+18301889

function itemToolResult(item: CodexThreadItem): { result?: Record<string, unknown> } {

18311890

if (item.type === "commandExecution") {

18321891

return {

@@ -1856,11 +1915,19 @@ function itemToolResult(item: CodexThreadItem): { result?: Record<string, unknow

18561915

};

18571916

}

18581917

if (item.type === "webSearch") {

1859-

return { result: sanitizeCodexAgentEventRecord({ status: "completed" }) };

1918+

return { result: webSearchToolResult(item) };

18601919

}

18611920

return {};

18621921

}

186319221923+

function webSearchToolResult(item: CodexThreadItem): Record<string, unknown> {

1924+

return sanitizeCodexAgentEventRecord({

1925+

status: itemStatus(item),

1926+

...(typeof item.durationMs === "number" ? { durationMs: item.durationMs } : {}),

1927+

...webSearchToolArgs(item),

1928+

});

1929+

}

1930+18641931

function itemFileChanges(item: CodexThreadItem): Array<{ path: string; kind: string }> {

18651932

return Array.isArray(item.changes)

18661933

? item.changes.map((change) => ({ path: change.path, kind: change.kind }))

@@ -1895,8 +1962,8 @@ function itemMeta(

18951962

{ detailMode },

18961963

);

18971964

}

1898-

if (item.type === "webSearch" && typeof item.query === "string") {

1899-

return item.query;

1965+

if (item.type === "webSearch") {

1966+

return inferToolMetaFromArgs("web_search", webSearchToolArgs(item), { detailMode });

19001967

}

19011968

const toolName = itemName(item);

19021969

if ((item.type === "dynamicToolCall" || item.type === "mcpToolCall") && toolName) {