feat: unwrap BusEvent namespace to flat exports + barrel

This commit is contained in:
Kit Langton
2026-04-16 07:29:31 -04:00
parent 7341718f92
commit c454c4acc5
32 changed files with 55 additions and 56 deletions

View File

@@ -1,33 +1,31 @@
import z from "zod"
import type { ZodType } from "zod"
export namespace BusEvent {
export type Definition = ReturnType<typeof define>
export type Definition = ReturnType<typeof define>
const registry = new Map<string, Definition>()
const registry = new Map<string, Definition>()
export function define<Type extends string, Properties extends ZodType>(type: Type, properties: Properties) {
const result = {
type,
properties,
}
registry.set(type, result)
return result
}
export function payloads() {
return registry
.entries()
.map(([type, def]) => {
return z
.object({
type: z.literal(type),
properties: def.properties,
})
.meta({
ref: `Event.${def.type}`,
})
})
.toArray()
export function define<Type extends string, Properties extends ZodType>(type: Type, properties: Properties) {
const result = {
type,
properties,
}
registry.set(type, result)
return result
}
export function payloads() {
return registry
.entries()
.map(([type, def]) => {
return z
.object({
type: z.literal(type),
properties: def.properties,
})
.meta({
ref: `Event.${def.type}`,
})
})
.toArray()
}

View File

@@ -2,7 +2,7 @@ import z from "zod"
import { Effect, Exit, Layer, PubSub, Scope, Context, Stream } from "effect"
import { EffectBridge } from "@/effect"
import { Log } from "../util"
import { BusEvent } from "./bus-event"
import * as BusEvent from "./bus-event"
import { GlobalBus } from "./global"
import { InstanceState } from "@/effect"
import { makeRuntime } from "@/effect/run-service"

View File

@@ -1 +1,2 @@
export * as Bus from "./bus"
export * as BusEvent from "./bus-event"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { SessionID } from "@/session/schema"
import z from "zod"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { InstanceState } from "@/effect"
import { EffectBridge } from "@/effect"
import type { InstanceContext } from "@/project/instance"

View File

@@ -3,7 +3,7 @@ import { setTimeout as sleep } from "node:timers/promises"
import { fn } from "@/util/fn"
import { Database, asc, eq, inArray } from "@/storage"
import { Project } from "@/project"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { GlobalBus } from "@/bus/global"
import { SyncEvent } from "@/sync"
import { EventTable } from "@/sync/event.sql"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { InstanceState } from "@/effect"
import { AppFileSystem } from "@opencode-ai/shared/filesystem"

View File

@@ -6,7 +6,7 @@ import { readdir } from "fs/promises"
import path from "path"
import z from "zod"
import { Bus } from "@/bus"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { InstanceState } from "@/effect"
import { Flag } from "@/flag/flag"
import { Git } from "@/git"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import z from "zod"
import { NamedError } from "@opencode-ai/shared/util/error"
import { Log } from "../util"

View File

@@ -5,7 +5,7 @@ import { withTransientReadRetry } from "@/util/effect-http-client"
import { ChildProcess, ChildProcessSpawner } from "effect/unstable/process"
import path from "path"
import z from "zod"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Flag } from "../flag/flag"
import { Log } from "../util"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import path from "path"
import { pathToFileURL, fileURLToPath } from "url"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import { Log } from "../util"
import * as LSPClient from "./client"

View File

@@ -21,7 +21,7 @@ import { AppFileSystem } from "@opencode-ai/shared/filesystem"
import { McpOAuthProvider } from "./oauth-provider"
import { McpOAuthCallback } from "./oauth-callback"
import { McpAuth } from "./auth"
import { BusEvent } from "../bus/bus-event"
import { BusEvent } from "../bus"
import { Bus } from "@/bus"
import { TuiEvent } from "@/cli/cmd/tui/event"
import open from "open"

View File

@@ -1,5 +1,5 @@
import { Bus } from "@/bus"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Config } from "@/config"
import { InstanceState } from "@/effect"
import { ProjectID } from "@/project/schema"

View File

@@ -4,7 +4,7 @@ import { ProjectTable } from "./project.sql"
import { SessionTable } from "../session/session.sql"
import { Log } from "../util"
import { Flag } from "@/flag/flag"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { GlobalBus } from "@/bus/global"
import { which } from "../util/which"
import { ProjectID } from "./schema"

View File

