Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fpdart v2.0.0 #147

Open
wants to merge 91 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
91 commits
Select commit Hold shift + click to select a range
f9ece2c
experiment with shared `Effect` class
SandroMaglione Feb 16, 2024
194db27
`IEffect` shared interface
SandroMaglione Feb 16, 2024
d44181c
`Either` as `IEffect`
SandroMaglione Feb 16, 2024
3861235
`Async` from `IEffect`
SandroMaglione Feb 16, 2024
0fec429
`call` run
SandroMaglione Feb 16, 2024
289085a
no Sync/Async/Either, just `Effect`
SandroMaglione Mar 10, 2024
8980c86
`Effect` and `Either` env
SandroMaglione Mar 10, 2024
f9c32f0
`Option` as `IEffect`
SandroMaglione Mar 10, 2024
0c23b78
`mapLeft`
SandroMaglione Mar 10, 2024
4d2612e
more `Effect` methods
SandroMaglione Mar 13, 2024
e0c2dfa
`asEffect` for `IEffect` interface
SandroMaglione Mar 14, 2024
5f945c4
`Effect` api with categories
SandroMaglione Mar 14, 2024
bddc3b9
file system example with `Effect`
SandroMaglione Mar 16, 2024
a5af9a8
refactor with abstract env
SandroMaglione Mar 16, 2024
8e3aa09
test with `provide` in `Effect`
SandroMaglione Mar 16, 2024
9d42ff6
`catchError`
SandroMaglione Mar 17, 2024
ae2a3ef
refactor internals
SandroMaglione Mar 17, 2024
30e643f
remove all examples
SandroMaglione Mar 17, 2024
5163c52
initial (new) tests on `Effect`
SandroMaglione Mar 17, 2024
51a2a62
import alias
SandroMaglione Mar 17, 2024
b5b4c4c
`Effect` sync execute
SandroMaglione Mar 17, 2024
c2e9349
collect as `Iterable`
SandroMaglione Mar 17, 2024
7fc0a24
expand `Effect` API
SandroMaglione Mar 17, 2024
f70327f
`orDie` API
SandroMaglione Mar 17, 2024
e66dd02
`Option` API
SandroMaglione Mar 17, 2024
15b5634
`Either` API
SandroMaglione Mar 17, 2024
cb69054
`Exit` with `Cause`
SandroMaglione Mar 17, 2024
4a85df3
`tryCatch` API
SandroMaglione Mar 18, 2024
1b8d00e
removed `Cause` by interrupt
SandroMaglione Mar 18, 2024
69af383
`zipLeft` and `zipRight`
SandroMaglione Mar 18, 2024
5b5beca
`forEach` and `all`
SandroMaglione Mar 18, 2024
6e256c9
migration md
SandroMaglione Mar 18, 2024
bea6930
version 2.0.0-dev.1
SandroMaglione Mar 18, 2024
bda3934
http request example
SandroMaglione Mar 18, 2024
1565436
run `Effect` with `Never` env
SandroMaglione Mar 18, 2024
f39ee8b
fetch pokemon with validation example
SandroMaglione Mar 19, 2024
81d4b0d
run `gen` as `sync` or `async`
SandroMaglione Mar 20, 2024
06fff82
pokemon api example with `void` type
SandroMaglione Mar 21, 2024
aa0d3a5
working on types `Never` vs `void`
SandroMaglione Mar 21, 2024
4da33a1
revert to use `Never`
SandroMaglione Mar 21, 2024
1ed678d
execute either as effect using `Never`
SandroMaglione Mar 21, 2024
7f3314e
Use generic instead of `Never`
SandroMaglione Mar 21, 2024
a63aae1
`onError` for `gen`
SandroMaglione Mar 21, 2024
e82dba6
`catchError` and `catchCause`
SandroMaglione Mar 22, 2024
05036f1
factory constructors
SandroMaglione Mar 22, 2024
a44fed8
running `Effect`
SandroMaglione Mar 22, 2024
0f91eeb
clean up `Cause`
SandroMaglione Mar 22, 2024
f7cdc3d
fix fail in `Effect.gen`
SandroMaglione Mar 22, 2024
62a5d01
conversions and folding
SandroMaglione Mar 23, 2024
ab71d1e
imports
SandroMaglione Mar 23, 2024
e27399e
prepare v2 dev pre release
SandroMaglione Mar 23, 2024
de6395d
no `Never` env, maybe `void`
SandroMaglione Mar 23, 2024
60290a9
`getSomes`, `getLefts`, `getRights`
SandroMaglione Mar 24, 2024
d330768
filtering
SandroMaglione Mar 24, 2024
8ad0f09
full `Option` API
SandroMaglione Mar 24, 2024
b73849d
full `Either` API
SandroMaglione Mar 24, 2024
229e536
rename `Fail` to `Failure`
SandroMaglione Mar 24, 2024
8a0f930
errors in `FutureOr` sync
SandroMaglione Mar 24, 2024
f02afe3
`onError` with stack trace
SandroMaglione Mar 24, 2024
df5740d
`provide` and `mapEnv`
SandroMaglione Mar 24, 2024
a3352b5
`provideEffect`
SandroMaglione Mar 24, 2024
d8144dd
test type parameters
SandroMaglione Mar 24, 2024
dcb9861
run only when env is `Null`
SandroMaglione Mar 25, 2024
24449a3
update examples
SandroMaglione Mar 25, 2024
07bfa82
update examples (again)
SandroMaglione Mar 25, 2024
3e72bf5
catch error in gen future
SandroMaglione Mar 25, 2024
57eb5ee
effect abstract only
SandroMaglione Mar 26, 2024
3473096
`meta` version
SandroMaglione Mar 27, 2024
f343b03
run effects with catching
SandroMaglione Mar 27, 2024
83667b4
`Deferred` and `Context`
SandroMaglione Mar 27, 2024
b79f034
`race` and `raceAll`
SandroMaglione Mar 27, 2024
e4d3ad2
`delay` and `timeout`
SandroMaglione Mar 27, 2024
ac7f9e1
`Deferred` as `Effect`
SandroMaglione Mar 27, 2024
da0b2ee
`Deferred` effect with test
SandroMaglione Mar 28, 2024
9c8610c
interruption test
SandroMaglione Mar 28, 2024
4c893ef
provide API
SandroMaglione Mar 28, 2024
82d1ed6
fpdart 2.0.0-dev.2
SandroMaglione Mar 28, 2024
56f9ad7
const `None`
SandroMaglione Mar 29, 2024
bed477a
introduce `Scope`
SandroMaglione Mar 29, 2024
3ca43b8
`Scope` with test
SandroMaglione Apr 3, 2024
26180a7
test closable `Scope`
SandroMaglione Apr 3, 2024
895f80a
v2.0.0-dev.3
SandroMaglione Apr 3, 2024
8e34681
refactor and remove `__unsafeRun`
SandroMaglione Apr 4, 2024
43f0592
removed `tryCatch` `onCancel`
SandroMaglione Apr 4, 2024
2f80240
renamed `succeedLazy` and `failLazy`
SandroMaglione Apr 4, 2024
f691c1e
scope methods in `Effect`
SandroMaglione Apr 4, 2024
5efd738
fix `withScope` issue
SandroMaglione Apr 4, 2024
1118bd6
`async`, `asyncInterrupt`, `sleep`
SandroMaglione Apr 6, 2024
2fe20e1
rename constructors sync/future
SandroMaglione Apr 6, 2024
4039939
example read/write file
SandroMaglione Apr 7, 2024
29331c8
`sleep`
SandroMaglione Apr 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
58 changes: 0 additions & 58 deletions examples/do_constructor_pitfalls/bin/do_constructor_pitfalls.dart

