From 077e52aadff7f71e4081fcad97f5689870a7eace Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Wed, 27 Sep 2023 17:16:04 -0700 Subject: [PATCH 1/2] Update versions for 3.5.2 --- README.md | 14 +++++++------- docs/core/native-image.md | 2 +- docs/core/scala-native.md | 2 +- docs/core/test-runtime.md | 2 +- docs/getting-started.md | 2 +- docs/migration-guide.md | 8 ++++---- docs/tutorial.md | 4 ++-- 7 files changed, 17 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index b167aa2390..785f456725 100644 --- a/README.md +++ b/README.md @@ -11,11 +11,11 @@ ## Getting Started -- Wired: **3.5.1** +- Wired: **3.5.2** - Tired: **2.5.5** (end of life) ```scala -libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.1" +libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.2" ``` The above represents the core, stable dependency which brings in the entirety of Cats Effect. This is *most likely* what you want. All current Cats Effect releases are published for Scala 2.12, 2.13, 3.0, and Scala.js 1.7. @@ -30,22 +30,22 @@ Depending on your use-case, you may want to consider one of the several other mo ```scala libraryDependencies ++= Seq( - "org.typelevel" %% "cats-effect-kernel" % "3.5.1", - "org.typelevel" %% "cats-effect-laws" % "3.5.1" % Test) + "org.typelevel" %% "cats-effect-kernel" % "3.5.2", + "org.typelevel" %% "cats-effect-laws" % "3.5.2" % Test) ``` If you're a middleware framework (like [Fs2](https://fs2.io/)), you probably want to depend on **std**, which gives you access to `Queue`, `Semaphore`, and much more without introducing a hard-dependency on `IO` outside of your tests: ```scala libraryDependencies ++= Seq( - "org.typelevel" %% "cats-effect-std" % "3.5.1", - "org.typelevel" %% "cats-effect" % "3.5.1" % Test) + "org.typelevel" %% "cats-effect-std" % "3.5.2", + "org.typelevel" %% "cats-effect" % "3.5.2" % Test) ``` You may also find some utility in the **testkit** and **kernel-testkit** projects, which contain `TestContext`, generators for `IO`, and a few other things: ```scala -libraryDependencies += "org.typelevel" %% "cats-effect-testkit" % "3.5.1" % Test +libraryDependencies += "org.typelevel" %% "cats-effect-testkit" % "3.5.2" % Test ``` Cats Effect provides backward binary compatibility within the 2.x and 3.x version lines, and both forward and backward compatibility within any major/minor line. This is analogous to the versioning scheme used by Cats itself, as well as other major projects such as Scala.js. Thus, any project depending upon Cats Effect 2.2.1 can be used with libraries compiled against Cats Effect 2.0.0 or 2.2.3, but *not* with libraries compiled against 2.3.0 or higher. diff --git a/docs/core/native-image.md b/docs/core/native-image.md index 237a70351a..0fefa4e45d 100644 --- a/docs/core/native-image.md +++ b/docs/core/native-image.md @@ -33,7 +33,7 @@ ThisBuild / scalaVersion := "2.13.8" lazy val root = (project in file(".")).enablePlugins(NativeImagePlugin).settings( name := "cats-effect-3-hello-world", - libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.1", + libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.2", Compile / mainClass := Some("com.example.Main"), nativeImageOptions += "--no-fallback", nativeImageVersion := "22.1.0" // It should be at least version 21.0.0 diff --git a/docs/core/scala-native.md b/docs/core/scala-native.md index d146d72fb4..7bceac890a 100644 --- a/docs/core/scala-native.md +++ b/docs/core/scala-native.md @@ -22,7 +22,7 @@ lazy val root = project.in(file(".")) .enablePlugins(ScalaNativePlugin) .settings( name := "cats-effect-3-hello-world", - libraryDependencies += "org.typelevel" %%% "cats-effect" % "3.5.1", + libraryDependencies += "org.typelevel" %%% "cats-effect" % "3.5.2", Compile / mainClass := Some("com.example.Main") ) diff --git a/docs/core/test-runtime.md b/docs/core/test-runtime.md index be1e17f199..a6c8746e4c 100644 --- a/docs/core/test-runtime.md +++ b/docs/core/test-runtime.md @@ -28,7 +28,7 @@ For those migrating code from Cats Effect 2, `TestControl` is a considerably mor In order to use `TestControl`, you will need to bring in the **cats-effect-testkit** dependency: ```scala -libraryDependencies += "org.typelevel" %% "cats-effect-testkit" % "3.5.1" % Test +libraryDependencies += "org.typelevel" %% "cats-effect-testkit" % "3.5.2" % Test ``` ## Example diff --git a/docs/getting-started.md b/docs/getting-started.md index 8ad0bc3fe6..8eae7764a7 100644 --- a/docs/getting-started.md +++ b/docs/getting-started.md @@ -6,7 +6,7 @@ title: Getting Started Add the following to your **build.sbt**: ```scala -libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.1" +libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.2" ``` Naturally, if you're using ScalaJS, you should replace the double `%%` with a triple `%%%`. If you're on Scala 2, it is *highly* recommended that you enable the [better-monadic-for](https://github.com/oleg-py/better-monadic-for) plugin, which fixes a number of surprising elements of the `for`-comprehension syntax in the Scala language: diff --git a/docs/migration-guide.md b/docs/migration-guide.md index 9fa8838271..33eae63039 100644 --- a/docs/migration-guide.md +++ b/docs/migration-guide.md @@ -81,9 +81,9 @@ Cats Effect 3 splits the code dependency into multiple modules. If you were prev The current non-test modules are: ```scala -"org.typelevel" %% "cats-effect-kernel" % "3.5.1", -"org.typelevel" %% "cats-effect-std" % "3.5.1", -"org.typelevel" %% "cats-effect" % "3.5.1", +"org.typelevel" %% "cats-effect-kernel" % "3.5.2", +"org.typelevel" %% "cats-effect-std" % "3.5.2", +"org.typelevel" %% "cats-effect" % "3.5.2", ``` - `kernel` - type class definitions, simple concurrency primitives @@ -96,7 +96,7 @@ The current non-test modules are: libraryDependencies ++= Seq( //... - "org.typelevel" %% "cats-effect" % "2.4.0", -+ "org.typelevel" %% "cats-effect" % "3.5.1", ++ "org.typelevel" %% "cats-effect" % "3.5.2", //... ) ``` diff --git a/docs/tutorial.md b/docs/tutorial.md index 4f8b48cf99..ffdf9c3e87 100644 --- a/docs/tutorial.md +++ b/docs/tutorial.md @@ -42,11 +42,11 @@ running the code snippets in this tutorial, it is recommended to use the same ```scala name := "cats-effect-tutorial" -version := "3.5.1" +version := "3.5.2" scalaVersion := "2.13.6" -libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.1" withSources() withJavadoc() +libraryDependencies += "org.typelevel" %% "cats-effect" % "3.5.2" withSources() withJavadoc() scalacOptions ++= Seq( "-feature", From 7dfe45de87ba0da7b9f760133a0e79311db1db5a Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Thu, 28 Sep 2023 00:24:27 +0000 Subject: [PATCH 2/2] Update more versions --- docs/faq.md | 2 +- docs/getting-started.md | 2 +- docs/std/mapref.md | 2 +- docs/std/ref.md | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/docs/faq.md b/docs/faq.md index d19089559c..2720afe6ab 100644 --- a/docs/faq.md +++ b/docs/faq.md @@ -9,7 +9,7 @@ title: FAQ ```scala-cli //> using scala "2.13.8" -//> using lib "org.typelevel::cats-effect::3.4.11" +//> using lib "org.typelevel::cats-effect::3.5.2" import cats.effect._ diff --git a/docs/getting-started.md b/docs/getting-started.md index 8eae7764a7..eff54fead0 100644 --- a/docs/getting-started.md +++ b/docs/getting-started.md @@ -62,7 +62,7 @@ We will learn more about constructs like `start` and `*>` in later pages, but fo Of course, the easiest way to play with Cats Effect is to try it out in a Scala REPL. We recommend using [Ammonite](https://ammonite.io/#Ammonite-REPL) for this kind of thing. To get started, run the following lines (if not using Ammonite, skip the first line and make sure that Cats Effect and its dependencies are correctly configured on the classpath): ```scala -import $ivy.`org.typelevel::cats-effect:3.4.11` +import $ivy.`org.typelevel::cats-effect:3.5.2` import cats.effect.unsafe.implicits._ import cats.effect.IO diff --git a/docs/std/mapref.md b/docs/std/mapref.md index 3b4266d082..54535d2411 100644 --- a/docs/std/mapref.md +++ b/docs/std/mapref.md @@ -32,7 +32,7 @@ as long as their keys belong to different shards. This is probably one of the most common uses of this datatype. ```scala mdoc:reset:silent -//> using lib "org.typelevel::cats-effect:3.5.1" +//> using lib "org.typelevel::cats-effect::3.5.2" import cats.effect.IO import cats.effect.std.MapRef diff --git a/docs/std/ref.md b/docs/std/ref.md index 259d208558..b4c7cc5892 100644 --- a/docs/std/ref.md +++ b/docs/std/ref.md @@ -33,7 +33,7 @@ This is probably one of the most common uses of this concurrency primitive. In this example, the workers will concurrently run and update the value of the `Ref`. ```scala mdoc:reset:silent -//> using lib "org.typelevel::cats-effect:3.4.11" +//> using lib "org.typelevel::cats-effect::3.5.2" import cats.effect.{IO, IOApp, Sync} import cats.effect.kernel.Ref