SimpleFileNameGenerator.smali

.class public Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;
.super Ljava/lang/Object;

# interfaces
.implements Lcom/cmcm/xiaobao/phone/commons/log/generator/FileNameGenerator;


# static fields
.field public static final MB:J = 0x100000L

.field private static final TYPE_TWO:I = 0x2


# instance fields
.field private mCurLogFile:Ljava/io/File;

.field private mFileName:Ljava/lang/String;

.field private mMaxLogSize:J


# direct methods
.method public constructor <init>(Ljava/lang/String;)V
    .registers 4

    const-wide/32 v0, 0x500000

    invoke-direct {p0, p1, v0, v1}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;-><init>(Ljava/lang/String;J)V

    return-void
.end method

.method public constructor <init>(Ljava/lang/String;J)V
    .registers 4

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

    iput-object p1, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mFileName:Ljava/lang/String;

    iput-wide p2, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mMaxLogSize:J

    return-void
.end method

.method static synthetic access$000(Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;)Ljava/lang/String;
    .registers 2

    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mFileName:Ljava/lang/String;

    return-object v0
.end method

.method private deleteExistLogFiles([Ljava/io/File;)V
    .registers 4

    array-length v0, p1

    const/4 v1, 0x2

    if-le v0, v1, :cond_a

    const/4 v0, 0x0

    aget-object v0, p1, v0

    invoke-virtual {v0}, Ljava/io/File;->delete()Z

    :cond_a
    return-void
.end method

.method private getCurLogFile(Ljava/io/File;)Ljava/io/File;
    .registers 8

    invoke-direct {p0, p1}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->getExistLogFiles(Ljava/io/File;)[Ljava/io/File;

    move-result-object v0

    invoke-direct {p0, v0}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->getCurLogFileIndex([Ljava/io/File;)I

    move-result v1

    invoke-direct {p0, v0}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->deleteExistLogFiles([Ljava/io/File;)V

    sget-object v0, Ljava/util/Locale;->CHINA:Ljava/util/Locale;

    const-string/jumbo v2, "%s.%d"

    const/4 v3, 0x2

    new-array v3, v3, [Ljava/lang/Object;

    const/4 v4, 0x0

    iget-object v5, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mFileName:Ljava/lang/String;

    aput-object v5, v3, v4

    const/4 v4, 0x1

    invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v1

    aput-object v1, v3, v4

    invoke-static {v0, v2, v3}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v0

    new-instance v1, Ljava/io/File;

    invoke-direct {v1, p1, v0}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V

    return-object v1
.end method

.method private getCurLogFileIndex([Ljava/io/File;)I
    .registers 8

    const/4 v0, 0x0

    :try_start_1
    array-length v1, p1

    if-lez v1, :cond_32

    array-length v1, p1

    add-int/lit8 v1, v1, -0x1

    aget-object v1, p1, v1

    invoke-virtual {v1}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v1

    const/16 v2, 0x2e

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

    move-result v2

    add-int/lit8 v2, v2, 0x1

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

    move-result-object v1

    invoke-static {v1}, Ljava/lang/Integer;->valueOf(Ljava/lang/String;)Ljava/lang/Integer;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/Integer;->intValue()I

    move-result v0

    array-length v1, p1

    add-int/lit8 v1, v1, -0x1

    aget-object v1, p1, v1

    invoke-virtual {v1}, Ljava/io/File;->length()J

    move-result-wide v2

    iget-wide v4, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mMaxLogSize:J
    :try_end_2c
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_2c} :catch_33

    cmp-long v1, v2, v4

    if-lez v1, :cond_32

    add-int/lit8 v0, v0, 0x1

    :cond_32
    :goto_32
    return v0

    :catch_33
    move-exception v1

    const-string/jumbo v2, "FileNameGenerator"

    const-string/jumbo v3, "Error!"

    invoke-static {v2, v3, v1}, Lcom/cmcm/xiaobao/phone/commons/log/LogUtil;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    goto :goto_32
.end method

.method private getExistLogFiles(Ljava/io/File;)[Ljava/io/File;
    .registers 4

    new-instance v0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator$1;

    invoke-direct {v0, p0}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator$1;-><init>(Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;)V

    invoke-virtual {p1, v0}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;

    move-result-object v0

    if-nez v0, :cond_f

    const/4 v0, 0x0

    new-array v0, v0, [Ljava/io/File;

    :goto_e
    return-object v0

    :cond_f
    new-instance v1, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator$2;

    invoke-direct {v1, p0}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator$2;-><init>(Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;)V

    invoke-static {v0, v1}, Ljava/util/Arrays;->sort([Ljava/lang/Object;Ljava/util/Comparator;)V

    goto :goto_e
.end method


# virtual methods
.method public generateFileName(Ljava/io/File;)Ljava/lang/String;
    .registers 6

    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mCurLogFile:Ljava/io/File;

    if-eqz v0, :cond_10

    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mCurLogFile:Ljava/io/File;

    invoke-virtual {v0}, Ljava/io/File;->length()J

    move-result-wide v0

    iget-wide v2, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mMaxLogSize:J

    cmp-long v0, v0, v2

    if-ltz v0, :cond_16

    :cond_10
    invoke-direct {p0, p1}, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->getCurLogFile(Ljava/io/File;)Ljava/io/File;

    move-result-object v0

    iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mCurLogFile:Ljava/io/File;

    :cond_16
    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/generator/SimpleFileNameGenerator;->mCurLogFile:Ljava/io/File;

    invoke-virtual {v0}, Ljava/io/File;->getName()Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method