Skip to content
This repository has been archived by the owner on Aug 7, 2024. It is now read-only.

Commit

Permalink
Merge pull request #22 from you-apps/cleanup-data-source
Browse files Browse the repository at this point in the history
refactor: cleanup dynamic data source
  • Loading branch information
Bnyro authored Oct 5, 2023
2 parents 8db9ff1 + a72cf23 commit e6843c2
Showing 1 changed file with 6 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,29 +19,25 @@ class DynamicDataSource(
private val defaultDataSource: DefaultDataSource
): DataSource {
private var isOnline = false
private val dataSource get() = if (isOnline) resolvingDataSource else defaultDataSource

override fun read(buffer: ByteArray, offset: Int, length: Int): Int {
return if (isOnline) resolvingDataSource.read(buffer, offset, length)
else defaultDataSource.read(buffer, offset, length)
return dataSource.read(buffer, offset, length)
}

override fun addTransferListener(transferListener: TransferListener) {
if (isOnline) resolvingDataSource.addTransferListener(transferListener)
else defaultDataSource.addTransferListener(transferListener)
dataSource.addTransferListener(transferListener)
}

override fun open(dataSpec: DataSpec): Long {
isOnline = dataSpec.uri.scheme != "content"
return if (isOnline) resolvingDataSource.open(dataSpec)
else defaultDataSource.open(dataSpec)
return dataSource.open(dataSpec)
}

override fun getUri(): Uri? {
return if (isOnline) resolvingDataSource.uri else defaultDataSource.uri
}
override fun getUri(): Uri? = dataSource.uri

override fun close() {
if (isOnline) resolvingDataSource.close() else defaultDataSource.close()
dataSource.close()
}

companion object {
Expand Down

0 comments on commit e6843c2

Please sign in to comment.