291 lines
47 KiB
HTML
291 lines
47 KiB
HTML
|
<!DOCTYPE html><html><head>
|
|||
|
<title>agent服务协议</title>
|
|||
|
<meta charset="utf-8">
|
|||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|||
|
|
|||
|
<link rel="stylesheet" href="assets/katex/katex.min.css">
|
|||
|
|
|||
|
|
|||
|
<script type="text/javascript" src="assets/mermaid/mermaid.min.js" charset="UTF-8"></script>
|
|||
|
|
|||
|
|
|||
|
<style>
|
|||
|
code[class*=language-],pre[class*=language-]{color:#333;background:0 0;font-family:Consolas,"Liberation Mono",Menlo,Courier,monospace;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.4;-moz-tab-size:8;-o-tab-size:8;tab-size:8;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{padding:.8em;overflow:auto;border-radius:3px;background:#f5f5f5}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal;background:#f5f5f5}.token.blockquote,.token.comment{color:#969896}.token.cdata{color:#183691}.token.doctype,.token.macro.property,.token.punctuation,.token.variable{color:#333}.token.builtin,.token.important,.token.keyword,.token.operator,.token.rule{color:#a71d5d}.token.attr-value,.token.regex,.token.string,.token.url{color:#183691}.token.atrule,.token.boolean,.token.code,.token.command,.token.constant,.token.entity,.token.number,.token.property,.token.symbol{color:#0086b3}.token.prolog,.token.selector,.token.tag{color:#63a35c}.token.attr-name,.token.class,.token.class-name,.token.function,.token.id,.token.namespace,.token.pseudo-class,.token.pseudo-element,.token.url-reference .token.variable{color:#795da3}.token.entity{cursor:help}.token.title,.token.title .token.punctuation{font-weight:700;color:#1d3e81}.token.list{color:#ed6a43}.token.inserted{background-color:#eaffea;color:#55a532}.token.deleted{background-color:#ffecec;color:#bd2c00}.token.bold{font-weight:700}.token.italic{font-style:italic}.language-json .token.property{color:#183691}.language-markup .token.tag .token.punctuation{color:#333}.language-css .token.function,code.language-css{color:#0086b3}.language-yaml .token.atrule{color:#63a35c}code.language-yaml{color:#183691}.language-ruby .token.function{color:#333}.language-markdown .token.url{color:#795da3}.language-makefile .token.symbol{color:#795da3}.language-makefile .token.variable{color:#183691}.language-makefile .token.builtin{color:#0086b3}.language-bash .token.keyword{color:#0086b3}pre[data-line]{position:relative;padding:1em 0 1em 3em}pre[data-line] .line-highlight-wrapper{position:absolute;top:0;left:0;background-color:transparent;display:block;width:100%}pre[data-line] .line-highlight{position:absolute;left:0;right:0;padding:inherit 0;margin-top:1em;background:hsla(24,20%,50%,.08);background:linear-gradient(to right,hsla(24,20%,50%,.1) 70%,hsla(24,20%,50%,0));pointer-events:none;line-height:inherit;white-space:pre}pre[data-line] .line-highlight:before,pre[data-line] .line-highlight[data-end]:after{content:attr(data-start);position:absolute;top:.4em;left:.6em;min-width:1em;padding:0 .5em;background-color:hsla(24,20%,50%,.4);color:#f4f1ef;font:bold 65%/1.5 sans-serif;text-align:center;vertical-align:.3em;border-radius:999px;text-shadow:none;box-shadow:0 1px #fff}pre[data-line] .line-highlight[data-end]:after{content:attr(data-end);top:auto;bottom:.4em}html body{font-family:'Helvetica Neue',Helvetica,'Segoe UI',Arial,freesans,sans-serif;font-size:16px;line-height:1.6;color:#333;background-color:#fff;overflow:initial;box-sizing:border-box;word-wrap:break-word}html body>:first-child{margin-top:0}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{line-height:1.2;margin-top:1em;margin-bottom:16px;color:#000}html body h1{font-size:2.25em;font-weight:300;padding-bottom:.3em}html body h2{font-size:1.75em;font-weight:400;padding-bottom:.3em}html body h3{font-size:1.5em;font-weight:500}html body h4{font-size:1.25em;font-weight:600}html body h5{font-size:1.1em;font-weight:600}html body h6{font-size:1em;font-weight:600}html body h1,html body h2,html body h3,html body h4,html body h5{font-weight:600}html body h5{font-size:1em}html body h6{color:#5c5c5c}html body strong{color:#000}html body del{color:#5c5c5c}html body a:not([href]){color:inherit;text-decoration:none}html body a{color:#08c;text-decoration:none}html body a:hover{color:#00a3f5;text-decoration:none}html body img{max-width:100%}html body>p{margin-top:0;margin-bottom:16px;word-wrap:break-word}html body>ol,html
|
|||
|
/* Please visit the URL below for more information: */
|
|||
|
/* https://shd101wyy.github.io/markdown-preview-enhanced/#/customize-css */
|
|||
|
|
|||
|
</style>
|
|||
|
<!-- The content below will be included at the end of the <head> element. --><script type="text/javascript">
|
|||
|
document.addEventListener("DOMContentLoaded", function () {
|
|||
|
// your code here
|
|||
|
});
|
|||
|
</script></head><body for="html-export">
|
|||
|
|
|||
|
|
|||
|
<div class="crossnote markdown-preview ">
|
|||
|
|
|||
|
<h4 id="1-ai-agent">1. AI agent </h4>
|
|||
|
<p>Agent模块负责处理request工作流,生成prompt与LLM交互。<br>
|
|||
|
Agent 有三模式运行,由plugin在request的model参数决定,运行模式在交互过程对agent是透明的。</p>
|
|||
|
<blockquote>
|
|||
|
<ol>
|
|||
|
<li>agent local model:就是agent调用本地部署的LLM模型</li>
|
|||
|
<li>agent remote api:就是agent调用openai或deepseek等外部服务的api</li>
|
|||
|
<li>plugin remote api:由plugin调用openai或deepseek等外部服务的api</li>
|
|||
|
</ol>
|
|||
|
</blockquote>
|
|||
|
<p>agent网页版测试 <a href="https://host:port/simpletest2025">https://host:port/simpletest2025</a><br>
|
|||
|
前端测试代码 repo/examples<br>
|
|||
|
测试api_key: “<em><strong>simpletest2025</strong></em>_xxxx” xxxx为任意字符串</p>
|
|||
|
<h5 id="11-系统框架">1.1 系统框架 </h5>
|
|||
|
<img src="assets/架构.png" alt="drawing" style="width:700px;">
|
|||
|
<p>ideservice 是须要plugin提供给agent的一些获取IDE信息的基础功能,为穿透NAT需要websocket连接。</p>
|
|||
|
<h5 id="12-workflow">1.2 workflow </h5>
|
|||
|
<div class="mermaid">sequenceDiagram
|
|||
|
plugin->>agent: request
|
|||
|
agent-->>ideservice: more info
|
|||
|
ideservice-->>agent: file, symbol
|
|||
|
agent->>plugin: result
|
|||
|
</div><p>agent有可能会多次向ideservice询问更多的信息,这对于plugin是透明的。</p>
|
|||
|
<h5 id="13-task-pool">1.3 Task Pool </h5>
|
|||
|
<p>章节2中所有带cmd参数带前缀“exec”的request都是涉及LLM模型调用的。<br>
|
|||
|
Agent用一个FIFO队列缓存所有用户的未处理任务,当队列长度过大时agent会拒绝新来的任务。<br>
|
|||
|
同一APIkey同时能建立5个链接,一个连接只能有一个任务在队列,同时提交两个task, 前一个会被取消。</p>
|
|||
|
<h4 id="2-agent协议">2. Agent协议 </h4>
|
|||
|
<p>plugin通过websocket连接agent。如果使用https, 需要设置client接受agent的https认证证书。</p>
|
|||
|
<h5 id="21-身份认证">2.1 身份认证 </h5>
|
|||
|
<p>建立连接时带header "X-Api-Key" : api_key,如果api_key不对agent主动断开连接</p>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token keyword keyword-let">let</span> client <span class="token operator">=</span> <span class="token keyword keyword-new">new</span> <span class="token class-name">ws<span class="token punctuation">.</span>WebSocket</span><span class="token punctuation">(</span><span class="token string">'wss://host:8080/ws'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span><span class="token literal-property property">headers</span><span class="token operator">:</span> <span class="token punctuation">{</span>
|
|||
|
<span class="token punctuation">[</span><span class="token string">"X-Api-Key"</span><span class="token punctuation">]</span><span class="token operator">:</span> <span class="token string">"simpletest2025_001"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">}</span><span class="token punctuation">)</span>
|
|||
|
</code></pre><h5 id="22-获取agent支持的模型-list_model">2.2 获取Agent支持的模型 (list_model) </h5>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">request</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"request_id"</span><span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"list_model"</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
<span class="token literal-property property">response</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"request_id"</span><span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 同request</span>
|
|||
|
<span class="token string-property property">"models"</span> <span class="token operator">:</span> <span class="token punctuation">[</span><span class="token string">"local deepseek-R1:32b"</span><span class="token punctuation">,</span> <span class="token string">"deepseek-R1:32b"</span><span class="token punctuation">]</span> <span class="token comment">// (必填)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
</code></pre><h5 id="23-生成代码解释-exec_explain">2.3 生成代码解释 (exec_explain) </h5>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">request</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_explain"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span> <span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"language"</span> <span class="token operator">:</span> <span class="token string">"en"</span><span class="token punctuation">,</span> <span class="token comment">// 语言, en-英文, zh-中文,默认为 en (可选)</span>
|
|||
|
<span class="token string-property property">"selected_text"</span><span class="token operator">:</span> text_context<span class="token punctuation">,</span> <span class="token comment">// 选取的代码片段 (必填)</span>
|
|||
|
<span class="token string-property property">"visible_text"</span> <span class="token operator">:</span> text_context<span class="token punctuation">,</span> <span class="token comment">// ide窗口可见的代码片段 (必填)</span>
|
|||
|
<span class="token string-property property">"model"</span> <span class="token operator">:</span> <span class="token string">"local deepseek-r1:32b"</span><span class="token punctuation">,</span> <span class="token comment">//(必填)</span>
|
|||
|
<span class="token string-property property">"stream"</span> <span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
<span class="token literal-property property">text_context</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"filepath"</span><span class="token operator">:</span> <span class="token string">"example\\\\game.py"</span><span class="token punctuation">,</span> <span class="token comment">// 文件路径 </span>
|
|||
|
<span class="token string-property property">"range"</span><span class="token operator">:</span> <span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"start"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">33</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token comment">// 从33行0字符开始</span>
|
|||
|
<span class="token string-property property">"end"</span> <span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">41</span><span class="token punctuation">}</span> <span class="token comment">// 到45行41字符结束</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"text"</span><span class="token operator">:</span> <span class="token string">"..."</span> <span class="token comment">// 源码片段</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
<span class="token literal-property property">成功返回</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"request_id"</span> <span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 同request(必填)</span>
|
|||
|
<span class="token string-property property">"msg"</span> <span class="token operator">:</span> <span class="token string">""</span><span class="token punctuation">,</span> <span class="token comment">// 返回内容</span>
|
|||
|
<span class="token string-property property">"stream_seq_id"</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">,</span> <span class="token comment">// stream sequence id,目前未支持 (可选)</span>
|
|||
|
<span class="token string-property property">"stream_finish"</span><span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream 结束,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
<span class="token literal-property property">失败返回</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"request_id"</span><span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 同request(必填)</span>
|
|||
|
<span class="token string-property property">"error"</span> <span class="token operator">:</span> <span class="token string">"cancelled"</span> <span class="token comment">// 出错信息,没有就是调用成功(必填)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
</code></pre><h5 id="24-生成代码文档-exec_docstring">2.4 生成代码文档 (exec_docstring) </h5>
|
|||
|
<p>目前只支持python</p>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">request</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_docstring"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span> <span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"language"</span> <span class="token operator">:</span> <span class="token string">"en"</span><span class="token punctuation">,</span> <span class="token comment">// 语言, en-英文, zh-中文,默认为 en (可选)</span>
|
|||
|
<span class="token string-property property">"selected_text"</span><span class="token operator">:</span> text_context<span class="token punctuation">,</span> <span class="token comment">// 选取的代码片段 (必填)</span>
|
|||
|
<span class="token string-property property">"model"</span> <span class="token operator">:</span> <span class="token string">"local deepseek-r1:32b"</span><span class="token punctuation">,</span> <span class="token comment">//(必填)</span>
|
|||
|
<span class="token string-property property">"stream"</span> <span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
返回json格式同 <span class="token number">2.3</span>
|
|||
|
</code></pre><h5 id="25-代码优化-exec_optimize">2.5 代码优化 (exec_optimize) </h5>
|
|||
|
<p>//TODO 未测试效果, prompt该如何描述优化?</p>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">request</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_optimize"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span> <span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"language"</span> <span class="token operator">:</span> <span class="token string">"en"</span><span class="token punctuation">,</span> <span class="token comment">// 语言, en-英文, zh-中文,默认为 en (可选)</span>
|
|||
|
<span class="token string-property property">"selected_text"</span><span class="token operator">:</span> <span class="token string">""</span><span class="token punctuation">,</span> <span class="token comment">// 选取的代码片段 (必填)</span>
|
|||
|
<span class="token string-property property">"model"</span> <span class="token operator">:</span> <span class="token string">"local deepseek-r1:32b"</span><span class="token punctuation">,</span> <span class="token comment">//(必填)</span>
|
|||
|
<span class="token string-property property">"stream"</span> <span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
返回json格式同 <span class="token number">2.3</span>
|
|||
|
</code></pre><h5 id="26-生成单元测试代码-exec_fix">2.6 生成单元测试代码 (exec_fix) </h5>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">request</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_fix"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span> <span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"language"</span> <span class="token operator">:</span> <span class="token string">"en"</span><span class="token punctuation">,</span> <span class="token comment">// 语言, en-英文, zh-中文,默认为 en (可选)</span>
|
|||
|
<span class="token string-property property">"selected_text"</span><span class="token operator">:</span> <span class="token string">""</span><span class="token punctuation">,</span> <span class="token comment">// 选取的代码片段 (必填)</span>
|
|||
|
<span class="token string-property property">"model"</span> <span class="token operator">:</span> <span class="token string">"local deepseek-r1:32b"</span><span class="token punctuation">,</span><span class="token comment">//(必填)</span>
|
|||
|
<span class="token string-property property">"stream"</span> <span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
|
|||
|
返回json格式同 <span class="token number">2.3</span>
|
|||
|
</code></pre><h5 id="27-生成单元测试代码-exec_unittest">2.7 生成单元测试代码 (exec_unittest) </h5>
|
|||
|
<p>// TODO 与ideservice交互</p>
|
|||
|
<p>目前仅支持英文回复, 流程对devchat做了简化</p>
|
|||
|
<div class="mermaid">sequenceDiagram
|
|||
|
plugin->>agent: exec_unittest_recommend 请求测试建议
|
|||
|
agent->>plugin: 测试建议
|
|||
|
plugin->>agent: exec_unittest_code 请求测试代码
|
|||
|
plugin->>agent: 测试代码
|
|||
|
</div><pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">请求测试建议</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_unittest_recommend"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span><span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"language"</span> <span class="token operator">:</span> <span class="token string">"en"</span><span class="token punctuation">,</span> <span class="token comment">// 语言, en-英文, zh-中文,默认为 en (可选)</span>
|
|||
|
|
|||
|
<span class="token string-property property">"user_prompt"</span> <span class="token operator">:</span> <span class="token string">""</span><span class="token punctuation">,</span> <span class="token comment">// 用户定制化描述 (可选)</span>
|
|||
|
<span class="token string-property property">"file_content"</span> <span class="token operator">:</span> <span class="token string">"..."</span> <span class="token comment">// 整个文件内容(必填)</span>
|
|||
|
<span class="token string-property property">"filepath"</span> <span class="token operator">:</span> <span class="token string">"\\example\\game.py"</span><span class="token punctuation">,</span> <span class="token comment">// 文件路径(必填)</span>
|
|||
|
<span class="token string-property property">"func_name"</span> <span class="token operator">:</span> <span class="token string">"next_turn"</span><span class="token punctuation">,</span> <span class="token comment">// 函数名 (必填)</span>
|
|||
|
<span class="token string-property property">"func_location"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 函数位置(必填)</span>
|
|||
|
<span class="token string-property property">"start"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">33</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"end"</span> <span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">41</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
|
|||
|
<span class="token string-property property">"func_symbols"</span><span class="token operator">:</span> <span class="token punctuation">[</span> <span class="token comment">// function 内的所以变量名和函数名 (必填)</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"name"</span><span class="token operator">:</span> <span class="token string">"next_turn"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"kind"</span><span class="token operator">:</span> <span class="token string">"Function"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"range"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 位置</span>
|
|||
|
<span class="token string-property property">"start"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">33</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"end"</span> <span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">41</span><span class="token punctuation">}</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"children"</span><span class="token operator">:</span> <span class="token punctuation">[</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"name"</span><span class="token operator">:</span> <span class="token string">"WIDTH"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"kind"</span><span class="token operator">:</span> <span class="token string">"Constant"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"range"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 位置</span>
|
|||
|
<span class="token string-property property">"start"</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">33</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"end"</span> <span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token string-property property">"line"</span><span class="token operator">:</span> <span class="token number">45</span><span class="token punctuation">,</span> <span class="token string-property property">"character"</span><span class="token operator">:</span> <span class="token number">41</span><span class="token punctuation">}</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"children"</span><span class="token operator">:</span> <span class="token punctuation">[</span>
|
|||
|
<span class="token spread operator">...</span>
|
|||
|
<span class="token punctuation">]</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token punctuation">]</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token spread operator">...</span>
|
|||
|
<span class="token punctuation">]</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"model"</span> <span class="token operator">:</span> <span class="token string">"local deepseek-r1:32b"</span><span class="token punctuation">,</span> <span class="token comment">//(必填)</span>
|
|||
|
<span class="token string-property property">"stream"</span> <span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
返回json格式同 <span class="token number">2.3</span>
|
|||
|
|
|||
|
请求测试代码:
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_unittest_code"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span> <span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"language"</span> <span class="token operator">:</span> <span class="token string">"en"</span><span class="token punctuation">,</span> <span class="token comment">// 语言, en-英文, zh-中文,默认为 en (可选)</span>
|
|||
|
<span class="token string-property property">"test_cases_str"</span><span class="token operator">:</span> <span class="token string">""</span><span class="token punctuation">,</span> <span class="token comment">// exec_unittest_recommend 提供的 (必填)</span>
|
|||
|
|
|||
|
<span class="token comment">// 如果task_id为空须填写:</span>
|
|||
|
<span class="token string-property property">"function_name"</span> <span class="token operator">:</span> <span class="token string">""</span> <span class="token comment">// 函数名 (可选)</span>
|
|||
|
<span class="token string-property property">"user_prompt"</span> <span class="token operator">:</span> <span class="token string">""</span> <span class="token comment">// 定制化描述 (可选)</span>
|
|||
|
<span class="token string-property property">"file_path"</span> <span class="token operator">:</span> <span class="token string">"./src/test.py"</span> <span class="token comment">// 文件在项目里的相对路径 (可选)</span>
|
|||
|
<span class="token string-property property">"relevant_content"</span> <span class="token operator">:</span> <span class="token string">""</span> <span class="token comment">// the relevant source code of the function (可选)</span>
|
|||
|
<span class="token string-property property">"reference_content"</span><span class="token operator">:</span> <span class="token string">""</span> <span class="token comment">// the relevant source code of the function (可选)</span>
|
|||
|
|
|||
|
<span class="token string-property property">"stream"</span><span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
返回json格式同 <span class="token number">2.3</span>
|
|||
|
</code></pre><h5 id="28-和大模型对话-exec_chat">2.8 和大模型对话 (exec_chat) </h5>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code><span class="token literal-property property">request</span><span class="token operator">:</span>
|
|||
|
<span class="token punctuation">{</span>
|
|||
|
<span class="token string-property property">"cmd"</span> <span class="token operator">:</span> <span class="token string">"exec_chat"</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"request_id"</span><span class="token operator">:</span> <span class="token number">123</span><span class="token punctuation">,</span> <span class="token comment">// 随机生成 (必填)</span>
|
|||
|
<span class="token string-property property">"msg"</span> <span class="token operator">:</span> <span class="token string">""</span><span class="token punctuation">,</span> <span class="token comment">// 内容 (必填)</span>
|
|||
|
<span class="token string-property property">"model"</span> <span class="token operator">:</span> <span class="token string">"local deepseek-r1:32b"</span><span class="token punctuation">,</span> <span class="token comment">//(必填)</span>
|
|||
|
<span class="token string-property property">"stream"</span> <span class="token operator">:</span> <span class="token boolean">false</span> <span class="token comment">// stream方式返回,目前未支持 (可选)</span>
|
|||
|
<span class="token punctuation">}</span>
|
|||
|
返回json格式同 <span class="token number">2.3</span>
|
|||
|
</code></pre><h4 id="3-ide_service协议">3. ide_service协议 </h4>
|
|||
|
<p>开发优先级低,解决2.7“与ideservice交互”问题前未用到</p>
|
|||
|
<p>是由 agent 向 ide_service 请求,参考<br>
|
|||
|
<a href="https://github.com/devchat-ai/devchat-vscode/blob/main/src/ide_services/services.ts">https://github.com/devchat-ai/devchat-vscode/blob/main/src/ide_services/services.ts</a></p>
|
|||
|
<p>只保留以下服务,</p>
|
|||
|
<pre data-role="codeBlock" data-info="javascript" class="language-javascript javascript"><code> <span class="token string-property property">"/get_document_symbols"</span><span class="token operator">:</span> <span class="token punctuation">{</span>
|
|||
|
<span class="token literal-property property">keys</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token string">"abspath"</span><span class="token punctuation">]</span><span class="token punctuation">,</span>
|
|||
|
<span class="token literal-property property">handler</span><span class="token operator">:</span> getDocumentSymbols<span class="token punctuation">,</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"/find_def_locations"</span><span class="token operator">:</span> <span class="token punctuation">{</span>
|
|||
|
<span class="token literal-property property">keys</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token string">"abspath"</span><span class="token punctuation">,</span> <span class="token string">"line"</span><span class="token punctuation">,</span> <span class="token string">"character"</span><span class="token punctuation">]</span><span class="token punctuation">,</span>
|
|||
|
<span class="token literal-property property">handler</span><span class="token operator">:</span> findDefinitionLocations<span class="token punctuation">,</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
<span class="token string-property property">"/find_type_def_locations"</span><span class="token operator">:</span> <span class="token punctuation">{</span>
|
|||
|
<span class="token literal-property property">keys</span><span class="token operator">:</span> <span class="token punctuation">[</span><span class="token string">"abspath"</span><span class="token punctuation">,</span> <span class="token string">"line"</span><span class="token punctuation">,</span> <span class="token string">"character"</span><span class="token punctuation">]</span><span class="token punctuation">,</span>
|
|||
|
<span class="token literal-property property">handler</span><span class="token operator">:</span> findTypeDefinitionLocations<span class="token punctuation">,</span>
|
|||
|
<span class="token punctuation">}</span><span class="token punctuation">,</span>
|
|||
|
</code></pre><h4 id="3-功能覆盖">3. 功能覆盖 </h4>
|
|||
|
<img src="assets/功能覆盖.png">
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
<script type="module">
|
|||
|
// TODO: If ZenUML gets integrated into mermaid in the future,
|
|||
|
// we can remove the following lines.
|
|||
|
|
|||
|
|
|||
|
var MERMAID_CONFIG = ({"startOnLoad":false});
|
|||
|
if (typeof MERMAID_CONFIG !== 'undefined') {
|
|||
|
MERMAID_CONFIG.startOnLoad = false
|
|||
|
MERMAID_CONFIG.cloneCssStyles = false
|
|||
|
MERMAID_CONFIG.theme = "default"
|
|||
|
}
|
|||
|
|
|||
|
mermaid.initialize(MERMAID_CONFIG || {})
|
|||
|
if (typeof(window['Reveal']) !== 'undefined') {
|
|||
|
function mermaidRevealHelper(event) {
|
|||
|
var currentSlide = event.currentSlide
|
|||
|
var diagrams = currentSlide.querySelectorAll('.mermaid')
|
|||
|
for (var i = 0; i < diagrams.length; i++) {
|
|||
|
var diagram = diagrams[i]
|
|||
|
if (!diagram.hasAttribute('data-processed')) {
|
|||
|
mermaid.init(null, diagram, ()=> {
|
|||
|
Reveal.slide(event.indexh, event.indexv)
|
|||
|
})
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
Reveal.addEventListener('slidetransitionend', mermaidRevealHelper)
|
|||
|
Reveal.addEventListener('ready', mermaidRevealHelper)
|
|||
|
await mermaid.run({
|
|||
|
nodes: document.querySelectorAll('.mermaid')
|
|||
|
})
|
|||
|
} else {
|
|||
|
await mermaid.run({
|
|||
|
nodes: document.querySelectorAll('.mermaid')
|
|||
|
})
|
|||
|
}
|
|||
|
</script>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
</body></html>
|