工具
工具允許 LLM 在您的程式碼庫中執行操作。SlopCode 自帶一組內建工具,您也可以透過自訂工具或 MCP 伺服器來擴充它。
預設情況下,所有工具都是啟用的,且無需權限即可執行。您可以透過權限來控制工具的行為。
設定
使用 permission 欄位來控制工具行為。您可以對每個工具設定允許、拒絕或需要審批。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "edit": "deny", "bash": "ask", "webfetch": "allow" }}您還可以使用萬用字元同時控制多個工具。例如,要求某個 MCP 伺服器的所有工具都需要審批:
{ "$schema": "https://slopcode.dev/config.json", "permission": { "mymcp_*": "ask" }}了解更多關於設定權限的內容。
內建工具
以下是 SlopCode 中所有可用的內建工具。
bash
在專案環境中執行 shell 指令。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "bash": "allow" }}該工具允許 LLM 執行終端機指令,例如 npm install、git status 或其他任何 shell 指令。
edit
透過精確的字串替換來修改現有檔案。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "edit": "allow" }}該工具透過替換精確匹配的文字來對檔案進行編輯。這是 LLM 修改程式碼的主要方式。
write
建立新檔案或覆蓋現有檔案。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "edit": "allow" }}使用此工具允許 LLM 建立新檔案。如果檔案已存在,則會覆蓋現有檔案。
read
讀取程式碼庫中的檔案內容。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "read": "allow" }}該工具讀取檔案並回傳其內容。它支援對大檔案讀取指定行範圍。
grep
使用正規表示式搜尋檔案內容。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "grep": "allow" }}在程式碼庫中快速搜尋內容。支援完整的正規表示式語法和檔案模式過濾。
glob
透過模式匹配查找檔案。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "glob": "allow" }}使用 **/*.js 或 src/**/*.ts 等 glob 模式搜尋檔案。回傳按修改時間排序的匹配檔案路徑。
list
列出指定路徑下的檔案和目錄。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "list": "allow" }}該工具用於列出目錄內容。它接受 glob 模式來過濾結果。
lsp(實驗性)
與已設定的 LSP 伺服器互動,取得程式碼智慧功能,如定義跳轉、參考查找、懸停資訊和呼叫階層結構。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "lsp": "allow" }}支援的操作包括 goToDefinition、findReferences、hover、documentSymbol、workspaceSymbol、goToImplementation、prepareCallHierarchy、incomingCalls 和 outgoingCalls。
要設定專案可用的 LSP 伺服器,請參閱 LSP 伺服器。
patch
對檔案套用補丁。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "edit": "allow" }}該工具將補丁檔案套用到您的程式碼庫中。適用於套用來自各種來源的 diff 和補丁。
skill
載入一個技能(即 SKILL.md 檔案)並在對話中回傳其內容。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "skill": "allow" }}todowrite
在編碼工作階段中管理待辦事項清單。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "todowrite": "allow" }}建立和更新任務清單以追蹤複雜操作的進度。LLM 使用此工具來組織多步驟任務。
todoread
讀取現有的待辦事項清單。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "todoread": "allow" }}讀取當前待辦事項清單的狀態。LLM 使用此工具來追蹤哪些任務待處理、哪些已完成。
webfetch
擷取網頁內容。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "webfetch": "allow" }}允許 LLM 擷取並讀取網頁內容。適用於查閱文件或研究線上資源。
websearch
在網路上搜尋資訊。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "websearch": "allow" }}使用 Exa AI 進行網路搜尋以查找相關資訊。適用於研究主題、了解時事動態或取得超出訓練資料截止日期的資訊。
無需 API 金鑰——該工具無需身分驗證即可直接連接到 Exa AI 的託管 MCP 服務。
question
在執行過程中向使用者提問。
{ "$schema": "https://slopcode.dev/config.json", "permission": { "question": "allow" }}該工具允許 LLM 在執行任務期間向使用者提問。適用於以下場景:
- 收集使用者偏好或需求
- 釐清模糊的指令
- 取得實作方案的決策
- 提供方向選擇的選項
每個問題包含標題、問題正文和選項清單。使用者可以從提供的選項中選擇,也可以輸入自訂答案。當有多個問題時,使用者可以在提交所有答案之前在各問題之間切換瀏覽。
自訂工具
自訂工具允許您定義 LLM 可以呼叫的自訂函式。這些函式在您的設定檔中定義,可以執行任意程式碼。
了解更多關於建立自訂工具的內容。
MCP 伺服器
MCP(Model Context Protocol)伺服器允許您整合外部工具和服務,包括資料庫存取、API 整合和第三方服務。
了解更多關於設定 MCP 伺服器的內容。
內部機制
在內部,grep、glob 和 list 等工具底層使用 ripgrep。預設情況下,ripgrep 遵循 .gitignore 中的模式,這意味著 .gitignore 中列出的檔案和目錄將被排除在搜尋和列表結果之外。
忽略模式
要包含通常會被忽略的檔案,請在專案根目錄下建立一個 .ignore 檔案。該檔案可以明確允許某些路徑。
!node_modules/!dist/!build/例如,這個 .ignore 檔案允許 ripgrep 在 node_modules/、dist/ 和 build/ 目錄中進行搜尋,即使它們已在 .gitignore 中列出。