mirror of
https://github.com/anomalyco/opencode.git
synced 2026-04-23 22:34:53 +00:00
address feedback
This commit is contained in:
@@ -51,19 +51,20 @@ import * as Effect from "effect/Effect"
|
||||
|
||||
// Adjusts the default Config layer to ensure that plugins are always initialised before
|
||||
// any other layers read the current config
|
||||
const ConfigWithPluginPriority = Layer.unwrap(
|
||||
const ConfigWithPluginPriority = Layer.effect(
|
||||
Config.Service,
|
||||
Effect.gen(function* () {
|
||||
const configSvc = yield* Config.Service
|
||||
const pluginSvc = yield* Plugin.Service
|
||||
const config = yield* Config.Service
|
||||
const plugin = yield* Plugin.Service
|
||||
|
||||
return Layer.succeed(Config.Service, {
|
||||
...configSvc,
|
||||
get: () => Effect.andThen(pluginSvc.init(), configSvc.get),
|
||||
getGlobal: () => Effect.andThen(pluginSvc.init(), configSvc.getGlobal),
|
||||
getConsoleState: () => Effect.andThen(pluginSvc.init(), configSvc.getConsoleState),
|
||||
})
|
||||
return {
|
||||
...config,
|
||||
get: () => Effect.andThen(plugin.init(), config.get),
|
||||
getGlobal: () => Effect.andThen(plugin.init(), config.getGlobal),
|
||||
getConsoleState: () => Effect.andThen(plugin.init(), config.getConsoleState),
|
||||
}
|
||||
}),
|
||||
).pipe(Layer.provideMerge(Layer.merge(Plugin.defaultLayer, Config.defaultLayer)))
|
||||
).pipe(Layer.provide(Layer.merge(Plugin.defaultLayer, Config.defaultLayer)))
|
||||
|
||||
export const AppLayer = Layer.mergeAll(
|
||||
AppFileSystem.defaultLayer,
|
||||
|
||||
Reference in New Issue
Block a user