diff --git a/cookbooks/jq/index.html b/cookbooks/jq/index.html index 3b2f829c2..760ce91fc 100644 --- a/cookbooks/jq/index.html +++ b/cookbooks/jq/index.html @@ -256,7 +256,7 @@

import fs2.data.json.jq.Compiler val queryCompiler = Compiler[IO] -// queryCompiler: Compiler[IO] = fs2.data.json.jq.internal.ESPJqCompiler@30512570 +// queryCompiler: Compiler[IO] = fs2.data.json.jq.internal.ESPJqCompiler@4975bd5f val queryPipe = queryCompiler.compile(query).unsafeRunSync() // queryPipe: fs2.package.Pipe[IO, json.Token, json.Token] = <function1> diff --git a/documentation/cbor-json/index.html b/documentation/cbor-json/index.html index f585cc7a3..453e983a7 100644 --- a/documentation/cbor-json/index.html +++ b/documentation/cbor-json/index.html @@ -264,7 +264,7 @@

implicit val stateDecoder = deriveCellDecoder[State] -// stateDecoder: CellDecoder[State] = fs2.data.csv.generic.internal.DerivedCellDecoder$$anonfun$coproductDecoder$3@34e37fbd +// stateDecoder: CellDecoder[State] = fs2.data.csv.generic.internal.DerivedCellDecoder$$anonfun$coproductDecoder$3@34a454ba // use stateDecoder to derive decoders for rows...or just test: stateDecoder("On") // res1: DecoderResult[State] = Right(value = On) @@ -199,7 +199,7 @@

// same goes for the encoder implicit val stateEncoder = deriveCellEncoder[State] -// stateEncoder: CellEncoder[State] = fs2.data.csv.generic.internal.DerivedCellEncoder$$anonfun$coproductEncoder$3@4d2fff0 +// stateEncoder: CellEncoder[State] = fs2.data.csv.generic.internal.DerivedCellEncoder$$anonfun$coproductEncoder$3@1641c1f8 stateEncoder(State.On) // res3: String = "On"

The generic derivation for cell decoders also supports renaming and deriving instances for unary product types (case classes with one field):

@@ -213,9 +213,9 @@

// works as we have an implicit CellDecoder[String] implicit val unknownDecoder = deriveCellDecoder[Advanced.Unknown] -// unknownDecoder: CellDecoder[Advanced.Unknown] = fs2.data.csv.generic.internal.DerivedCellDecoder$$anonfun$unaryProductDecoder$3@5acbfd2f +// unknownDecoder: CellDecoder[Advanced.Unknown] = fs2.data.csv.generic.internal.DerivedCellDecoder$$anonfun$unaryProductDecoder$3@6f70d0ac implicit val advancedDecoder = deriveCellDecoder[Advanced] -// advancedDecoder: CellDecoder[Advanced] = fs2.data.csv.generic.internal.DerivedCellDecoder$$anonfun$coproductDecoder$3@22905132 +// advancedDecoder: CellDecoder[Advanced] = fs2.data.csv.generic.internal.DerivedCellDecoder$$anonfun$coproductDecoder$3@53d8921c advancedDecoder("Active") // res4: DecoderResult[Advanced] = Right(value = On) @@ -223,9 +223,9 @@

// res5: DecoderResult[Advanced] = Right(value = Unknown(name = "Off")) implicit val unknownEncoder = deriveCellEncoder[Advanced.Unknown] -// unknownEncoder: CellEncoder[Advanced.Unknown] = fs2.data.csv.generic.internal.DerivedCellEncoder$$anonfun$unaryProductEncoder$3@da1cc4a +// unknownEncoder: CellEncoder[Advanced.Unknown] = fs2.data.csv.generic.internal.DerivedCellEncoder$$anonfun$unaryProductEncoder$3@454f0d59 implicit val advancedEncoder = deriveCellEncoder[Advanced] -// advancedEncoder: CellEncoder[Advanced] = fs2.data.csv.generic.internal.DerivedCellEncoder$$anonfun$coproductEncoder$3@1e9f8f71 +// advancedEncoder: CellEncoder[Advanced] = fs2.data.csv.generic.internal.DerivedCellEncoder$$anonfun$coproductEncoder$3@5d994a09 advancedEncoder(Advanced.On) // res6: String = "Active" @@ -269,7 +269,7 @@

