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

Kotlin Multiplatform support #447

Open
bpavuk opened this issue May 16, 2024 · 7 comments
Open

Kotlin Multiplatform support #447

bpavuk opened this issue May 16, 2024 · 7 comments

Comments

@bpavuk
Copy link

bpavuk commented May 16, 2024

Kotlin Multiplatform is slowly rising, many major libraries are either migrating or already support KMP. Google announced their official support of KMP, by the way. I know that there is a Mastodonk library, but the last commit was like 10 months ago

@bocops
Copy link
Collaborator

bocops commented May 21, 2024

I'm not sure if this library even has any code or dependencies that currently rules out its use on specific platforms. What exactly would we need to change?

@bpavuk
Copy link
Author

bpavuk commented May 21, 2024

Migrate to OkHttp v5.x and wait for them to bring other platforms' support, or choose the Ktor Client, rewrite all the networking code on another framework, and not wait for Square to bring multiplatform support for OkHttp. Both paths are time-consuming.

@PattaFeuFeu
Copy link
Collaborator

When previously rewriting the Streaming API, I already had the idea to go for ktor and with it go for suspend functions, but that would have implications for users of the library that write in Java.

I don’t know how to write suspending Kotlin code that has good interoperability with Java code so I had put the idea on hold for the time being.

@bpavuk
Copy link
Author

bpavuk commented May 21, 2024

We need to adapt only the Java-exclusive bigbone-rx module to Kotlin coroutines, don't we?

@PattaFeuFeu
Copy link
Collaborator

PattaFeuFeu commented May 24, 2024

@bpavuk Mhm, not entirely. At least from feedback we had gotten in the past, it seems like (some) people are also using the library called from “vanilla” Java without RxJava.

Having a Coroutines<>RxJava bridge would, for example, be possible via kotlinx-coroutines-rx3 and I have used that in apps. But I’m not sure how well—if at all—Coroutines can be used from a “pure” Java context.

That being said, I would still very much like to give ktor a try. Even if just for how much easier testing with it looks, especially for WebSockets which we use for the streaming portion of the Mastodon APIs.

@bpavuk
Copy link
Author

bpavuk commented May 26, 2024

Fast googling suggests we cannot call Coroutines from pure Java code.
Maybe, we could publish the refactor as a separate artifact, like "BigboneX"? Sounds similar to Android -> AndroidX. You can still use the pure Android framework, but if you prefer the usability, then migrate to AndroidX.

@PattaFeuFeu
Copy link
Collaborator

I don’t see how we could keep that intact. We would then need to maintain both versions.

With ktor not being Coroutines-friendly but Coroutines-“based”, I don’t really see a way here. We would have to handle methods and functions as suspend functions everywhere in the library. A Java layer could maybe expose them as synchronous by using them in a blocking fashion but I don’t really like that idea.

We’d likely have to think about how to move forward here and how we want to structure BigBone anyway. Do we want to keep on supporting pure Java? Do we want to introduce different modules to the library where users could, for example, use only our types but do the calls themselves, and then have the API calls as easy-to-call methods like we currently provide them, but in a separate module you could add a dependency for?

Either way, we’ll have to talk about it if we want to move forward with either KMP support or even just Coroutines.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants