.class Lcom/moji/statistics/upload/UploadRunnable; .super Ljava/lang/Object; .source "UploadRunnable.java" # interfaces .implements Ljava/lang/Runnable; # instance fields .field private a:Lcom/moji/statistics/AbsEventLogWriter; # direct methods .method constructor ()V .locals 0 .line 20 invoke-direct {p0}, Ljava/lang/Object;->()V return-void .end method .method private a()V .locals 8 .line 35 new-instance v0, Ljava/util/ArrayList; invoke-direct {v0}, Ljava/util/ArrayList;->()V .line 36 iget-object v1, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v1}, Lcom/moji/statistics/AbsEventLogWriter;->getCache()Ljava/util/Vector; move-result-object v1 monitor-enter v1 .line 37 :try_start_0 iget-object v2, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v2}, Lcom/moji/statistics/AbsEventLogWriter;->getCache()Ljava/util/Vector; move-result-object v2 invoke-interface {v0, v2}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z .line 38 iget-object v2, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v2}, Lcom/moji/statistics/AbsEventLogWriter;->getCache()Ljava/util/Vector; move-result-object v2 invoke-virtual {v2}, Ljava/util/Vector;->clear()V .line 39 monitor-exit v1 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 .line 42 sget-object v2, Lcom/moji/statistics/AbsEventLogWriter;->FILE_LOCK:Ljava/lang/Object; monitor-enter v2 .line 43 :try_start_1 invoke-interface {v0}, Ljava/util/List;->isEmpty()Z move-result v1 if-nez v1, :cond_0 .line 44 iget-object v1, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v1, v0}, Lcom/moji/statistics/AbsEventLogWriter;->writeFile(Ljava/util/List;)Z :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :cond_0 const/4 v0, 0x0 .line 48 :try_start_2 new-instance v1, Ljava/io/File; iget-object v3, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v3}, Lcom/moji/statistics/AbsEventLogWriter;->getEventLogPath()Ljava/lang/String; move-result-object v3 const-string v4, "lla.log" invoke-direct {v1, v3, v4}, Ljava/io/File;->(Ljava/lang/String;Ljava/lang/String;)V .line 49 invoke-virtual {v1}, Ljava/io/File;->exists()Z move-result v3 if-eqz v3, :cond_3 const-wide/16 v3, 0x0 invoke-virtual {v1}, Ljava/io/File;->length()J move-result-wide v5 cmp-long v7, v3, v5 if-eqz v7, :cond_3 .line 50 new-instance v3, Ljava/io/File; iget-object v4, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v4}, Lcom/moji/statistics/AbsEventLogWriter;->getUploadEventLogPath()Ljava/lang/String; move-result-object v4 const-string v5, "lla.zip" invoke-direct {v3, v4, v5}, Ljava/io/File;->(Ljava/lang/String;Ljava/lang/String;)V :try_end_2 .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_2} :catch_1 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 51 :try_start_3 iget-object v0, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; invoke-virtual {v0, v1, v3}, Lcom/moji/statistics/AbsEventLogWriter;->zip(Ljava/io/File;Ljava/io/File;)Z move-result v0 if-eqz v0, :cond_2 .line 52 invoke-direct {p0, v3}, Lcom/moji/statistics/upload/UploadRunnable;->a(Ljava/io/File;)Z move-result v0 if-eqz v0, :cond_2 .line 53 invoke-virtual {v1}, Ljava/io/File;->delete()Z move-result v0 if-nez v0, :cond_1 const-string v0, "UploadRunnable" const-string v1, "old event log file delete failed after upload success" .line 54 invoke-static {v0, v1}, Lcom/moji/tool/log/MJLogger;->d(Ljava/lang/String;Ljava/lang/String;)V .line 56 :cond_1 new-instance v0, Lcom/moji/statistics/fliter/LogConfigPreferences; invoke-static {}, Lcom/moji/tool/AppDelegate;->a()Landroid/content/Context; move-result-object v1 invoke-direct {v0, v1}, Lcom/moji/statistics/fliter/LogConfigPreferences;->(Landroid/content/Context;)V .line 57 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v4 invoke-virtual {v0, v4, v5}, Lcom/moji/statistics/fliter/LogConfigPreferences;->a(J)V .line 60 :cond_2 invoke-virtual {v3}, Ljava/io/File;->delete()Z move-result v0 if-nez v0, :cond_3 const-string v0, "UploadRunnable" const-string v1, "old event log zip file delete failed" .line 61 invoke-static {v0, v1}, Lcom/moji/tool/log/MJLogger;->d(Ljava/lang/String;Ljava/lang/String;)V :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_0 .catchall {:try_start_3 .. :try_end_3} :catchall_0 goto :goto_1 :catch_0 move-exception v0 goto :goto_0 :catch_1 move-exception v1 move-object v3, v0 move-object v0, v1 :goto_0 :try_start_4 const-string v1, "UploadRunnable" .line 65 invoke-static {v1, v0}, Lcom/moji/tool/log/MJLogger;->a(Ljava/lang/String;Ljava/lang/Throwable;)V if-eqz v3, :cond_3 .line 67 invoke-virtual {v3}, Ljava/io/File;->delete()Z move-result v0 if-nez v0, :cond_3 const-string v0, "UploadRunnable" const-string v1, "old event log zip file delete failed after exception:" .line 68 invoke-static {v0, v1}, Lcom/moji/tool/log/MJLogger;->d(Ljava/lang/String;Ljava/lang/String;)V .line 72 :cond_3 :goto_1 monitor-exit v2 return-void :catchall_0 move-exception v0 monitor-exit v2 :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 throw v0 :catchall_1 move-exception v0 .line 39 :try_start_5 monitor-exit v1 :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 throw v0 .end method .method private a(Ljava/io/File;)Z .locals 1 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/Exception; } .end annotation .line 76 new-instance v0, Lcom/moji/http/upload/UploadLogFile; invoke-direct {v0, p1}, Lcom/moji/http/upload/UploadLogFile;->(Ljava/io/File;)V invoke-virtual {v0}, Lcom/moji/http/upload/UploadLogFile;->f()Ljava/lang/Object; move-result-object p1 check-cast p1, Ljava/lang/String; .line 77 invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result p1 xor-int/lit8 p1, p1, 0x1 return p1 .end method # virtual methods .method public run()V .locals 1 .line 27 invoke-static {}, Lcom/moji/statistics/EventWriterImpl;->getInstance()Lcom/moji/statistics/EventWriterImpl; move-result-object v0 iput-object v0, p0, Lcom/moji/statistics/upload/UploadRunnable;->a:Lcom/moji/statistics/AbsEventLogWriter; .line 28 invoke-direct {p0}, Lcom/moji/statistics/upload/UploadRunnable;->a()V return-void .end method