标签:
.class public Lcom/SmaliInjector; .super Ljava/lang/Object; .source "SmaliInjector.java" # static fields .field private static tag:Ljava/lang/String; # direct methods .method static constructor <clinit>()V .locals 1 .prologue .line 7 const-string v0, "SmaliInjector" sput-object v0, Lcom/SmaliInjector;->tag:Ljava/lang/String; return-void .end method .method public constructor <init>()V .locals 0 .prologue .line 5 invoke-direct {p0}, Ljava/lang/Object;-><init>()V return-void .end method .method public static BytesToHexString([B)Ljava/lang/String; .locals 5 .param p0, "bytes" # [B .prologue .line 100 const-string v2, "" .line 101 .local v2, "result":Ljava/lang/String; const/4 v1, 0x0 .local v1, "i":I :goto_0 array-length v3, p0 if-lt v1, v3, :cond_0 .line 110 invoke-virtual {v2}, Ljava/lang/String;->toUpperCase()Ljava/lang/String; move-result-object v3 return-object v3 .line 103 :cond_0 aget-byte v3, p0, v1 and-int/lit16 v3, v3, 0xff invoke-static {v3}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String; move-result-object v0 .line 104 .local v0, "hex":Ljava/lang/String; invoke-virtual {v0}, Ljava/lang/String;->length()I move-result v3 const/4 v4, 0x1 if-ne v3, v4, :cond_1 .line 106 new-instance v3, Ljava/lang/StringBuilder; const/16 v4, 0x30 invoke-static {v4}, Ljava/lang/String;->valueOf(C)Ljava/lang/String; move-result-object v4 invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 .line 108 :cond_1 new-instance v3, Ljava/lang/StringBuilder; invoke-static {v2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v4 invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 const-string v4, " " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 .line 101 add-int/lit8 v1, v1, 0x1 goto :goto_0 .end method .method public static GetCaller()Ljava/lang/String; .locals 5 .prologue .line 142 :try_start_0 const-string v0, "" .line 143 .local v0, "caller":Ljava/lang/String; new-instance v3, Ljava/lang/Throwable; invoke-direct {v3}, Ljava/lang/Throwable;-><init>()V invoke-virtual {v3}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement; move-result-object v2 .line 144 .local v2, "stack":[Ljava/lang/StackTraceElement; new-instance v3, Ljava/lang/StringBuilder; const/4 v4, 0x2 aget-object v4, v2, v4 invoke-virtual {v4}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String; move-result-object v4 invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v4 invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v4, "." invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 const/4 v4, 0x2 aget-object v4, v2, v4 invoke-virtual {v4}, Ljava/lang/StackTraceElement;->getMethodName()Ljava/lang/String; move-result-object v4 invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v3 invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 move-result-object v0 .line 149 .end local v0 # "caller":Ljava/lang/String; .end local v2 # "stack":[Ljava/lang/StackTraceElement; :goto_0 return-object v0 .line 147 .restart local v0 # "caller":Ljava/lang/String; :catch_0 move-exception v1 .line 149 .local v1, "e":Ljava/lang/Exception; const-string v0, "can not get caller" goto :goto_0 .end method .method public static GetCallerStack()Ljava/lang/String; .locals 7 .prologue .line 122 :try_start_0 const-string v0, "" .line 123 .local v0, "caller":Ljava/lang/String; new-instance v5, Ljava/lang/Throwable; invoke-direct {v5}, Ljava/lang/Throwable;-><init>()V invoke-virtual {v5}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement; move-result-object v4 .line 124 .local v4, "stack":[Ljava/lang/StackTraceElement; const/4 v2, 0x1 .local v2, "i":I :goto_0 array-length v5, v4 if-lt v2, v5, :cond_0 .line 133 .end local v0 # "caller":Ljava/lang/String; .end local v2 # "i":I .end local v4 # "stack":[Ljava/lang/StackTraceElement; :goto_1 return-object v0 .line 126 .restart local v0 # "caller":Ljava/lang/String; .restart local v2 # "i":I .restart local v4 # "stack":[Ljava/lang/StackTraceElement; :cond_0 aget-object v3, v4, v2 .line 127 .local v3, "s":Ljava/lang/StackTraceElement; new-instance v5, Ljava/lang/StringBuilder; invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v6 invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v3}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String; move-result-object v6 invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v5 const-string v6, "." invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v5 invoke-virtual {v3}, Ljava/lang/StackTraceElement;->getMethodName()Ljava/lang/String; move-result-object v6 invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v5 const-string v6, ";" invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v5 invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 move-result-object v0 .line 124 add-int/lit8 v2, v2, 0x1 goto :goto_0 .line 131 .end local v2 # "i":I .end local v3 # "s":Ljava/lang/StackTraceElement; .end local v4 # "stack":[Ljava/lang/StackTraceElement; :catch_0 move-exception v1 .line 133 .local v1, "e":Ljava/lang/Exception; const-string v0, "can not get caller stack" goto :goto_1 .end method .method public static LogBytesValueWithMethodName(Ljava/lang/String;[B)V .locals 4 .param p0, "bytesVariableName" # Ljava/lang/String; .param p1, "bytes" # [B .prologue .line 86 invoke-static {}, Lcom/SmaliInjector;->GetCaller()Ljava/lang/String; move-result-object v1 .line 90 .local v1, "methodName":Ljava/lang/String; :try_start_0 new-instance v2, Ljava/lang/StringBuilder; invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v3 invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v3, " : " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, " = " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-static {p1}, Lcom/SmaliInjector;->BytesToHexString([B)Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 96 :goto_0 return-void .line 92 :catch_0 move-exception v0 .line 94 .local v0, "e":Ljava/lang/Exception; new-instance v2, Ljava/lang/StringBuilder; const-string v3, "error in LogStringValueWithMethodName. methodName: " invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", bytesVariableName: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", value: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static LogCallerStack()V .locals 1 .prologue .line 115 invoke-static {}, Lcom/SmaliInjector;->GetCallerStack()Ljava/lang/String; move-result-object v0 invoke-static {v0}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V .line 116 return-void .end method .method public static LogIntValue(Ljava/lang/String;I)V .locals 3 .param p0, "intVariableName" # Ljava/lang/String; .param p1, "value" # I .prologue .line 63 :try_start_0 new-instance v1, Ljava/lang/StringBuilder; invoke-static {p0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v2 invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v2, " = " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 69 :goto_0 return-void .line 65 :catch_0 move-exception v0 .line 67 .local v0, "e":Ljava/lang/Exception; new-instance v1, Ljava/lang/StringBuilder; const-string v2, "error in LogStringValue. intVariableName: " invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 const-string v2, ", value: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static LogIntValueWithMethodName(Ljava/lang/String;I)V .locals 4 .param p0, "intVariableName" # Ljava/lang/String; .param p1, "value" # I .prologue .line 73 invoke-static {}, Lcom/SmaliInjector;->GetCaller()Ljava/lang/String; move-result-object v1 .line 76 .local v1, "methodName":Ljava/lang/String; :try_start_0 new-instance v2, Ljava/lang/StringBuilder; invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v3 invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v3, " : " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, " = " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 82 :goto_0 return-void .line 78 :catch_0 move-exception v0 .line 80 .local v0, "e":Ljava/lang/Exception; new-instance v2, Ljava/lang/StringBuilder; const-string v3, "error in LogStringValueWithMethodName. methodName: " invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", intVariableName: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", value: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static LogMethodMsg(Ljava/lang/String;)V .locals 4 .param p0, "msg" # Ljava/lang/String; .prologue .line 23 invoke-static {}, Lcom/SmaliInjector;->GetCaller()Ljava/lang/String; move-result-object v1 .line 26 .local v1, "methodName":Ljava/lang/String; :try_start_0 new-instance v2, Ljava/lang/StringBuilder; invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v3 invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v3, " : " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 32 :goto_0 return-void .line 28 :catch_0 move-exception v0 .line 30 .local v0, "e":Ljava/lang/Exception; new-instance v2, Ljava/lang/StringBuilder; const-string v3, "error in LogMethodMsg. methodName: " invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", msg: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static LogMsg(Ljava/lang/String;)V .locals 3 .param p0, "msg" # Ljava/lang/String; .prologue .line 13 :try_start_0 invoke-static {p0}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 19 :goto_0 return-void .line 15 :catch_0 move-exception v0 .line 17 .local v0, "e":Ljava/lang/Exception; new-instance v1, Ljava/lang/StringBuilder; const-string v2, "error in LogMsg. error: " invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static LogStringValue(Ljava/lang/String;Ljava/lang/String;)V .locals 3 .param p0, "stringVariableName" # Ljava/lang/String; .param p1, "value" # Ljava/lang/String; .prologue .line 38 :try_start_0 new-instance v1, Ljava/lang/StringBuilder; invoke-static {p0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v2 invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v2, " = " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 44 :goto_0 return-void .line 40 :catch_0 move-exception v0 .line 42 .local v0, "e":Ljava/lang/Exception; new-instance v1, Ljava/lang/StringBuilder; const-string v2, "error in LogStringValue. stringVariableName: " invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 const-string v2, ", value: " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v2 invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v1 invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static LogStringValueWithMethodName(Ljava/lang/String;Ljava/lang/String;)V .locals 4 .param p0, "stringVariableName" # Ljava/lang/String; .param p1, "value" # Ljava/lang/String; .prologue .line 48 invoke-static {}, Lcom/SmaliInjector;->GetCaller()Ljava/lang/String; move-result-object v1 .line 51 .local v1, "methodName":Ljava/lang/String; :try_start_0 new-instance v2, Ljava/lang/StringBuilder; invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v3 invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V const-string v3, " : " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, " = " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .line 57 :goto_0 return-void .line 53 :catch_0 move-exception v0 .line 55 .local v0, "e":Ljava/lang/Exception; new-instance v2, Ljava/lang/StringBuilder; const-string v3, "error in LogStringValueWithMethodName. methodName: " invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", stringVariableName: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 const-string v3, ", value: " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String; move-result-object v3 invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v2}, Lcom/SmaliInjector;->log(Ljava/lang/String;)V goto :goto_0 .end method .method public static log(Ljava/lang/String;)V .locals 1 .param p0, "msg" # Ljava/lang/String; .prologue .line 155 sget-object v0, Lcom/SmaliInjector;->tag:Ljava/lang/String; invoke-static {v0, p0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I .line 156 return-void .end method
标签:
原文地址:http://www.cnblogs.com/xunbu7/p/4468753.html