import fs2.data.csv.generic.semiauto._ implicit val MyRowDecoder: CsvRowDecoder[MyRow, String] = deriveCsvRowDecoder[MyRow] -// MyRowDecoder: CsvRowDecoder[MyRow, String] = fs2.data.csv.generic.internal.DerivedCsvRowDecoder$$anon$1@7d4c7f +// MyRowDecoder: CsvRowDecoder[MyRow, String] = fs2.data.csv.generic.internal.DerivedCsvRowDecoder$$anon$1@15a081cd val decoded = stream.through(decodeUsingHeaders[MyRow]()) // decoded: Stream[[x]Fallible[x], MyRow] = Stream(..) diff --git a/documentation/csv/index.html b/documentation/csv/index.html index f086ca725..8160d2441 100644 --- a/documentation/csv/index.html +++ b/documentation/csv/index.html @@ -200,9 +200,9 @@

val textStream = Stream.emit(input).covary[Fallible] // textStream: Stream[Fallible, String] = Stream(..) implicit val myRowDecoder: CsvRowDecoder[MyRow, String] = deriveCsvRowDecoder -// myRowDecoder: CsvRowDecoder[MyRow, String] = fs2.data.csv.generic.internal.DerivedCsvRowDecoder$$anon$1@5a4380fa +// myRowDecoder: CsvRowDecoder[MyRow, String] = fs2.data.csv.generic.internal.DerivedCsvRowDecoder$$anon$1@3328a43d implicit val myRowEncoder: CsvRowEncoder[MyRow, String] = deriveCsvRowEncoder -// myRowEncoder: CsvRowEncoder[MyRow, String] = fs2.data.csv.generic.internal.DerivedCsvRowEncoder$$anonfun$productWriter$2@c2e82eb +// myRowEncoder: CsvRowEncoder[MyRow, String] = fs2.data.csv.generic.internal.DerivedCsvRowEncoder$$anonfun$productWriter$2@27bb60c7 // decodeUsingHeaders can take a `Char` indicating the separator to use // for example `decodeUsingHeaders[MyRow](';') for a semi-colon separated csv @@ -453,7 +453,7 @@

implicit val parseableMyHeaders: ParseableHeader[MyHeaders] = ParseableHeader.instance[MyHeaders] { name => MyHeaders.withNameInsensitiveOption(name).toRight(new HeaderError(s"Unknown header $name")) } -// parseableMyHeaders: ParseableHeader[MyHeaders] = fs2.data.csv.ParseableHeader$$$Lambda$13047/0x0000000803522840@3ddd6b4f +// parseableMyHeaders: ParseableHeader[MyHeaders] = fs2.data.csv.ParseableHeader$$$Lambda$13104/0x00000008034c9840@54f61bc4 val withMyHeaders = stream.through(lowlevel.headers[Fallible, MyHeaders]) // withMyHeaders: Stream[[x]Fallible[x], CsvRow[MyHeaders]] = Stream(..) @@ -559,10 +559,10 @@

For CellEncoder, it is even easier to define your own as encoding can't fail, so basically it's just a function A => String. The easiest ways to roll your own are using Scala's single abstract method sugar:

case class Wrapper(content: String)
 implicit val wrapperCellEncoder: CellEncoder[Wrapper] = (w: Wrapper) => w.content
-// wrapperCellEncoder: CellEncoder[Wrapper] = repl.MdocSession$MdocApp$$anonfun$9@7bdf785e
+// wrapperCellEncoder: CellEncoder[Wrapper] = repl.MdocSession$MdocApp$$anonfun$9@2209542b

or using contramap on an existing encoder:

