RongExceptionHandler.smali
.class public Lio/rong/imlib/ipc/RongExceptionHandler;
.super Ljava/lang/Object;
.source "RongExceptionHandler.java"
# interfaces
.implements Ljava/lang/Thread$UncaughtExceptionHandler;
# static fields
.field private static final TAG:Ljava/lang/String; = "RongExceptionHandler"
# instance fields
.field private mContext:Landroid/content/Context;
# direct methods
.method public constructor <init>(Landroid/content/Context;)V
.registers 2
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
iput-object p1, p0, Lio/rong/imlib/ipc/RongExceptionHandler;->mContext:Landroid/content/Context;
return-void
.end method
# virtual methods
.method public uncaughtException(Ljava/lang/Thread;Ljava/lang/Throwable;)V
.registers 8
const-string p1, "uncaughtException"
const-string v0, "RongExceptionHandler"
.line 1
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
.line 2
new-instance v3, Ljava/util/Date;
invoke-direct {v3, v1, v2}, Ljava/util/Date;-><init>(J)V
.line 3
new-instance v1, Ljava/text/SimpleDateFormat;
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
move-result-object v2
const-string v4, "yyyyMMdd_HHmmss"
invoke-direct {v1, v4, v2}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
.line 4
invoke-virtual {v1, v3}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v1
.line 5
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
iget-object v3, p0, Lio/rong/imlib/ipc/RongExceptionHandler;->mContext:Landroid/content/Context;
const-string v4, "crashlog"
invoke-static {v3, v4}, Lio/rong/common/FileUtils;->getCachePath(Landroid/content/Context;Ljava/lang/String;)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "/crash_"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ".log"
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 6
new-instance v2, Ljava/io/File;
invoke-direct {v2, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
const/4 v1, 0x0
.line 7
:try_start_43
invoke-virtual {v2}, Ljava/io/File;->createNewFile()Z
move-result v3
if-nez v3, :cond_4e
const-string v3, "crashFile.createNewFile() failed"
.line 8
invoke-static {v0, v3}, Lio/rong/common/RLog;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 9
:cond_4e
new-instance v3, Ljava/io/FileOutputStream;
invoke-direct {v3, v2}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
:try_end_53
.catch Ljava/lang/Exception; {:try_start_43 .. :try_end_53} :catch_6a
.catchall {:try_start_43 .. :try_end_53} :catchall_68
.line 10
:try_start_53
new-instance v1, Ljava/io/PrintStream;
invoke-direct {v1, v3}, Ljava/io/PrintStream;-><init>(Ljava/io/OutputStream;)V
.line 11
invoke-virtual {p2, v1}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintStream;)V
.line 12
invoke-virtual {v1}, Ljava/io/PrintStream;->close()V
:try_end_5e
.catch Ljava/lang/Exception; {:try_start_53 .. :try_end_5e} :catch_65
.catchall {:try_start_53 .. :try_end_5e} :catchall_62
.line 13
:try_start_5e
invoke-virtual {v3}, Ljava/io/FileOutputStream;->close()V
:try_end_61
.catch Ljava/io/IOException; {:try_start_5e .. :try_end_61} :catch_74
goto :goto_78
:catchall_62
move-exception p2
move-object v1, v3
goto :goto_80
:catch_65
move-exception v2
move-object v1, v3
goto :goto_6b
:catchall_68
move-exception p2
goto :goto_80
:catch_6a
move-exception v2
.line 14
:goto_6b
:try_start_6b
invoke-static {v0, p1, v2}, Lio/rong/common/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:try_end_6e
.catchall {:try_start_6b .. :try_end_6e} :catchall_68
if-eqz v1, :cond_78
.line 15
:try_start_70
invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V
:try_end_73
.catch Ljava/io/IOException; {:try_start_70 .. :try_end_73} :catch_74
goto :goto_78
:catch_74
move-exception v1
.line 16
invoke-static {v0, p1, v1}, Lio/rong/common/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 17
:cond_78
:goto_78
invoke-static {v0, p1, p2}, Lio/rong/common/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
const/4 p1, 0x2
.line 18
invoke-static {p1}, Ljava/lang/System;->exit(I)V
return-void
:goto_80
if-eqz v1, :cond_8a
.line 19
:try_start_82
invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V
:try_end_85
.catch Ljava/io/IOException; {:try_start_82 .. :try_end_85} :catch_86
goto :goto_8a
:catch_86
move-exception v1
.line 20
invoke-static {v0, p1, v1}, Lio/rong/common/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 21
:cond_8a
:goto_8a
throw p2
.end method