Skip to content

Scope

Scope.extend has been renamed to Scope.provide in v4. The behavior is identical: it provides a Scope to an effect that requires one, removing Scope from the effect’s requirements without closing the scope when the effect completes.

The new name better reflects the operation — you are providing a service (the Scope) to an effect, consistent with how other services are provided in Effect.

v3

import { Effect, Scope } from "effect"
const program = Effect.gen(function*() {
const scope = yield* Scope.make()
yield* Scope.extend(myEffect, scope)
})

v4

import { Effect, Scope } from "effect"
const program = Effect.gen(function*() {
const scope = yield* Scope.make()
yield* Scope.provide(scope)(myEffect)
})

Both data-first and data-last (curried) forms are supported:

// data-first
Scope.provide(myEffect, scope)
// data-last (curried)
myEffect.pipe(Scope.provide(scope))
v3 v4
Scope.extend Scope.provide