AppRTCBluetoothManager.smali

.class public Lorg/webrtc/audio/AppRTCBluetoothManager;
.super Ljava/lang/Object;
.source "AppRTCBluetoothManager.java"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothHeadsetBroadcastReceiver;,
        Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothServiceListener;,
        Lorg/webrtc/audio/AppRTCBluetoothManager$State;
    }
.end annotation


# static fields
.field private static final BLUETOOTH_SCO_TIMEOUT_MS:I

.field private static final MAX_SCO_CONNECTION_ATTEMPTS:I

.field private static final TAG:Ljava/lang/String; = "AppRTCBluetoothManager"


# instance fields
.field private final apprtcAudioManager:Lorg/webrtc/audio/AppRTCAudioManager;

.field private final apprtcContext:Landroid/content/Context;

.field private final audioManager:Landroid/media/AudioManager;

.field private bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

.field private bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

.field private bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

.field private final bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;

.field private final bluetoothServiceListener:Landroid/bluetooth/BluetoothProfile$ServiceListener;

.field private bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

.field private final bluetoothTimeoutRunnable:Ljava/lang/Runnable;

.field private mHandler:Landroid/os/Handler;

.field scoConnectionAttempts:I


# direct methods
.method static constructor <clinit>()V
    .registers 1

    const v0, 0x1acf

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/audio/AppRTCBluetoothManager;->BLUETOOTH_SCO_TIMEOUT_MS:I

    const v0, 0x156d

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/audio/AppRTCBluetoothManager;->MAX_SCO_CONNECTION_ATTEMPTS:I

    return-void
.end method