implicit val wrapperCellEncoder2: CellEncoder[Wrapper] = CellEncoder[String].contramap(_.content)
-// wrapperCellEncoder2: CellEncoder[Wrapper] = fs2.data.csv.CellEncoder$$anonfun$contramap$2@39e9414
+// wrapperCellEncoder2: CellEncoder[Wrapper] = fs2.data.csv.CellEncoder$$anonfun$contramap$2@5ec8a5f5

RowDecoder & RowEncoder

RowDecoders can be used to decode an entire CSV row based on field positions. For instance if you want to decode the CSV data into shapeless HList:

diff --git a/documentation/json/jq/index.html b/documentation/json/jq/index.html index 3bae0ab1e..e6a37e412 100644 --- a/documentation/json/jq/index.html +++ b/documentation/json/jq/index.html @@ -325,7 +325,7 @@

val qCompiler = jq.Compiler[SyncIO] -// qCompiler: jq.Compiler[SyncIO] = fs2.data.json.jq.internal.ESPJqCompiler@30a91880 +// qCompiler: jq.Compiler[SyncIO] = fs2.data.json.jq.internal.ESPJqCompiler@5e36f712 val compiled = qCompiler.compile(query).unsafeRunSync() // compiled: Pipe[SyncIO, Token, Token] = <function1> diff --git a/pagefind/fragment/en_1efe427.pf_fragment b/pagefind/fragment/en_1efe427.pf_fragment new file mode 100644 index 000000000..819f7f453 Binary files /dev/null and b/pagefind/fragment/en_1efe427.pf_fragment differ diff --git a/pagefind/fragment/en_84c6e9b.pf_fragment b/pagefind/fragment/en_84c6e9b.pf_fragment new file mode 100644 index 000000000..d667f6d49 Binary files /dev/null and b/pagefind/fragment/en_84c6e9b.pf_fragment differ diff --git a/pagefind/fragment/en_a54f169.pf_fragment b/pagefind/fragment/en_a54f169.pf_fragment new file mode 100644 index 000000000..32497e56f Binary files /dev/null and b/pagefind/fragment/en_a54f169.pf_fragment differ diff --git a/pagefind/fragment/en_b3e3657.pf_fragment b/pagefind/fragment/en_b3e3657.pf_fragment new file mode 100644 index 000000000..02827402e Binary files /dev/null and b/pagefind/fragment/en_b3e3657.pf_fragment differ diff --git a/pagefind/fragment/en_be908a1.pf_fragment b/pagefind/fragment/en_be908a1.pf_fragment new file mode 100644 index 000000000..786083dd8 Binary files /dev/null and b/pagefind/fragment/en_be908a1.pf_fragment differ diff --git a/pagefind/fragment/en_e61a15f.pf_fragment b/pagefind/fragment/en_e61a15f.pf_fragment new file mode 100644 index 000000000..2804e94a6 Binary files /dev/null and b/pagefind/fragment/en_e61a15f.pf_fragment differ diff --git a/pagefind/index/en_51afd1e.pf_index b/pagefind/index/en_51afd1e.pf_index new file mode 100644 index 000000000..26ce93379 Binary files /dev/null and b/pagefind/index/en_51afd1e.pf_index differ diff --git a/pagefind/index/en_e79db1a.pf_index b/pagefind/index/en_e79db1a.pf_index new file mode 100644 index 000000000..643435050 Binary files /dev/null and b/pagefind/index/en_e79db1a.pf_index differ diff --git a/pagefind/pagefind-entry.json b/pagefind/pagefind-entry.json index 4736bf1a4..4a4051b65 100644 --- a/pagefind/pagefind-entry.json +++ b/pagefind/pagefind-entry.json @@ -1 +1 @@ -{"version":"1.0.4","languages":{"en":{"hash":"en_397410bcb4","wasm":"en","page_count":17}}} \ No newline at end of file +{"version":"1.0.4","languages":{"en":{"hash":"en_1563d3a493","wasm":"en","page_count":17}}} \ No newline at end of file diff --git a/pagefind/pagefind.en_1563d3a493.pf_meta b/pagefind/pagefind.en_1563d3a493.pf_meta new file mode 100644 index 000000000..613847f9b Binary files /dev/null and b/pagefind/pagefind.en_1563d3a493.pf_meta differ