Give up trying to workaround Compatibility
This commit is contained in:
@@ -86,7 +86,7 @@ class TetherTimeoutMonitor(private val timeout: Long = 0,
|
|||||||
fun onClientsChanged(noClient: Boolean) {
|
fun onClientsChanged(noClient: Boolean) {
|
||||||
this.noClient = noClient
|
this.noClient = noClient
|
||||||
if (!noClient) close() else if (timeoutJob == null) timeoutJob = GlobalScope.launch(context) {
|
if (!noClient) close() else if (timeoutJob == null) timeoutJob = GlobalScope.launch(context) {
|
||||||
delay(if (timeout == 0L) defaultTimeout.toLong() else timeout)
|
delay(if (timeout <= 0L) defaultTimeout.toLong() else timeout)
|
||||||
onTimeout()
|
onTimeout()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -548,7 +548,16 @@ data class SoftApConfigurationCompat(
|
|||||||
setChannelsCompat(builder, channels)
|
setChannelsCompat(builder, channels)
|
||||||
setBssid(builder, bssid?.toPlatform())
|
setBssid(builder, bssid?.toPlatform())
|
||||||
setMaxNumberOfClients(builder, maxNumberOfClients)
|
setMaxNumberOfClients(builder, maxNumberOfClients)
|
||||||
setShutdownTimeoutMillis(builder, shutdownTimeoutMillis)
|
try {
|
||||||
|
setShutdownTimeoutMillis(builder, shutdownTimeoutMillis)
|
||||||
|
} catch (e: InvocationTargetException) {
|
||||||
|
if (e.targetException is IllegalArgumentException) try {
|
||||||
|
setShutdownTimeoutMillis(builder, -1 - shutdownTimeoutMillis)
|
||||||
|
} catch (e2: InvocationTargetException) {
|
||||||
|
e2.addSuppressed(e)
|
||||||
|
throw e2
|
||||||
|
} else throw e
|
||||||
|
}
|
||||||
setAutoShutdownEnabled(builder, isAutoShutdownEnabled)
|
setAutoShutdownEnabled(builder, isAutoShutdownEnabled)
|
||||||
setClientControlByUserEnabled(builder, isClientControlByUserEnabled)
|
setClientControlByUserEnabled(builder, isClientControlByUserEnabled)
|
||||||
setHiddenSsid(builder, isHiddenSsid)
|
setHiddenSsid(builder, isHiddenSsid)
|
||||||
|
|||||||
@@ -152,7 +152,7 @@ class WifiApDialogFragment : AlertDialogFragment<WifiApDialogFragment.Arg, WifiA
|
|||||||
if (full) @TargetApi(28) {
|
if (full) @TargetApi(28) {
|
||||||
isAutoShutdownEnabled = dialogView.autoShutdown.isChecked
|
isAutoShutdownEnabled = dialogView.autoShutdown.isChecked
|
||||||
shutdownTimeoutMillis = dialogView.timeout.text.let { text ->
|
shutdownTimeoutMillis = dialogView.timeout.text.let { text ->
|
||||||
if (text.isNullOrEmpty()) defaultTimeout else text.toString().toLong()
|
if (text.isNullOrEmpty()) 0 else text.toString().toLong()
|
||||||
}
|
}
|
||||||
if (Build.VERSION.SDK_INT >= 23 || arg.p2pMode) channels = generateChannels()
|
if (Build.VERSION.SDK_INT >= 23 || arg.p2pMode) channels = generateChannels()
|
||||||
bssid = if (dialogView.bssid.length() != 0) {
|
bssid = if (dialogView.bssid.length() != 0) {
|
||||||
@@ -289,8 +289,6 @@ class WifiApDialogFragment : AlertDialogFragment<WifiApDialogFragment.Arg, WifiA
|
|||||||
populateFromConfiguration()
|
populateFromConfiguration()
|
||||||
}
|
}
|
||||||
|
|
||||||
private val defaultTimeout get() = if (arg.p2pMode) 0L else SoftApConfigurationCompat.DEFAULT_TIMEOUT
|
|
||||||
|
|
||||||
private fun locate(i: Int): Int {
|
private fun locate(i: Int): Int {
|
||||||
val band = base.channels.keyAt(i)
|
val band = base.channels.keyAt(i)
|
||||||
val channel = base.channels.valueAt(i)
|
val channel = base.channels.valueAt(i)
|
||||||
@@ -306,7 +304,7 @@ class WifiApDialogFragment : AlertDialogFragment<WifiApDialogFragment.Arg, WifiA
|
|||||||
if (!arg.p2pMode) dialogView.security.setSelection(base.securityType)
|
if (!arg.p2pMode) dialogView.security.setSelection(base.securityType)
|
||||||
dialogView.password.setText(base.passphrase)
|
dialogView.password.setText(base.passphrase)
|
||||||
dialogView.autoShutdown.isChecked = base.isAutoShutdownEnabled
|
dialogView.autoShutdown.isChecked = base.isAutoShutdownEnabled
|
||||||
dialogView.timeout.setText(base.shutdownTimeoutMillis.let { if (it == defaultTimeout) "" else it.toString() })
|
dialogView.timeout.setText(base.shutdownTimeoutMillis.let { if (it <= 0) "" else it.toString() })
|
||||||
if (Build.VERSION.SDK_INT >= 23 || arg.p2pMode) {
|
if (Build.VERSION.SDK_INT >= 23 || arg.p2pMode) {
|
||||||
dialogView.bandPrimary.setSelection(locate(0))
|
dialogView.bandPrimary.setSelection(locate(0))
|
||||||
if (Build.VERSION.SDK_INT >= 31 && !arg.p2pMode) {
|
if (Build.VERSION.SDK_INT >= 31 && !arg.p2pMode) {
|
||||||
|
|||||||
Reference in New Issue
Block a user