This file was deleted.

18 changes: 0 additions & 18 deletions examples/do_constructor_pitfalls/pubspec.yaml

This file was deleted.

This file was deleted.

1 change: 1 addition & 0 deletions examples/file_read_stream/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
lib/output.json
12 changes: 12 additions & 0 deletions examples/file_read_stream/analysis_options.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
include: package:lints/recommended.yaml

linter:
rules:
annotate_overrides: true
prefer_void_to_null: false

analyzer:
language:
strict-casts: true
strict-inference: true
strict-raw-types: true
130 changes: 130 additions & 0 deletions examples/file_read_stream/lib/main.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,130 @@
import 'dart:convert';
import 'dart:io';

import 'package:fpdart/fpdart.dart';

import './word.dart';

typedef Env = ({
String wordPairCsv,
String wordsCsv,
String outputPath,
});

final wordPairs = Effect<Env, String, List<WordPair>>.gen(($) async {
final env = $.sync(Effect.env());
final inputFile = File(env.wordPairCsv);

final lines = inputFile.openRead().transform(utf8.decoder).transform(
LineSplitter(),
);

final wordCollection = <WordPair>[];
await for (var line in lines) {
final split = line.split(',');
if (split.length != 3) {
return $.sync(Effect.fail("Missing word-pair info at: '$line'"));
}

final wordInfo = $
.sync(Effect.all([
Effect.fromNullable(
int.tryParse(split[0]),
onNull: () => "Missing id collection",
),
Effect.fromNullable(
int.tryParse(split[1]),
onNull: () => "Missing id word1",
),
Effect.fromNullable(
int.tryParse(split[2]),
onNull: () => "Missing id word2",
),
]))
.toList();

wordCollection.add(WordPair(wordInfo[0], wordInfo[1], wordInfo[2]));
}

return wordCollection;
});