@@ -2,7 +2,7 @@ import { Effect, Layer, Context, Stream, Scope } from "effect"
import { formatPatch, structuredPatch } from "diff"
import path from "path"
import { Bus } from "@/bus"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { InstanceState } from "@/effect"
import { AppFileSystem } from "@opencode-ai/shared/filesystem"
import { FileWatcher } from "@/file/watcher"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import { InstanceState } from "@/effect"
import { Instance } from "@/project/instance"

View File

@@ -1,6 +1,6 @@
import { Deferred, Effect, Layer, Schema, Context } from "effect"
import { Bus } from "@/bus"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { InstanceState } from "@/effect"
import { SessionID, MessageID } from "@/session/schema"
import { zod } from "@/util/effect-zod"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import z from "zod"
export const Event = {

View File

@@ -3,7 +3,7 @@ import { Hono } from "hono"
import { describeRoute, resolver } from "hono-openapi"
import { streamSSE } from "hono/streaming"
import { Log } from "@/util"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import { AsyncQueue } from "../../util/queue"

View File

@@ -3,7 +3,7 @@ import { describeRoute, resolver, validator } from "hono-openapi"
import { streamSSE } from "hono/streaming"
import { Effect } from "effect"
import z from "zod"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { SyncEvent } from "@/sync"
import { GlobalBus } from "@/bus/global"
import { AppRuntime } from "@/effect/app-runtime"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import * as Session from "./session"
import { SessionID, MessageID, PartID } from "./schema"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { SessionID, MessageID, PartID } from "./schema"
import z from "zod"
import { NamedError } from "@opencode-ai/shared/util/error"

View File

@@ -1,6 +1,6 @@
import { Slug } from "@opencode-ai/shared/util/slug"
import path from "path"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import { Decimal } from "decimal.js"
import z from "zod"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import { InstanceState } from "@/effect"
import { SessionID } from "./schema"

View File

@@ -1,4 +1,4 @@
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Bus } from "@/bus"
import { SessionID } from "./schema"
import { Effect, Layer, Context } from "effect"

View File

@@ -3,7 +3,7 @@ import type { ZodObject } from "zod"
import { Database, eq } from "@/storage"
import { GlobalBus } from "@/bus/global"
import { Bus as ProjectBus } from "@/bus"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { Instance } from "@/project/instance"
import { EventSequenceTable, EventTable } from "./event.sql"
import { WorkspaceContext } from "@/control-plane/workspace-context"

View File

@@ -10,7 +10,7 @@ import type { ProjectID } from "../project/schema"
import { Log } from "../util"
import { Slug } from "@opencode-ai/shared/util/slug"
import { errorMessage } from "../util/error"
import { BusEvent } from "@/bus/bus-event"
import { BusEvent } from "@/bus"
import { GlobalBus } from "@/bus/global"
import { Git } from "@/git"
import { Effect, Layer, Path, Scope, Context, Stream } from "effect"

View File

@@ -2,7 +2,7 @@ import { describe, expect } from "bun:test"
import { Deferred, Effect, Layer, Stream } from "effect"
import z from "zod"
import { Bus } from "../../src/bus"
import { BusEvent } from "../../src/bus/bus-event"
import { BusEvent } from "../../src/bus"
import { Instance } from "../../src/project/instance"
import * as CrossSpawnSpawner from "../../src/effect/cross-spawn-spawner"
import { provideInstance, provideTmpdirInstance, tmpdirScoped } from "../fixture/fixture"

View File

@@ -1,7 +1,7 @@
import { afterEach, describe, expect, test } from "bun:test"
import z from "zod"
import { Bus } from "../../src/bus"
import { BusEvent } from "../../src/bus/bus-event"
import { BusEvent } from "../../src/bus"
import { Instance } from "../../src/project/instance"
import { tmpdir } from "../fixture/fixture"

View File

@@ -1,7 +1,7 @@
import { afterEach, describe, expect, test } from "bun:test"
import z from "zod"
import { Bus } from "../../src/bus"
import { BusEvent } from "../../src/bus/bus-event"
import { BusEvent } from "../../src/bus"
import { Instance } from "../../src/project/instance"
import { tmpdir } from "../fixture/fixture"

View File

@@ -11,7 +11,7 @@ import { AppFileSystem } from "@opencode-ai/shared/filesystem"
import { Format } from "../../src/format"
import { Agent } from "../../src/agent/agent"
import { Bus } from "../../src/bus"
import { BusEvent } from "../../src/bus/bus-event"
import { BusEvent } from "../../src/bus"
import { Truncate } from "../../src/tool"
import { SessionID, MessageID } from "../../src/session/schema"