This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class LocalDataSource<F>(A: ApplicativeError<F, Throwable>) : | |
DataSource<F>, ApplicativeError<F, Throwable> by A { | |
private val localCache: Map<User, List<Task>> = | |
mapOf(User(UserId("user1")) to listOf(Task("LocalTask assigned to user1"))) | |
override fun allTasksByUser(user: User): Kind<F, List<Task>> = | |
Option.fromNullable(localCache[user]).fold( | |
{ raiseError(UserNotInLocalStorage(user)) }, | |
{ just(it) } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
interface DataSource<F> { | |
fun allTasksByUser(user: User): Kind<F, List<Task>> | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
object test { | |
@JvmStatic | |
fun main(args: Array<String>): Unit { | |
val user1 = User(UserId("user1")) | |
val user2 = User(UserId("user2")) | |
val user3 = User(UserId("unknown user")) | |
val dependenciesModule = Module() | |
dependenciesModule.run { |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class Module { | |
private val localDataSource: LocalDataSource = LocalDataSource() | |
private val remoteDataSource: RemoteDataSource = RemoteDataSource() | |
val repository: TaskRepository = TaskRepository(localDataSource, remoteDataSource) | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class TaskRepository(private val localDS: DataSource, | |
private val remoteDS: RemoteDataSource) { | |
fun allTasksByUser(user: User): Observable<List<Task>> = | |
localDS.allTasksByUser(user) | |
.subscribeOn(Schedulers.io()) | |
.observeOn(Schedulers.computation()) | |
.onErrorResumeNext { _: Throwable -> remoteDS.allTasksByUser(user) } | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class LocalDataSource : DataSource { | |
private val localCache: Map<User, List<Task>> = | |
mapOf(User(UserId("user1")) to listOf(Task("LocalTask assigned to user1"))) | |
override fun allTasksByUser(user: User): Observable<List<Task>> = | |
Observable.create { emitter -> | |
val cachedUser = localCache[user] | |
if (cachedUser != null) { | |
emitter.onNext(cachedUser) | |
} else { |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
interface DataSource { | |
fun allTasksByUser(user: User): Observable<List<Task>> | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
interface DataSource { | |
fun allTasksByUser(user: User): Observable<List<Task>> | |
} | |
class LocalDataSource : DataSource { | |
private val localCache: Map<User, List<Task>> = | |
mapOf(User(UserId("user1")) to listOf(Task("LocalTask assigned to user1"))) | |
override fun allTasksByUser(user: User): Observable<List<Task>> = Observable.create { emitter -> | |
val cachedUser = localCache[user] |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
fun getCountryCode(maybePerson : Either<BizError, Person>): Either<BizError, String> = | |
Either.monadError<BizError>().binding { | |
val person = maybePerson.bind() | |
val address = person.address.toEither({ AddressNotFound(person.id) }).bind() | |
val country = address.country.toEither({ CountryNotFound(address.id) }).bind() | |
yields(country.code) | |
}.ev() |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class Memoize1<in T, out R>(val f: (T) -> R) : (T) -> R { | |
private val values = mutableMapOf<T, R>() | |
override fun invoke(x: T): R { | |
return values.getOrPut(x, { f(x) }) | |
} | |
} | |
fun <T, R> ((T) -> R).memoize(): (T) -> R = Memoize1(this) | |
val memoizedSumFactors = { x: Int -> sumOfFactors(x) }.memoize() |