.method protected constructor <init>(Landroid/content/Context;Lorg/webrtc/audio/AppRTCAudioManager;)V
    .registers 5
    .param p1, "context"    # Landroid/content/Context;
    .param p2, "audioManager"    # Lorg/webrtc/audio/AppRTCAudioManager;

    .line 205
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 46
    new-instance v0, Landroid/os/Handler;

    invoke-direct {v0}, Landroid/os/Handler;-><init>()V

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->mHandler:Landroid/os/Handler;

    .line 83
    new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager$1;

    invoke-direct {v0, p0}, Lorg/webrtc/audio/AppRTCBluetoothManager$1;-><init>(Lorg/webrtc/audio/AppRTCBluetoothManager;)V

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeoutRunnable:Ljava/lang/Runnable;

    .line 206
    const-string v0, "AppRTCBluetoothManager"

    const-string v1, "ctor"

    invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 207
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 208
    iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;

    .line 209
    iput-object p2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcAudioManager:Lorg/webrtc/audio/AppRTCAudioManager;

    .line 210
    invoke-virtual {p0, p1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->getAudioManager(Landroid/content/Context;)Landroid/media/AudioManager;

    move-result-object v0

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    .line 211
    sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 212
    new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothServiceListener;

    const/4 v1, 0x0

    invoke-direct {v0, p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothServiceListener;-><init>(Lorg/webrtc/audio/AppRTCBluetoothManager;Lorg/webrtc/audio/AppRTCBluetoothManager$1;)V

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothServiceListener:Landroid/bluetooth/BluetoothProfile$ServiceListener;

    .line 213
    new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothHeadsetBroadcastReceiver;

    invoke-direct {v0, p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothHeadsetBroadcastReceiver;-><init>(Lorg/webrtc/audio/AppRTCBluetoothManager;Lorg/webrtc/audio/AppRTCBluetoothManager$1;)V

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;

    .line 214
    return-void
.end method

.method static synthetic access$000(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;

    .line 38
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeout()V

    return-void
.end method

.method static synthetic access$100(Lorg/webrtc/audio/AppRTCBluetoothManager;)Lorg/webrtc/audio/AppRTCBluetoothManager$State;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;

    .line 38
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    return-object v0
.end method

.method static synthetic access$102(Lorg/webrtc/audio/AppRTCBluetoothManager;Lorg/webrtc/audio/AppRTCBluetoothManager$State;)Lorg/webrtc/audio/AppRTCBluetoothManager$State;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;
    .param p1, "x1"    # Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 38
    iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    return-object p1
.end method

.method static synthetic access$202(Lorg/webrtc/audio/AppRTCBluetoothManager;Landroid/bluetooth/BluetoothHeadset;)Landroid/bluetooth/BluetoothHeadset;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;
    .param p1, "x1"    # Landroid/bluetooth/BluetoothHeadset;

    .line 38
    iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    return-object p1
.end method

.method static synthetic access$300(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;

    .line 38
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->updateAudioDeviceState()V

    return-void
.end method

.method static synthetic access$402(Lorg/webrtc/audio/AppRTCBluetoothManager;Landroid/bluetooth/BluetoothDevice;)Landroid/bluetooth/BluetoothDevice;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;
    .param p1, "x1"    # Landroid/bluetooth/BluetoothDevice;

    .line 38
    iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    return-object p1
.end method

.method static synthetic access$500(Lorg/webrtc/audio/AppRTCBluetoothManager;I)Ljava/lang/String;
    .registers 3
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;
    .param p1, "x1"    # I

    .line 38
    invoke-direct {p0, p1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method

.method static synthetic access$600(Lorg/webrtc/audio/AppRTCBluetoothManager;)Landroid/os/Handler;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;

    .line 38
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->mHandler:Landroid/os/Handler;

    return-object v0
.end method

.method static synthetic access$700(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/audio/AppRTCBluetoothManager;

    .line 38
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->cancelTimer()V

    return-void
.end method

.method private bluetoothTimeout()V
    .registers 7

    .line 471
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 472
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v1, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v1, :cond_c3

    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    if-nez v0, :cond_f

    goto/16 :goto_c3

    .line 475
    :cond_f
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "bluetoothTimeout: BT state="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    const-string v1, ", attempts: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v1, ", SCO is on: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 477
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z

    move-result v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 475
    const-string v1, "AppRTCBluetoothManager"

    invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 478
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v2, :cond_44

    .line 479
    return-void

    .line 482
    :cond_44
    const/4 v0, 0x0

    .line 483
    .local v0, "scoConnected":Z
    iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    invoke-virtual {v2}, Landroid/bluetooth/BluetoothHeadset;->getConnectedDevices()Ljava/util/List;

    move-result-object v2

    .line 484
    .local v2, "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
    invoke-interface {v2}, Ljava/util/List;->size()I

    move-result v3

    const/4 v4, 0x0

    if-lez v3, :cond_98

    .line 485
    invoke-interface {v2, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;

    move-result-object v3

    check-cast v3, Landroid/bluetooth/BluetoothDevice;

    iput-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 486
    iget-object v5, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    invoke-virtual {v5, v3}, Landroid/bluetooth/BluetoothHeadset;->isAudioConnected(Landroid/bluetooth/BluetoothDevice;)Z

    move-result v3

    if-eqz v3, :cond_7e

    .line 487
    new-instance v3, Ljava/lang/StringBuilder;

    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V

    const-string v5, "SCO connected with "

    invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v5, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    invoke-virtual {v5}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;

    move-result-object v5

    invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-static {v1, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 488
    const/4 v0, 0x1

    goto :goto_98

    .line 490
    :cond_7e
    new-instance v3, Ljava/lang/StringBuilder;

    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V

    const-string v5, "SCO is not connected with "

    invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v5, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    invoke-virtual {v5}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;

    move-result-object v5

    invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-static {v1, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 493
    :cond_98
    :goto_98
    if-eqz v0, :cond_a1

    .line 495
    sget-object v3, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 496
    iput v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    goto :goto_a9

    .line 499
    :cond_a1
    const-string v3, "BT failed to connect after timeout"

    invoke-static {v1, v3}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    .line 500
    invoke-virtual {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stopScoAudio()V

    .line 502
    :goto_a9
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->updateAudioDeviceState()V

    .line 503
    new-instance v3, Ljava/lang/StringBuilder;

    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V

    const-string v4, "bluetoothTimeout done: BT state="

    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-static {v1, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 504
    return-void

    .line 473
    .end local v0    # "scoConnected":Z
    .end local v2    # "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
    :cond_c3
    :goto_c3
    return-void
.end method

.method private cancelTimer()V
    .registers 3

    .line 461
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 462
    const-string v0, "AppRTCBluetoothManager"

    const-string v1, "cancelTimer"

    invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 463
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeoutRunnable:Ljava/lang/Runnable;

    invoke-static {v0}, Lorg/webrtc/ali/ThreadUtils;->runOnUiThread(Ljava/lang/Runnable;)V

    .line 464
    return-void
.end method

.method static create(Landroid/content/Context;Lorg/webrtc/audio/AppRTCAudioManager;)Lorg/webrtc/audio/AppRTCBluetoothManager;
    .registers 4
    .param p0, "context"    # Landroid/content/Context;
    .param p1, "audioManager"    # Lorg/webrtc/audio/AppRTCAudioManager;

    .line 201
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "create"

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-static {}, Lorg/webrtc/utils/AppRTCUtils;->getThreadInfo()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    const-string v1, "AppRTCBluetoothManager"

    invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 202
    new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager;

    invoke-direct {v0, p0, p1}, Lorg/webrtc/audio/AppRTCBluetoothManager;-><init>(Landroid/content/Context;Lorg/webrtc/audio/AppRTCAudioManager;)V

    return-object v0
.end method

.method private isScoOn()Z
    .registers 2

    .line 508
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    invoke-virtual {v0}, Landroid/media/AudioManager;->isBluetoothScoOn()Z

    move-result v0

    return v0
.end method

.method private startTimer()V
    .registers 4

    .line 454
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 455
    const-string v0, "AppRTCBluetoothManager"

    const-string v1, "startTimer"

    invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 456
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeoutRunnable:Ljava/lang/Runnable;

    const-wide/16 v1, 0xfa0

    invoke-static {v0, v1, v2}, Lorg/webrtc/ali/ThreadUtils;->postOnUiThread(Ljava/lang/Runnable;J)V

    .line 457
    return-void
.end method

.method private stateToString(I)Ljava/lang/String;
    .registers 3
    .param p1, "state"    # I

    .line 513
    if-eqz p1, :cond_26

    const/4 v0, 0x1

    if-eq p1, v0, :cond_23

    const/4 v0, 0x2

    if-eq p1, v0, :cond_20

    const/4 v0, 0x3

    if-eq p1, v0, :cond_1d

    packed-switch p1, :pswitch_data_2a

    .line 535
    const-string v0, "INVALID"

    return-object v0

    .line 529
    :pswitch_11
    const-string v0, "TURNING_OFF"

    return-object v0

    .line 525
    :pswitch_14
    const-string v0, "ON"

    return-object v0

    .line 533
    :pswitch_17
    const-string v0, "TURNING_ON"

    return-object v0

    .line 523
    :pswitch_1a
    const-string v0, "OFF"

    return-object v0

    .line 521
    :cond_1d
    const-string v0, "DISCONNECTING"

    return-object v0

    .line 517
    :cond_20
    const-string v0, "CONNECTED"

    return-object v0

    .line 519
    :cond_23
    const-string v0, "CONNECTING"

    return-object v0

    .line 515
    :cond_26
    const-string v0, "DISCONNECTED"

    return-object v0

    nop

    :pswitch_data_2a
    .packed-switch 0xa
        :pswitch_1a
        :pswitch_17
        :pswitch_14
        :pswitch_11
    .end packed-switch
.end method

.method private updateAudioDeviceState()V
    .registers 3

    .line 447
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 448
    const-string v0, "AppRTCBluetoothManager"

    const-string v1, "updateAudioDeviceState"

    invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 449
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcAudioManager:Lorg/webrtc/audio/AppRTCAudioManager;

    invoke-virtual {v0}, Lorg/webrtc/audio/AppRTCAudioManager;->updateAudioDeviceState()V

    .line 450
    return-void
.end method


# virtual methods
.method protected getAudioManager(Landroid/content/Context;)Landroid/media/AudioManager;
    .registers 3
    .param p1, "context"    # Landroid/content/Context;

    .line 398
    const-string v0, "audio"

    invoke-virtual {p1, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Landroid/media/AudioManager;

    return-object v0
.end method

.method protected getBluetoothProfileProxy(Landroid/content/Context;Landroid/bluetooth/BluetoothProfile$ServiceListener;I)Z
    .registers 5
    .param p1, "context"    # Landroid/content/Context;
    .param p2, "listener"    # Landroid/bluetooth/BluetoothProfile$ServiceListener;
    .param p3, "profile"    # I

    .line 419
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    invoke-virtual {v0, p1, p2, p3}, Landroid/bluetooth/BluetoothAdapter;->getProfileProxy(Landroid/content/Context;Landroid/bluetooth/BluetoothProfile$ServiceListener;I)Z

    move-result v0

    return v0
.end method

.method public getState()Lorg/webrtc/audio/AppRTCBluetoothManager$State;
    .registers 2

    .line 218
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 219
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    return-object v0
.end method

.method protected hasPermission(Landroid/content/Context;Ljava/lang/String;)Z
    .registers 6
    .param p1, "context"    # Landroid/content/Context;
    .param p2, "permission"    # Ljava/lang/String;

    .line 423
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;

    invoke-static {}, Landroid/os/Process;->myPid()I

    move-result v1

    invoke-static {}, Landroid/os/Process;->myUid()I

    move-result v2

    invoke-virtual {v0, p2, v1, v2}, Landroid/content/Context;->checkPermission(Ljava/lang/String;II)I

    move-result v0

    if-nez v0, :cond_12

    const/4 v0, 0x1

    goto :goto_13

    :cond_12
    const/4 v0, 0x0

    :goto_13
    return v0
.end method

.method protected logBluetoothAdapterInfo(Landroid/bluetooth/BluetoothAdapter;)V
    .registers 9
    .param p1, "localAdapter"    # Landroid/bluetooth/BluetoothAdapter;

    .line 430
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "BluetoothAdapter: enabled="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 431
    invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->isEnabled()Z

    move-result v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    const-string v1, ", state="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 432
    invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getState()I

    move-result v1

    invoke-direct {p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, ", name="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 433
    invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getName()Ljava/lang/String;

    move-result-object v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, ", address="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 434
    invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getAddress()Ljava/lang/String;

    move-result-object v2

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 430
    const-string v2, "AppRTCBluetoothManager"

    invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 436
    invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getBondedDevices()Ljava/util/Set;

    move-result-object v0

    .line 437
    .local v0, "pairedDevices":Ljava/util/Set;, "Ljava/util/Set<Landroid/bluetooth/BluetoothDevice;>;"
    invoke-interface {v0}, Ljava/util/Set;->isEmpty()Z

    move-result v3

    if-nez v3, :cond_84

    .line 438
    const-string v3, "paired devices:"

    invoke-static {v2, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 439
    invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;

    move-result-object v3

    :goto_55
    invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z

    move-result v4

    if-eqz v4, :cond_84

    invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v4

    check-cast v4, Landroid/bluetooth/BluetoothDevice;

    .line 440
    .local v4, "device":Landroid/bluetooth/BluetoothDevice;
    new-instance v5, Ljava/lang/StringBuilder;

    invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V

    const-string v6, " name="

    invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v4}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;

    move-result-object v6

    invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v4}, Landroid/bluetooth/BluetoothDevice;->getAddress()Ljava/lang/String;

    move-result-object v6

    invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v5

    invoke-static {v2, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 441
    .end local v4    # "device":Landroid/bluetooth/BluetoothDevice;
    goto :goto_55

    .line 443
    :cond_84
    return-void
.end method

.method protected registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)V
    .registers 4
    .param p1, "receiver"    # Landroid/content/BroadcastReceiver;
    .param p2, "filter"    # Landroid/content/IntentFilter;

    .line 403
    :try_start_0
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;

    invoke-virtual {v0, p1, p2}, Landroid/content/Context;->registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)Landroid/content/Intent;
    :try_end_5
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_5} :catch_6

    .line 406
    goto :goto_a

    .line 404
    :catch_6
    move-exception v0

    .line 405
    .local v0, "e":Ljava/lang/Exception;
    invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V

    .line 407
    .end local v0    # "e":Ljava/lang/Exception;
    :goto_a
    return-void
.end method

.method public start()V
    .registers 6

    .line 236
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 237
    const-string v0, "AppRTCBluetoothManager"

    const-string v1, "start"

    invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 238
    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;

    const-string v2, "android.permission.BLUETOOTH"

    invoke-virtual {p0, v1, v2}, Lorg/webrtc/audio/AppRTCBluetoothManager;->hasPermission(Landroid/content/Context;Ljava/lang/String;)Z

    move-result v1

    if-nez v1, :cond_32

    .line 239
    new-instance v1, Ljava/lang/StringBuilder;

    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V

    const-string v2, "Process (pid="

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-static {}, Landroid/os/Process;->myPid()I

    move-result v2

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v2, ") lacks BLUETOOTH permission"

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v1

    invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    .line 240
    return-void

    .line 242
    :cond_32
    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v1, v2, :cond_3e

    .line 243
    const-string v1, "Invalid BT state"

    invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    .line 244
    return-void

    .line 246
    :cond_3e
    const/4 v1, 0x0

    iput-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    .line 247
    iput-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 248
    const/4 v1, 0x0

    iput v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    .line 250
    invoke-static {}, Landroid/bluetooth/BluetoothAdapter;->getDefaultAdapter()Landroid/bluetooth/BluetoothAdapter;

    move-result-object v1

    iput-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    .line 251
    if-nez v1, :cond_54

    .line 252
    const-string v1, "Device does not support Bluetooth"

    invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I

    .line 253
    return-void

    .line 256
    :cond_54
    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    invoke-virtual {v1}, Landroid/media/AudioManager;->isBluetoothScoAvailableOffCall()Z

    move-result v1

    if-nez v1, :cond_62

    .line 257
    const-string v1, "Bluetooth SCO audio is not available off call"

    invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 258
    return-void

    .line 260
    :cond_62
    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    invoke-virtual {p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->logBluetoothAdapterInfo(Landroid/bluetooth/BluetoothAdapter;)V

    .line 263
    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;

    iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothServiceListener:Landroid/bluetooth/BluetoothProfile$ServiceListener;

    const/4 v3, 0x1

    invoke-virtual {p0, v1, v2, v3}, Lorg/webrtc/audio/AppRTCBluetoothManager;->getBluetoothProfileProxy(Landroid/content/Context;Landroid/bluetooth/BluetoothProfile$ServiceListener;I)Z

    move-result v1

    if-nez v1, :cond_78

    .line 265
    const-string v1, "BluetoothAdapter.getProfileProxy(HEADSET) failed"

    invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 266
    return-void

    .line 269
    :cond_78
    new-instance v1, Landroid/content/IntentFilter;

    invoke-direct {v1}, Landroid/content/IntentFilter;-><init>()V

    .line 271
    .local v1, "bluetoothHeadsetFilter":Landroid/content/IntentFilter;
    const-string v2, "android.bluetooth.headset.profile.action.CONNECTION_STATE_CHANGED"

    invoke-virtual {v1, v2}, Landroid/content/IntentFilter;->addAction(Ljava/lang/String;)V

    .line 273
    const-string v2, "android.bluetooth.headset.profile.action.AUDIO_STATE_CHANGED"

    invoke-virtual {v1, v2}, Landroid/content/IntentFilter;->addAction(Ljava/lang/String;)V

    .line 274
    iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;

    invoke-virtual {p0, v2, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)V

    .line 275
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v4, "HEADSET profile state: "

    invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    .line 276
    invoke-virtual {v4, v3}, Landroid/bluetooth/BluetoothAdapter;->getProfileConnectionState(I)I

    move-result v3

    invoke-direct {p0, v3}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    .line 275
    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 277
    const-string v2, "Bluetooth proxy for headset profile has started"

    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 278
    sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_UNAVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 279
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "start done: BT state="

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 280
    return-void
.end method

.method public startScoAudio()Z
    .registers 6

    .line 319
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 320
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "startSco: BT state="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    const-string v1, ", attempts: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v1, ", SCO is on: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 322
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z

    move-result v2

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 320
    const-string v2, "AppRTCBluetoothManager"

    invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 323
    iget v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    const/4 v3, 0x0

    const/4 v4, 0x2

    if-lt v0, v4, :cond_3d

    .line 324
    const-string v0, "BT SCO connection fails - no more attempts"

    invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 325
    return v3

    .line 327
    :cond_3d
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v4, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_AVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v4, :cond_49

    .line 328
    const-string v0, "BT SCO connection fails - no headset available"

    invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 329
    return v3

    .line 332
    :cond_49
    const-string v0, "Starting Bluetooth SCO and waits for ACTION_AUDIO_STATE_CHANGED..."

    invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 336
    sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 337
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    invoke-virtual {v0}, Landroid/media/AudioManager;->startBluetoothSco()V

    .line 338
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    const/4 v3, 0x1

    invoke-virtual {v0, v3}, Landroid/media/AudioManager;->setBluetoothScoOn(Z)V

    .line 339
    iget v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    add-int/2addr v0, v3

    iput v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I

    .line 340
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->startTimer()V

    .line 341
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v4, "startScoAudio done: BT state="

    invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 342
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z

    move-result v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 341
    invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 343
    return v3
.end method

.method public stop()V
    .registers 6

    .line 284
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 285
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;

    invoke-virtual {p0, v0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V

    .line 286
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "stop: BT state="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    const-string v1, "AppRTCBluetoothManager"

    invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 287
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    if-eqz v0, :cond_45

    .line 289
    invoke-virtual {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stopScoAudio()V

    .line 291
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v2, :cond_45

    .line 292
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->cancelTimer()V

    .line 293
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    const/4 v2, 0x0

    if-eqz v0, :cond_3d

    .line 294
    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    const/4 v4, 0x1

    invoke-virtual {v3, v4, v0}, Landroid/bluetooth/BluetoothAdapter;->closeProfileProxy(ILandroid/bluetooth/BluetoothProfile;)V

    .line 295
    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    .line 297
    :cond_3d
    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;

    .line 298
    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 299
    sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 302
    :cond_45
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v2, "stop done: BT state="

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 303
    return-void
.end method

.method public stopScoAudio()V
    .registers 5

    .line 348
    invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V

    .line 349
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "stopScoAudio: BT state="

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    const-string v1, ", SCO is on: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 350
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z

    move-result v2

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 349
    const-string v2, "AppRTCBluetoothManager"

    invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 351
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v3, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v3, :cond_34

    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v3, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v3, :cond_34

    .line 352
    return-void

    .line 354
    :cond_34
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->cancelTimer()V

    .line 355
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    invoke-virtual {v0}, Landroid/media/AudioManager;->stopBluetoothSco()V

    .line 356
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;

    const/4 v3, 0x0

    invoke-virtual {v0, v3}, Landroid/media/AudioManager;->setBluetoothScoOn(Z)V

    .line 357
    sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_DISCONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 358
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "stopScoAudio done: BT state="

    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 359
    invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z

    move-result v1

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    .line 358
    invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 360
    return-void
.end method

.method protected unregisterReceiver(Landroid/content/BroadcastReceiver;)V
    .registers 3
    .param p1, "receiver"    # Landroid/content/BroadcastReceiver;

    .line 411
    :try_start_0
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;

    invoke-virtual {v0, p1}, Landroid/content/Context;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V
    :try_end_5
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_5} :catch_6

    .line 414
    goto :goto_a

    .line 412
    :catch_6
    move-exception v0

    .line 413
    .local v0, "e":Ljava/lang/Exception;
    invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V

    .line 415
    .end local v0    # "e":Ljava/lang/Exception;
    :goto_a
    return-void
.end method

.method public updateDevice()V
    .registers 6

    .line 370
    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    sget-object v1, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    if-eq v0, v1, :cond_8e

    iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    if-nez v0, :cond_c

    goto/16 :goto_8e

    .line 373
    :cond_c
    const-string v0, "AppRTCBluetoothManager"

    const-string v1, "updateDevice"

    invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 377
    iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    invoke-virtual {v1}, Landroid/bluetooth/BluetoothHeadset;->getConnectedDevices()Ljava/util/List;

    move-result-object v1

    .line 378
    .local v1, "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
    invoke-interface {v1}, Ljava/util/List;->isEmpty()Z

    move-result v2

    if-eqz v2, :cond_2c

    .line 379
    const/4 v2, 0x0

    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 380
    sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_UNAVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 381
    const-string v2, "No connected bluetooth headset"

    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_77

    .line 384
    :cond_2c
    const/4 v2, 0x0

    invoke-interface {v1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;

    move-result-object v2

    check-cast v2, Landroid/bluetooth/BluetoothDevice;

    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 385
    sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_AVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    .line 386
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "Connected bluetooth headset: name="

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 387
    invoke-virtual {v3}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, ", state="

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 388
    invoke-virtual {v3, v4}, Landroid/bluetooth/BluetoothHeadset;->getConnectionState(Landroid/bluetooth/BluetoothDevice;)I

    move-result v3

    invoke-direct {p0, v3}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, ", SCO audio="

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;

    iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;

    .line 389
    invoke-virtual {v3, v4}, Landroid/bluetooth/BluetoothHeadset;->isAudioConnected(Landroid/bluetooth/BluetoothDevice;)Z

    move-result v3

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    .line 386
    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 391
    :goto_77
    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    const-string v3, "updateDevice done: BT state="

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v2

    invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 392
    return-void

    .line 371
    .end local v1    # "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
    :cond_8e
    :goto_8e
    return-void
.end method