summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorDax Raad <[email protected]>2025-05-29 11:58:40 -0400
committerDax Raad <[email protected]>2025-05-29 11:58:40 -0400
commit80597cd3fdf149cef87db55f03a3cc0bfd723a7a (patch)
treeb9332733cca2084a86334eb88fdc5115ab37b922
parent48f81fe4d3a286ead827888e030f9bd89c864dee (diff)
downloadopencode-80597cd3fdf149cef87db55f03a3cc0bfd723a7a.tar.gz
opencode-80597cd3fdf149cef87db55f03a3cc0bfd723a7a.zip
type error fix
-rw-r--r--js/example/broken.ts1
-rw-r--r--js/example/cli.ts21
-rw-r--r--js/example/ink.tsx122
-rw-r--r--js/src/app/app.ts (renamed from js/src/app/index.ts)0
-rw-r--r--js/src/bus/index.ts2
-rw-r--r--js/src/config/config.ts (renamed from js/src/app/config.ts)34
-rw-r--r--js/src/index.ts2
-rw-r--r--js/src/llm/llm.ts17
-rw-r--r--js/src/llm/models/anthropic.ts0
-rw-r--r--js/src/llm/models/index.ts1
-rw-r--r--js/src/llm/models/model.ts11
-rw-r--r--js/src/lsp/client.ts3
-rw-r--r--js/src/lsp/index.ts3
-rw-r--r--js/src/provider/provider.ts32
-rw-r--r--js/src/server/server.ts6
-rw-r--r--js/src/session/session.ts2
-rw-r--r--js/src/share/share.ts2
-rw-r--r--js/src/storage/storage.ts2
-rw-r--r--js/src/tool/edit.ts3
-rw-r--r--js/src/tool/glob.ts2
-rw-r--r--js/src/tool/grep.ts2
-rw-r--r--js/src/tool/ls.ts2
-rw-r--r--js/src/tool/lsp-diagnostics.ts2
-rw-r--r--js/src/tool/lsp-hover.ts2
-rw-r--r--js/src/tool/util/file-times.ts2
-rw-r--r--js/test/tool/tool.test.ts2
-rw-r--r--pkg/client/gen/openapi.json8
-rw-r--r--pkg/client/generated-client.go20
28 files changed, 76 insertions, 230 deletions
diff --git a/js/example/broken.ts b/js/example/broken.ts
deleted file mode 100644
index e073ad008..000000000
--- a/js/example/broken.ts
+++ /dev/null
@@ -1 +0,0 @@
-export const x: number = "asd";
diff --git a/js/example/cli.ts b/js/example/cli.ts
deleted file mode 100644
index 9c9e07edd..000000000
--- a/js/example/cli.ts
+++ /dev/null
@@ -1,21 +0,0 @@
-import { App } from "../src/app";
-import path from "path";
-import { edit } from "../src/tool";
-import { FileTimes } from "../src/tool/util/file-times";
-
-await App.provide({ directory: process.cwd() }, async () => {
- const file = path.join(process.cwd(), "example/broken.ts");
- FileTimes.read(file);
- const tool = await edit.execute(
- {
- file_path: file,
- old_string: "x:",
- new_string: "x:",
- },
- {
- toolCallId: "test",
- messages: [],
- },
- );
- console.log(tool.output);
-});
diff --git a/js/example/ink.tsx b/js/example/ink.tsx
deleted file mode 100644
index 5eaab4d3b..000000000
--- a/js/example/ink.tsx
+++ /dev/null
@@ -1,122 +0,0 @@
-import React, { useEffect, useState } from "react";
-import type { Server } from "../src/server/server";
-import type { Session } from "../src/session/session";
-import { hc } from "hono/client";
-import { createInterface, Interface } from "readline";
-
-const client = hc<Server.App>(`http://localhost:16713`);
-
-
-const session = await client.session_create.$post().then((res) => res.json());
-
-const initial: {
- session: {
- info: {
- [sessionID: string]: Session.Info;
- };
- message: {
- [sessionID: string]: {
- [messageID: string]: Session.Message;
- };
- };
- };
-} = {
- session: {
- info: {
- [session.id]: session
- },
- message: {
- [session.id]: {}
- },
- },
-};
-
-import { render, Text, Newline, useStdout, Box } from "ink";
-import TextInput from "ink-text-input"
-
-function App() {
- const [state, setState] = useState(initial)
- const [input, setInput] = useState("")
-
- useEffect(() => {
- fetch("http://localhost:16713/event")
- .then(stream => {
- const decoder = new TextDecoder();
- stream.body!.pipeTo(
- new WritableStream({
- write(chunk) {
- const data = decoder.decode(chunk);
- if (data.startsWith("data: ")) {
- try {
- const event = JSON.parse(data.substring(6));
- switch (event.type) {
- case "storage.write":
- const splits: string[] = event.properties.key.split("/");
- let item = state as any;
- for (let i = 0; i < splits.length; i++) {
- const part = splits[i];
- if (i === splits.length - 1) {
- item[part] = event.properties.body;
- continue;
- }
- if (!item[part]) item[part] = {};
- item = item[part];
- }
- }
- setState({ ...state })
- } catch {
- }
- }
- },
- }),
- )
- });
- }, [])
-
-
- return (
- <>
- <Text>{session.title}</Text>
- {
- Object.values(state.session.message[session.id])
- .filter(message => message.role !== "system")
- .map(message => {
- return Object.values(message.parts)
- .map((part, index) => {
- if (part.type === "text") {
- return <Text key={`${message.id}-${index}`}>{message.role}: {part.text}</Text>
- }
- if (part.type === "tool-invocation") {
- return <Text key={`${message.id}-${index}`}>{message.role}: {part.toolInvocation.toolName} {JSON.stringify(part.toolInvocation.args)}</Text>
- }
- })
- })
- }
- <Box gap={1} >
- <Text>Input:</Text>
- <TextInput
- value={input}
- onChange={setInput}
- onSubmit={() => {
- setInput("")
- client.session_chat.$post({
- json: {
- sessionID: session.id,
- parts: [
- {
- type: "text",
- text: input,
- },
- ],
- }
- })
- }}
- />
- </Box>
- </>
- );
-};
-
-console.clear();
-render(<App />);
-
diff --git a/js/src/app/index.ts b/js/src/app/app.ts
index 0c6260bc7..0c6260bc7 100644
--- a/js/src/app/index.ts
+++ b/js/src/app/app.ts
diff --git a/js/src/bus/index.ts b/js/src/bus/index.ts
index cf5101b67..342d82b6d 100644
--- a/js/src/bus/index.ts
+++ b/js/src/bus/index.ts
@@ -1,5 +1,5 @@
import { z, type ZodType } from "zod";
-import { App } from "../app";
+import { App } from "../app/app";
import { Log } from "../util/log";
export namespace Bus {
diff --git a/js/src/app/config.ts b/js/src/config/config.ts
index e68b24bb9..76181b792 100644
--- a/js/src/app/config.ts
+++ b/js/src/config/config.ts
@@ -1,7 +1,8 @@
import path from "path";
import { Log } from "../util/log";
import { z } from "zod";
-import { App } from ".";
+import { App } from "../app/app";
+import { Provider } from "../provider/provider";
export namespace Config {
const log = Log.create({ service: "config" });
@@ -11,38 +12,9 @@ export namespace Config {
return result;
});
- export const Model = z
- .object({
- name: z.string().optional(),
- cost: z.object({
- input: z.number(),
- inputCached: z.number(),
- output: z.number(),
- outputCached: z.number(),
- }),
- contextWindow: z.number(),
- maxTokens: z.number().optional(),
- attachment: z.boolean(),
- reasoning: z.boolean().optional(),
- })
- .openapi({
- ref: "model",
- });
- export type Model = z.output<typeof Model>;
-
- export const Provider = z
- .object({
- options: z.record(z.string(), z.any()).optional(),
- models: z.record(z.string(), Model),
- })
- .openapi({
- ref: "provider",
- });
- export type Provider = z.output<typeof Provider>;
-
export const Info = z
.object({
- providers: z.record(z.string(), Provider).optional(),
+ providers: z.record(z.string(), Provider.Info).optional(),
})
.strict();
diff --git a/js/src/index.ts b/js/src/index.ts
index ddea15e91..1f6c7ae26 100644
--- a/js/src/index.ts
+++ b/js/src/index.ts
@@ -1,5 +1,5 @@
import "zod-openapi/extend";
-import { App } from "./app";
+import { App } from "./app/app";
import { Server } from "./server/server";
import fs from "fs/promises";
import path from "path";
diff --git a/js/src/llm/llm.ts b/js/src/llm/llm.ts
index e6230584a..990c30069 100644
--- a/js/src/llm/llm.ts
+++ b/js/src/llm/llm.ts
@@ -1,11 +1,12 @@
-import { App } from "../app";
+import { App } from "../app/app";
import { Log } from "../util/log";
import { mergeDeep } from "remeda";
import path from "path";
+import { Provider } from "../provider/provider";
-import type { LanguageModel, Provider } from "ai";
+import type { LanguageModel, Provider as ProviderInstance } from "ai";
import { NoSuchModelError } from "ai";
-import { Config } from "../app/config";
+import { Config } from "../config/config";
import { BunProc } from "../bun";
import { Global } from "../global";
@@ -18,7 +19,7 @@ export namespace LLM {
}
}
- const NATIVE_PROVIDERS: Record<string, Config.Provider> = {
+ const NATIVE_PROVIDERS: Record<string, Provider.Info> = {
anthropic: {
models: {
"claude-sonnet-4-20250514": {
@@ -76,18 +77,18 @@ export namespace LLM {
google: ["GOOGLE_GENERATIVE_AI_API_KEY"],
};
- const state = App.state("llm", async (app) => {
+ const state = App.state("llm", async () => {
const config = await Config.get();
const providers: Record<
string,
{
- info: Config.Provider;
- instance: Provider;
+ info: Provider.Info;
+ instance: ProviderInstance;
}
> = {};
const models = new Map<
string,
- { info: Config.Model; instance: LanguageModel }
+ { info: Provider.Model; instance: LanguageModel }
>();
const list = mergeDeep(NATIVE_PROVIDERS, config.providers ?? {});
diff --git a/js/src/llm/models/anthropic.ts b/js/src/llm/models/anthropic.ts
deleted file mode 100644
index e69de29bb..000000000
--- a/js/src/llm/models/anthropic.ts
+++ /dev/null
diff --git a/js/src/llm/models/index.ts b/js/src/llm/models/index.ts
deleted file mode 100644
index f974b4d3e..000000000
--- a/js/src/llm/models/index.ts
+++ /dev/null
@@ -1 +0,0 @@
-export * as anthropic from "./anthropic";
diff --git a/js/src/llm/models/model.ts b/js/src/llm/models/model.ts
deleted file mode 100644
index e78dbb87f..000000000
--- a/js/src/llm/models/model.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-export interface ModelInfo {
- cost: {
- input: number;
- inputCached: number;
- output: number;
- outputCached: number;
- };
- contextWindow: number;
- maxTokens: number;
- attachment: boolean;
-}
diff --git a/js/src/lsp/client.ts b/js/src/lsp/client.ts
index cb8bdad2d..82caa82a2 100644
--- a/js/src/lsp/client.ts
+++ b/js/src/lsp/client.ts
@@ -6,7 +6,7 @@ import {
StreamMessageWriter,
} from "vscode-jsonrpc/node";
import type { Diagnostic as VSCodeDiagnostic } from "vscode-languageserver-types";
-import { App } from "../app";
+import { App } from "../app/app";
import { Log } from "../util/log";
import { LANGUAGE_EXTENSIONS } from "./language";
import { Bus } from "../bus";
@@ -31,7 +31,6 @@ export namespace LSPClient {
export async function create(input: { cmd: string[]; serverID: string }) {
log.info("starting client", input);
- let version = 0;
const app = await App.use();
const [command, ...args] = input.cmd;
diff --git a/js/src/lsp/index.ts b/js/src/lsp/index.ts
index ee5a8b2d7..e3344a934 100644
--- a/js/src/lsp/index.ts
+++ b/js/src/lsp/index.ts
@@ -1,4 +1,4 @@
-import { App } from "../app";
+import { App } from "../app/app";
import { Log } from "../util/log";
import { LSPClient } from "./client";
import path from "path";
@@ -9,6 +9,7 @@ export namespace LSP {
const state = App.state(
"lsp",
async () => {
+ log.info("initializing");
const clients = new Map<string, LSPClient.Info>();
return {
diff --git a/js/src/provider/provider.ts b/js/src/provider/provider.ts
new file mode 100644
index 000000000..44482b6db
--- /dev/null
+++ b/js/src/provider/provider.ts
@@ -0,0 +1,32 @@
+import z from "zod";
+
+export namespace Provider {
+ export const Model = z
+ .object({
+ name: z.string().optional(),
+ cost: z.object({
+ input: z.number(),
+ inputCached: z.number(),
+ output: z.number(),
+ outputCached: z.number(),
+ }),
+ contextWindow: z.number(),
+ maxTokens: z.number().optional(),
+ attachment: z.boolean(),
+ reasoning: z.boolean().optional(),
+ })
+ .openapi({
+ ref: "Provider.Model",
+ });
+ export type Model = z.output<typeof Model>;
+
+ export const Info = z
+ .object({
+ options: z.record(z.string(), z.any()).optional(),
+ models: z.record(z.string(), Model),
+ })
+ .openapi({
+ ref: "Provider.Info",
+ });
+ export type Info = z.output<typeof Info>;
+}
diff --git a/js/src/server/server.ts b/js/src/server/server.ts
index ff2d0924b..5bf8d9f54 100644
--- a/js/src/server/server.ts
+++ b/js/src/server/server.ts
@@ -6,9 +6,9 @@ import { streamSSE } from "hono/streaming";
import { Session } from "../session/session";
import { resolver, validator as zValidator } from "hono-openapi/zod";
import { z } from "zod";
-import { Config } from "../app/config";
import { LLM } from "../llm/llm";
import { Message } from "../session/message";
+import { Provider } from "../provider/provider";
export namespace Server {
const log = Log.create({ service: "server" });
@@ -234,7 +234,7 @@ export namespace Server {
description: "List of providers",
content: {
"application/json": {
- schema: resolver(z.record(z.string(), Config.Provider)),
+ schema: resolver(z.record(z.string(), Provider.Info)),
},
},
},
@@ -242,7 +242,7 @@ export namespace Server {
}),
async (c) => {
const providers = await LLM.providers();
- const result: Record<string, Config.Provider> = {};
+ const result: Record<string, Provider.Info> = {};
for (const [providerID, provider] of Object.entries(providers)) {
result[providerID] = provider.info;
}
diff --git a/js/src/session/session.ts b/js/src/session/session.ts
index 5e07764b8..f6b50a0bf 100644
--- a/js/src/session/session.ts
+++ b/js/src/session/session.ts
@@ -1,5 +1,5 @@
import path from "path";
-import { App } from "../app/";
+import { App } from "../app/app";
import { Identifier } from "../id/id";
import { LLM } from "../llm/llm";
import { Storage } from "../storage/storage";
diff --git a/js/src/share/share.ts b/js/src/share/share.ts
index e77f692f4..62dee63a7 100644
--- a/js/src/share/share.ts
+++ b/js/src/share/share.ts
@@ -1,4 +1,4 @@
-import { App } from "../app";
+import { App } from "../app/app";
import { Bus } from "../bus";
import { Session } from "../session/session";
import { Storage } from "../storage/storage";
diff --git a/js/src/storage/storage.ts b/js/src/storage/storage.ts
index 85fa26be6..983b7e0f9 100644
--- a/js/src/storage/storage.ts
+++ b/js/src/storage/storage.ts
@@ -2,7 +2,7 @@ import { FileStorage } from "@flystorage/file-storage";
import { LocalStorageAdapter } from "@flystorage/local-fs";
import fs from "fs/promises";
import { Log } from "../util/log";
-import { App } from "../app";
+import { App } from "../app/app";
import { AppPath } from "../app/path";
import { Bus } from "../bus";
import z from "zod";
diff --git a/js/src/tool/edit.ts b/js/src/tool/edit.ts
index 3f784d616..41ff60855 100644
--- a/js/src/tool/edit.ts
+++ b/js/src/tool/edit.ts
@@ -1,12 +1,9 @@
import { z } from "zod";
import * as path from "path";
-import { Log } from "../util/log";
import { Tool } from "./tool";
import { FileTimes } from "./util/file-times";
import { LSP } from "../lsp";
-const log = Log.create({ service: "tool.edit" });
-
const DESCRIPTION = `Edits files by replacing text, creating new files, or deleting content. For moving or renaming files, use the Bash tool with the 'mv' command instead. For larger file edits, use the FileWrite tool to overwrite files.
Before using this tool:
diff --git a/js/src/tool/glob.ts b/js/src/tool/glob.ts
index 5f1952b78..f52c3f5d0 100644
--- a/js/src/tool/glob.ts
+++ b/js/src/tool/glob.ts
@@ -1,6 +1,6 @@
import { z } from "zod";
import { Tool } from "./tool";
-import { App } from "../app";
+import { App } from "../app/app";
const DESCRIPTION = `Fast file pattern matching tool that finds files by name and pattern, returning matching paths sorted by modification time (newest first).
diff --git a/js/src/tool/grep.ts b/js/src/tool/grep.ts
index d5c2d700c..0c5848074 100644
--- a/js/src/tool/grep.ts
+++ b/js/src/tool/grep.ts
@@ -1,6 +1,6 @@
import { z } from "zod";
import { Tool } from "./tool";
-import { App } from "../app";
+import { App } from "../app/app";
import { spawn } from "child_process";
import { promises as fs } from "fs";
import path from "path";
diff --git a/js/src/tool/ls.ts b/js/src/tool/ls.ts
index 62c3d113b..5954355a3 100644
--- a/js/src/tool/ls.ts
+++ b/js/src/tool/ls.ts
@@ -1,6 +1,6 @@
import { z } from "zod";
import { Tool } from "./tool";
-import { App } from "../app";
+import { App } from "../app/app";
import * as path from "path";
import * as fs from "fs";
diff --git a/js/src/tool/lsp-diagnostics.ts b/js/src/tool/lsp-diagnostics.ts
index c1372b0e9..ecd54c1a7 100644
--- a/js/src/tool/lsp-diagnostics.ts
+++ b/js/src/tool/lsp-diagnostics.ts
@@ -2,7 +2,7 @@ import { z } from "zod";
import { Tool } from "./tool";
import path from "path";
import { LSP } from "../lsp";
-import { App } from "../app";
+import { App } from "../app/app";
export const LspDiagnosticTool = Tool.define({
name: "diagnostics",
diff --git a/js/src/tool/lsp-hover.ts b/js/src/tool/lsp-hover.ts
index 9b6290ef5..4ffa90a75 100644
--- a/js/src/tool/lsp-hover.ts
+++ b/js/src/tool/lsp-hover.ts
@@ -2,7 +2,7 @@ import { z } from "zod";
import { Tool } from "./tool";
import path from "path";
import { LSP } from "../lsp";
-import { App } from "../app";
+import { App } from "../app/app";
export const LspHoverTool = Tool.define({
name: "lsp.hover",
diff --git a/js/src/tool/util/file-times.ts b/js/src/tool/util/file-times.ts
index aab562dd4..8d36d007d 100644
--- a/js/src/tool/util/file-times.ts
+++ b/js/src/tool/util/file-times.ts
@@ -1,4 +1,4 @@
-import { App } from "../../app";
+import { App } from "../../app/app";
export namespace FileTimes {
export const state = App.state("tool.filetimes", () => ({
diff --git a/js/test/tool/tool.test.ts b/js/test/tool/tool.test.ts
index a8a621dc6..4b6d2efd3 100644
--- a/js/test/tool/tool.test.ts
+++ b/js/test/tool/tool.test.ts
@@ -1,5 +1,5 @@
import { describe, expect, test } from "bun:test";
-import { App } from "../../src/app";
+import { App } from "../../src/app/app";
import { glob } from "../../src/tool/glob";
import { ls } from "../../src/tool/ls";
diff --git a/pkg/client/gen/openapi.json b/pkg/client/gen/openapi.json
index 4e6506e73..0b481d209 100644
--- a/pkg/client/gen/openapi.json
+++ b/pkg/client/gen/openapi.json
@@ -238,7 +238,7 @@
"schema": {
"type": "object",
"additionalProperties": {
- "$ref": "#/components/schemas/provider"
+ "$ref": "#/components/schemas/Provider.Info"
}
}
}
@@ -740,7 +740,7 @@
"title"
]
},
- "provider": {
+ "Provider.Info": {
"type": "object",
"properties": {
"options": {
@@ -750,7 +750,7 @@
"models": {
"type": "object",
"additionalProperties": {
- "$ref": "#/components/schemas/model"
+ "$ref": "#/components/schemas/Provider.Model"
}
}
},
@@ -758,7 +758,7 @@
"models"
]
},
- "model": {
+ "Provider.Model": {
"type": "object",
"properties": {
"name": {
diff --git a/pkg/client/generated-client.go b/pkg/client/generated-client.go
index 0fce536e7..9cbb91944 100644
--- a/pkg/client/generated-client.go
+++ b/pkg/client/generated-client.go
@@ -170,8 +170,14 @@ type MessageToolInvocationToolResult struct {
ToolName string `json:"toolName"`
}
-// Model defines model for model.
-type Model struct {
+// ProviderInfo defines model for Provider.Info.
+type ProviderInfo struct {
+ Models map[string]ProviderModel `json:"models"`
+ Options *map[string]interface{} `json:"options,omitempty"`
+}
+
+// ProviderModel defines model for Provider.Model.
+type ProviderModel struct {
Attachment bool `json:"attachment"`
ContextWindow float32 `json:"contextWindow"`
Cost struct {
@@ -185,12 +191,6 @@ type Model struct {
Reasoning *bool `json:"reasoning,omitempty"`
}
-// Provider defines model for provider.
-type Provider struct {
- Models map[string]Model `json:"models"`
- Options *map[string]interface{} `json:"options,omitempty"`
-}
-
// SessionInfo defines model for session.info.
type SessionInfo struct {
Id string `json:"id"`
@@ -1329,7 +1329,7 @@ func (r GetEventResponse) StatusCode() int {
type PostProviderListResponse struct {
Body []byte
HTTPResponse *http.Response
- JSON200 *map[string]Provider
+ JSON200 *map[string]ProviderInfo
}
// Status returns HTTPResponse.Status
@@ -1625,7 +1625,7 @@ func ParsePostProviderListResponse(rsp *http.Response) (*PostProviderListRespons
switch {
case strings.Contains(rsp.Header.Get("Content-Type"), "json") && rsp.StatusCode == 200:
- var dest map[string]Provider
+ var dest map[string]ProviderInfo
if err := json.Unmarshal(bodyBytes, &dest); err != nil {
return nil, err
}