Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/pakoito/RxComprehensions

Reduce boilerplate in RxJava by abstracting chained operators like flatMap, concatMap, switchMap, or compose [STABLE]
https://github.com/pakoito/RxComprehensions

Last synced: about 2 months ago
JSON representation

Reduce boilerplate in RxJava by abstracting chained operators like flatMap, concatMap, switchMap, or compose [STABLE]

Awesome Lists containing this project

README

        

# RxComprehensions

RxComprehensions is a library to reduce boilerplate and simplify your `Observable` chains.

## Rationale

As your code starts getting more and more functional, you find that you have to chain multiple `Observable` by means of `flatMap()`, `concatMap()`, or `switchMap()`. This causes indentation levels to go quite high, and would often require that you split the code in several methods just to keep it readable.

```java
Observable getUserFriends =
profileClicks()
.flatMap { position ->
getUserFromProfile(position)
.flatMap { user ->
requestFriendListForUser(position, user.id)
.flatMap { friends ->
storeUserAndFriends(user, friends)
.flatMap { result ->
toUserDisplayString(position, user, friends, result)
}
}
}
}
```

**Comprehensions** are a language feature that allow you to define such a chain in a way where every observable is a function at topmost indentation, yet still contains all the parameters received in the previous functions.

## Usage

### Map comprehensions

RxComprehensions contains static methods `doFlatMap()` for `flatMap()`, `doConcatMap()` for `concatMap()`, `doSwitchMap()` for `switchMap()`. Each takes from 1 to 9 `FuncN` each with an increasing number of parameters, and returns an `Observable` of the type of the return of the last function.

```java
Observable getUserFriends =
// chained with flatMap()
RxComprehensions.doFlatMap(
() -> profileClicks(),
position -> getUserFromProfile(position),
position, user -> requestFriendListForUser(position, user.id),
position, user, friends -> storeUserAndFriends(user, friends),
position, user, friends, result -> toUserDisplayString(position, user, friends, result)
);
```

### Compose comprehensions

RxComprehensions contains static methods `doCompose()` for `compose()`. Each takes from 1 to 9 `Transformer` (RxJava 1.X) or `ObservableTransformer` (RxJava 2.X), and returns an `Observable` of the type of the return of the last one.

```java
Observable> getRelatives =
// chained with compose()
RxComprehensions.doCompose(
() -> requestRelative("12345"),
validate(),
assureThreads(Schedulers.io(), AndroidSchedulers.main()),
respectLifecycle(activity),
toUILayerModel(),
groupSiblings()
);

Observable requestRelative(String id) { /* ... */ }

ObservableTransformer validate() { /* ... */ }

ObservableTransformer assureThreads(Scheduler in, Scheduler out) { /* ... */ }

ObservableTransformer respectLifecycle(Activity activity) { /* ... */ }

ObservableTransformer toUILayerModel() { /* ... */ }

ObservableTransformer> groupSiblings() { /* ... */ }
```

## Distribution

### RxJava 1.X

Add as a dependency to your `build.gradle`
```groovy
repositories {
...
maven { url "https://jitpack.io" }
...
}

dependencies {
...
compile 'com.github.pakoito.RxComprehensions:rxcomprehensions:1.3.0'
...
}
```
or to your `pom.xml`

```xml


jitpack.io
https://jitpack.io

com.github.pakoito.RxComprehensions
rxcomprehensions
1.3.0

```

### RxJava 2.X

Add as a dependency to your `build.gradle`
```groovy
repositories {
...
maven { url "https://jitpack.io" }
...
}

dependencies {
...
compile 'com.github.pakoito.RxComprehensions:rxcomprehensions2:1.3.0'
...
}
```
or to your `pom.xml`

```xml


jitpack.io
https://jitpack.io

com.github.pakoito.RxComprehensions
rxcomprehensions2
1.3.0

```

## License

Copyright (c) pakoito 2016

The Apache Software License, Version 2.0

See LICENSE.md