|
@@ -3,10 +3,13 @@ export function deactivate() {}
|
|
|
|
|
|
|
|
import * as vscode from "vscode"
|
|
import * as vscode from "vscode"
|
|
|
|
|
|
|
|
|
|
+const TERMINAL_NAME = "opencode"
|
|
|
|
|
+
|
|
|
export function activate(context: vscode.ExtensionContext) {
|
|
export function activate(context: vscode.ExtensionContext) {
|
|
|
- const TERMINAL_NAME = "opencode"
|
|
|
|
|
|
|
+ let openNewTerminalDisposable = vscode.commands.registerCommand("opencode.openNewTerminal", async () => {
|
|
|
|
|
+ await openTerminal()
|
|
|
|
|
+ })
|
|
|
|
|
|
|
|
- // Register command to open terminal in split screen and run opencode
|
|
|
|
|
let openTerminalDisposable = vscode.commands.registerCommand("opencode.openTerminal", async () => {
|
|
let openTerminalDisposable = vscode.commands.registerCommand("opencode.openTerminal", async () => {
|
|
|
// An opencode terminal already exists => focus it
|
|
// An opencode terminal already exists => focus it
|
|
|
const existingTerminal = vscode.window.terminals.find((t) => t.name === TERMINAL_NAME)
|
|
const existingTerminal = vscode.window.terminals.find((t) => t.name === TERMINAL_NAME)
|
|
@@ -15,6 +18,27 @@ export function activate(context: vscode.ExtensionContext) {
|
|
|
return
|
|
return
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ await openTerminal()
|
|
|
|
|
+ })
|
|
|
|
|
+
|
|
|
|
|
+ let addFilepathDisposable = vscode.commands.registerCommand("opencode.addFilepathToTerminal", async () => {
|
|
|
|
|
+ const fileRef = getActiveFile()
|
|
|
|
|
+ if (!fileRef) return
|
|
|
|
|
+
|
|
|
|
|
+ const terminal = vscode.window.activeTerminal
|
|
|
|
|
+ if (!terminal) return
|
|
|
|
|
+
|
|
|
|
|
+ if (terminal.name === TERMINAL_NAME) {
|
|
|
|
|
+ // @ts-ignore
|
|
|
|
|
+ const port = terminal.creationOptions.env?.["_EXTENSION_OPENCODE_PORT"]
|
|
|
|
|
+ port ? await appendPrompt(parseInt(port), fileRef) : terminal.sendText(fileRef)
|
|
|
|
|
+ terminal.show()
|
|
|
|
|
+ }
|
|
|
|
|
+ })
|
|
|
|
|
+
|
|
|
|
|
+ context.subscriptions.push(openTerminalDisposable, addFilepathDisposable)
|
|
|
|
|
+
|
|
|
|
|
+ async function openTerminal() {
|
|
|
// Create a new terminal in split screen
|
|
// Create a new terminal in split screen
|
|
|
const port = Math.floor(Math.random() * (65535 - 16384 + 1)) + 16384
|
|
const port = Math.floor(Math.random() * (65535 - 16384 + 1)) + 16384
|
|
|
const terminal = vscode.window.createTerminal({
|
|
const terminal = vscode.window.createTerminal({
|
|
@@ -57,64 +81,46 @@ export function activate(context: vscode.ExtensionContext) {
|
|
|
await appendPrompt(port, `In ${fileRef}`)
|
|
await appendPrompt(port, `In ${fileRef}`)
|
|
|
terminal.show()
|
|
terminal.show()
|
|
|
}
|
|
}
|
|
|
- })
|
|
|
|
|
-
|
|
|
|
|
- // Register command to add filepath to terminal
|
|
|
|
|
- let addFilepathDisposable = vscode.commands.registerCommand("opencode.addFilepathToTerminal", async () => {
|
|
|
|
|
- const fileRef = getActiveFile()
|
|
|
|
|
- if (!fileRef) return
|
|
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- const terminal = vscode.window.activeTerminal
|
|
|
|
|
- if (!terminal) return
|
|
|
|
|
|
|
+ async function appendPrompt(port: number, text: string) {
|
|
|
|
|
+ await fetch(`http://localhost:${port}/tui/append-prompt`, {
|
|
|
|
|
+ method: "POST",
|
|
|
|
|
+ headers: {
|
|
|
|
|
+ "Content-Type": "application/json",
|
|
|
|
|
+ },
|
|
|
|
|
+ body: JSON.stringify({ text }),
|
|
|
|
|
+ })
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if (terminal.name === TERMINAL_NAME) {
|
|
|
|
|
- // @ts-ignore
|
|
|
|
|
- const port = terminal.creationOptions.env?.["_EXTENSION_OPENCODE_PORT"]
|
|
|
|
|
- port ? await appendPrompt(parseInt(port), fileRef) : terminal.sendText(fileRef)
|
|
|
|
|
- terminal.show()
|
|
|
|
|
|
|
+ function getActiveFile() {
|
|
|
|
|
+ const activeEditor = vscode.window.activeTextEditor
|
|
|
|
|
+ if (!activeEditor) return
|
|
|
|
|
+
|
|
|
|
|
+ const document = activeEditor.document
|
|
|
|
|
+ const workspaceFolder = vscode.workspace.getWorkspaceFolder(document.uri)
|
|
|
|
|
+ if (!workspaceFolder) return
|
|
|
|
|
+
|
|
|
|
|
+ // Get the relative path from workspace root
|
|
|
|
|
+ const relativePath = vscode.workspace.asRelativePath(document.uri)
|
|
|
|
|
+ let filepathWithAt = `@${relativePath}`
|
|
|
|
|
+
|
|
|
|
|
+ // Check if there's a selection and add line numbers
|
|
|
|
|
+ const selection = activeEditor.selection
|
|
|
|
|
+ if (!selection.isEmpty) {
|
|
|
|
|
+ // Convert to 1-based line numbers
|
|
|
|
|
+ const startLine = selection.start.line + 1
|
|
|
|
|
+ const endLine = selection.end.line + 1
|
|
|
|
|
+
|
|
|
|
|
+ if (startLine === endLine) {
|
|
|
|
|
+ // Single line selection
|
|
|
|
|
+ filepathWithAt += `#L${startLine}`
|
|
|
|
|
+ } else {
|
|
|
|
|
+ // Multi-line selection
|
|
|
|
|
+ filepathWithAt += `#L${startLine}-${endLine}`
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|
|
|
- })
|
|
|
|
|
-
|
|
|
|
|
- context.subscriptions.push(openTerminalDisposable, addFilepathDisposable)
|
|
|
|
|
-}
|
|
|
|
|
|
|
|
|
|
-async function appendPrompt(port: number, text: string) {
|
|
|
|
|
- await fetch(`http://localhost:${port}/tui/append-prompt`, {
|
|
|
|
|
- method: "POST",
|
|
|
|
|
- headers: {
|
|
|
|
|
- "Content-Type": "application/json",
|
|
|
|
|
- },
|
|
|
|
|
- body: JSON.stringify({ text }),
|
|
|
|
|
- })
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
-function getActiveFile() {
|
|
|
|
|
- const activeEditor = vscode.window.activeTextEditor
|
|
|
|
|
- if (!activeEditor) return
|
|
|
|
|
-
|
|
|
|
|
- const document = activeEditor.document
|
|
|
|
|
- const workspaceFolder = vscode.workspace.getWorkspaceFolder(document.uri)
|
|
|
|
|
- if (!workspaceFolder) return
|
|
|
|
|
-
|
|
|
|
|
- // Get the relative path from workspace root
|
|
|
|
|
- const relativePath = vscode.workspace.asRelativePath(document.uri)
|
|
|
|
|
- let filepathWithAt = `@${relativePath}`
|
|
|
|
|
-
|
|
|
|
|
- // Check if there's a selection and add line numbers
|
|
|
|
|
- const selection = activeEditor.selection
|
|
|
|
|
- if (!selection.isEmpty) {
|
|
|
|
|
- // Convert to 1-based line numbers
|
|
|
|
|
- const startLine = selection.start.line + 1
|
|
|
|
|
- const endLine = selection.end.line + 1
|
|
|
|
|
-
|
|
|
|
|
- if (startLine === endLine) {
|
|
|
|
|
- // Single line selection
|
|
|
|
|
- filepathWithAt += `#L${startLine}`
|
|
|
|
|
- } else {
|
|
|
|
|
- // Multi-line selection
|
|
|
|
|
- filepathWithAt += `#L${startLine}-${endLine}`
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ return filepathWithAt
|
|
|
}
|
|
}
|
|
|
-
|
|
|
|
|
- return filepathWithAt
|
|
|
|
|
}
|
|
}
|