final words = Effect<Env, String, List<WordFull>>.gen(($) async {
final env = $.sync(Effect.env());
final wordCollection = await $.async(wordPairs);

final inputFile = File(env.wordsCsv);
final lines = inputFile.openRead().transform(utf8.decoder).transform(
LineSplitter(),
);

final wordMap = <int, String>{};
await for (var line in lines) {
final split = line.split(',');
if (split.length < 2) {
return $.sync(Effect.fail("Missing word info at: '$line'"));
}

final idWord = $.sync(Effect.fromNullable(
int.tryParse(split[0]),
onNull: () => "Missing id word",
));
final word = split[1];

wordMap[idWord] = word;
}

final wordFullList = <WordFull>[];
for (var entry in wordCollection) {
final word1 = $.sync(Effect.fromNullable(
wordMap[entry.idWord1],
onNull: () => "Missing word 1 at: $entry",
));
final word2 = $.sync(Effect.fromNullable(
wordMap[entry.idWord2],
onNull: () => "Missing word 2 at: $entry",
));

wordFullList.add(
WordFull(
entry.idCollection,
Word(entry.idWord1, word1),
Word(entry.idWord2, word2),
),
);
}

return wordFullList.toSet().toList();
});

final program = Effect<Env, String, Unit>.gen(($) async {
final env = $.sync(Effect.env());
final wordFullList = await $.async(words);

final outputFile = File(env.outputPath);
await $.async(
Effect.tryCatch(
execute: () => outputFile.writeAsString(
"[${wordFullList.map((e) => e.toJson()).join(",\n")}]",
),
onError: (_, __) => "Error while writing output file",
),
);

return unit;
});

void main() async {
await program.provideEnv((
wordPairCsv: "./lib/word_pairs.csv",
wordsCsv: "./lib/words.csv",
outputPath: "./lib/output.json",
)).matchCause(
onFailure: (cause) {
print(cause);
},
onSuccess: (_) {
print("Success");
},
).runFutureExit();
}
53 changes: 53 additions & 0 deletions examples/file_read_stream/lib/word.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
import 'package:equatable/equatable.dart';

class WordPair {
final int idCollection;
final int idWord1;
final int idWord2;
const WordPair(this.idCollection, this.idWord1, this.idWord2);

@override
String toString() {
return "($idCollection)$idWord1|$idWord2";
}
}

class Word extends Equatable {
final int idWord;
final String word;
const Word(this.idWord, this.word);

@override
String toString() {
return "($idWord)$word";
}

@override
List<Object?> get props => [idWord];

Map<String, dynamic> toJson() => {
'"idWord"': idWord,
'"word"': '"$word"',
};
}

class WordFull extends Equatable {
final int idCollection;
final Word word1;
final Word word2;
const WordFull(this.idCollection, this.word1, this.word2);

@override
String toString() {
return "πŸ‘‰ $idCollection\n $word1\n $word2";
}

@override
List<Object?> get props => [word1, word2];

Map<String, dynamic> toJson() => {
'"idCollection"': idCollection,
'"word1"': word1.toJson(),
'"word2"': word2.toJson(),
};
}
Loading
Loading