From 074ac3919edef8b48e6b2f1089a4c02f58deac84 Mon Sep 17 00:00:00 2001 From: Flavio Brasil Date: Sun, 17 Sep 2023 16:43:21 -0700 Subject: [PATCH] minor --- README.md | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index b83ed1cce..bcde4e771 100644 --- a/README.md +++ b/README.md @@ -9,7 +9,7 @@ Kyo is a complete toolkit for Scala development, spanning from browser-based apps in ScalaJS to high-performance backends on the JVM. It introduces a novel approach, based on algebraic effects, to deliver straightforward APIs in the pure Functional Programming paradigm. Unlike similar solutions, Kyo achieves this without inundating developers with esoteric concepts from Category Theory or using cryptic symbolic operators, resulting in a development experience that is both intuitive and robust. -Drawing inspiration from ZIO's effect rotation, Kyo takes a more generalized approach. While ZIO restricts effects to two channels, dependency injection and short-circuiting, Kyo allows for an arbitrary number of effectful channels. This enhancement gives developers greater flexibility in effect management, while also simplifying Kyo's internal codebase through more principled design patterns. +Drawing inspiration from [ZIO](https://zio.dev/)'s [effect rotation](https://degoes.net/articles/rotating-effects), Kyo takes a more generalized approach. While ZIO restricts effects to two channels, dependency injection and short-circuiting, Kyo allows for an arbitrary number of effectful channels. This enhancement gives developers greater flexibility in effect management, while also simplifying Kyo's internal codebase through more principled design patterns. ## The `>` type @@ -129,7 +129,7 @@ val a: Int > Options = Options.get(Some(1)) ``` -Effect handling is done using the `run` method. Though it's named `run`, the operation doesn't necessarily execute the computation immediately, as the effect handling can also be suspended if another effect is pending. +Effect handling is done using the `run*` methods. Though named `run`, the operation doesn't necessarily execute the computation immediately, as the effect handling can also be suspended if another effect is pending. ```scala // Handle the 'Options' effect @@ -249,10 +249,10 @@ In some specific cases where Kyo isn't used as the main effect system of an appl val a: Int > IOs = IOs(42) -// ** Avoid 'IOs.run' this, use 'kyo.App' instead) ** +// ** Avoid 'IOs.run', use 'kyo.App' instead) ** val b: Int = IOs.run(a).pure -// ** Avoid 'IOs.run' this, use 'kyo.App' instead) ** +// ** Avoid 'IOs.run', use 'kyo.App' instead) ** ``` The `runLazy` method accepts computations with other effects but it doesn't guarantee that all side effects are performed before the method returns. If other effects still have to be handled, the side effects can be executed later once the other effects are handled. This a low-level API that must be used with caution. @@ -268,14 +268,14 @@ val a: Int > (Options with IOs) = } } -// ** Avoid 'IOs.runLazy' this, use 'kyo.App' instead) ** +// ** Avoid 'IOs.runLazy', use 'kyo.App' instead) ** // Handle the 'IOs' effect lazily val b: Int > Options = IOs.runLazy(a) -// ** Avoid 'IOs.runLazy' this, use 'kyo.App' instead) ** +// ** Avoid 'IOs.runLazy', use 'kyo.App' instead) ** // Since the computation is suspended with the -// 'Options' effect first, the lazy IOs execution +// 'Options' effect first, the lazy 'IOs' execution // will be triggered once 'Options' is handled val c: Option[Int] = Options.run(b).pure @@ -285,7 +285,7 @@ val c: Option[Int] = ### Envs: Dependency Injection -The `Envs` effect is similar to ZIO's environment mechanism but offers more flexible scoping as values can be provided individually. `Envs` doesn't provide a solution like ZIO's layers, though. The user is responsible for initializing environment values like services for example, in parallel. +`Envs` is similar to ZIO's environment feature but offers more granular control. Unlike ZIO, which has built-in layering for dependencies, Envs allows you to inject individual services directly. However, it lacks ZIO's structured dependency management; you manage and initialize your services yourself. ```scala import kyo.envs._ @@ -406,7 +406,7 @@ val b: Int > IOs = Resources.run(a) ``` -### Choices: Decision Making and Exploration +### Choices: Exploratory Branching The `Choices` effect is designed to aid in handling and exploring multiple options, pathways, or outcomes in a computation. This effect is particularly useful in scenarios where you're dealing with decision trees, backtracking algorithms, or any situation that involves dynamically exploring multiple options. @@ -442,7 +442,7 @@ The Choices effect becomes exceptionally powerful when combined with other effec ### Aspects: Aspect-Oriented Programming (AOP) -The `Aspects` effect provides a mechanism for users to customize the behavior of a computation from an indirect scope. Aspects in Kyo are expressed as first-class values, which enables flexible scoping. For example, users may instantiate aspects and reduce their visibility via regular field modifiers. +The `Aspects` effect in Kyo allows for high-level customization of behavior across your application. This is similar to how some frameworks use aspects for centralized control over diverse functionalities like database timeouts, authentication, authorization, and transaction management. You can modify these core operations without altering their individual codebases, streamlining how centralized logic is applied across different parts of an application. This makes `Aspects` ideal for implementing cross-cutting concerns in a clean and efficient manner. To instantiate an aspect, use the `Aspects.init` method. It takes three type parameters: @@ -882,6 +882,10 @@ val b: Boolean > IOs = > A `Promise` is basically a `Fiber` with all the regular functionality plus the `complete` method to manually fulfill the promise. +### Channels: Asynchronous Communication + + + License -------