zzgy.smali

.class public final Lcom/google/android/gms/internal/firebase_ml/zzgy;
.super Ljava/lang/Object;


# static fields
.field private static final zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

.field private static zzsy:Lcom/google/android/gms/internal/firebase_ml/zzgy;


# instance fields
.field private final zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

.field private zzsu:J

.field private final zzsv:Ljava/util/Set;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Set",
            "<",
            "Lcom/google/android/gms/internal/firebase_ml/zzgx;",
            ">;"
        }
    .end annotation
.end field

.field final zzsw:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map",
            "<",
            "Lcom/google/android/gms/internal/firebase_ml/zzgx;",
            "Lcom/google/android/gms/tasks/Task",
            "<",
            "Ljava/lang/Void;",
            ">;>;"
        }
    .end annotation
.end field

.field private final zzsx:Ljava/util/concurrent/ConcurrentHashMap;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/ConcurrentHashMap",
            "<",
            "Lcom/google/android/gms/internal/firebase_ml/zzgx;",
            "Lcom/google/android/gms/internal/firebase_ml/zzha;",
            ">;"
        }
    .end annotation
.end field


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

    new-instance v0, Lcom/google/android/gms/common/internal/GmsLogger;

    const-string v1, "ModelResourceManager"

    const-string v2, ""

    invoke-direct {v0, v1, v2}, Lcom/google/android/gms/common/internal/GmsLogger;-><init>(Ljava/lang/String;Ljava/lang/String;)V

    sput-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

    return-void
.end method

.method private constructor <init>(Lcom/google/firebase/a;)V
    .registers 5

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

    invoke-static {}, Lcom/google/android/gms/internal/firebase_ml/zzgp;->zzex()Lcom/google/android/gms/internal/firebase_ml/zzgp;

    move-result-object v0

    iput-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

    const-wide/32 v0, 0x493e0

    iput-wide v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsu:J

    new-instance v0, Ljava/util/HashSet;

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

    iput-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsv:Ljava/util/Set;

    new-instance v0, Ljava/util/HashMap;

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

    iput-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V

    iput-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsx:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-virtual {p1}, Lcom/google/firebase/a;->getApplicationContext()Landroid/content/Context;

    move-result-object v0

    if-eqz v0, :cond_56

    invoke-virtual {p1}, Lcom/google/firebase/a;->getApplicationContext()Landroid/content/Context;

    move-result-object v0

    instance-of v0, v0, Landroid/app/Application;

    if-eqz v0, :cond_56

    invoke-virtual {p1}, Lcom/google/firebase/a;->getApplicationContext()Landroid/content/Context;

    move-result-object v0

    check-cast v0, Landroid/app/Application;

    invoke-static {v0}, Lcom/google/android/gms/common/api/internal/BackgroundDetector;->initialize(Landroid/app/Application;)V

    :goto_3a
    invoke-static {}, Lcom/google/android/gms/common/api/internal/BackgroundDetector;->getInstance()Lcom/google/android/gms/common/api/internal/BackgroundDetector;

    move-result-object v0

    new-instance v1, Lcom/google/android/gms/internal/firebase_ml/zzgz;

    invoke-direct {v1, p0}, Lcom/google/android/gms/internal/firebase_ml/zzgz;-><init>(Lcom/google/android/gms/internal/firebase_ml/zzgy;)V

    invoke-virtual {v0, v1}, Lcom/google/android/gms/common/api/internal/BackgroundDetector;->addListener(Lcom/google/android/gms/common/api/internal/BackgroundDetector$BackgroundStateChangeListener;)V

    invoke-static {}, Lcom/google/android/gms/common/api/internal/BackgroundDetector;->getInstance()Lcom/google/android/gms/common/api/internal/BackgroundDetector;

    move-result-object v0

    const/4 v1, 0x1

    invoke-virtual {v0, v1}, Lcom/google/android/gms/common/api/internal/BackgroundDetector;->readCurrentStateIfPossible(Z)Z

    move-result v0

    if-eqz v0, :cond_55

    const-wide/16 v0, 0x7d0

    iput-wide v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsu:J

    :cond_55
    return-void

    :cond_56
    sget-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

    const-string v1, "ModelResourceManager"

    const-string v2, "No valid Application available and auto-manage cannot work"

    invoke-virtual {v0, v1, v2}, Lcom/google/android/gms/common/internal/GmsLogger;->e(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_3a
.end method

.method static synthetic zza(Lcom/google/android/gms/internal/firebase_ml/zzgy;J)J
    .registers 4

    iput-wide p1, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsu:J

    return-wide p1
.end method

.method static synthetic zza(Lcom/google/android/gms/internal/firebase_ml/zzgy;)V
    .registers 1

    invoke-direct {p0}, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzez()V

    return-void
.end method

.method public static declared-synchronized zzb(Lcom/google/firebase/a;)Lcom/google/android/gms/internal/firebase_ml/zzgy;
    .registers 3

    const-class v1, Lcom/google/android/gms/internal/firebase_ml/zzgy;

    monitor-enter v1

    :try_start_3
    sget-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsy:Lcom/google/android/gms/internal/firebase_ml/zzgy;

    if-nez v0, :cond_e

    new-instance v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;

    invoke-direct {v0, p0}, Lcom/google/android/gms/internal/firebase_ml/zzgy;-><init>(Lcom/google/firebase/a;)V

    sput-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsy:Lcom/google/android/gms/internal/firebase_ml/zzgy;

    :cond_e
    sget-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsy:Lcom/google/android/gms/internal/firebase_ml/zzgy;
    :try_end_10
    .catchall {:try_start_3 .. :try_end_10} :catchall_12

    monitor-exit v1

    return-object v0

    :catchall_12
    move-exception v0

    monitor-exit v1

    throw v0
.end method

.method private final zzc(Lcom/google/android/gms/internal/firebase_ml/zzgx;)V
    .registers 9

    invoke-direct {p0, p1}, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zze(Lcom/google/android/gms/internal/firebase_ml/zzgx;)Lcom/google/android/gms/internal/firebase_ml/zzha;

    move-result-object v0

    iget-object v1, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

    invoke-virtual {v1, v0}, Lcom/google/android/gms/internal/firebase_ml/zzgp;->zzb(Ljava/util/concurrent/Callable;)V

    sget-object v1, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

    const-string v2, "ModelResourceManager"

    iget-wide v4, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsu:J

    const/16 v3, 0x3d

    new-instance v6, Ljava/lang/StringBuilder;

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

    const-string v3, "Reschulding modelResource release after: "

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

    move-result-object v3

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

    move-result-object v3

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

    move-result-object v3

    invoke-virtual {v1, v2, v3}, Lcom/google/android/gms/common/internal/GmsLogger;->v(Ljava/lang/String;Ljava/lang/String;)V

    iget-object v1, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

    iget-wide v2, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsu:J

    invoke-virtual {v1, v0, v2, v3}, Lcom/google/android/gms/internal/firebase_ml/zzgp;->zza(Ljava/util/concurrent/Callable;J)V

    return-void
.end method

.method private final zze(Lcom/google/android/gms/internal/firebase_ml/zzgx;)Lcom/google/android/gms/internal/firebase_ml/zzha;
    .registers 5

    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsx:Ljava/util/concurrent/ConcurrentHashMap;

    new-instance v1, Lcom/google/android/gms/internal/firebase_ml/zzha;

    const-string v2, "OPERATION_RELEASE"

    invoke-direct {v1, p0, p1, v2}, Lcom/google/android/gms/internal/firebase_ml/zzha;-><init>(Lcom/google/android/gms/internal/firebase_ml/zzgy;Lcom/google/android/gms/internal/firebase_ml/zzgx;Ljava/lang/String;)V

    invoke-virtual {v0, p1, v1}, Ljava/util/concurrent/ConcurrentHashMap;->putIfAbsent(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsx:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-virtual {v0, p1}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/internal/firebase_ml/zzha;

    return-object v0
.end method

.method private final declared-synchronized zzez()V
    .registers 3

    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsv:Ljava/util/Set;

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

    move-result-object v1

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

    move-result v0

    if-eqz v0, :cond_1a

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

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/internal/firebase_ml/zzgx;

    invoke-direct {p0, v0}, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzc(Lcom/google/android/gms/internal/firebase_ml/zzgx;)V
    :try_end_16
    .catchall {:try_start_1 .. :try_end_16} :catchall_17

    goto :goto_7

    :catchall_17
    move-exception v0

    monitor-exit p0

    throw v0

    :cond_1a
    monitor-exit p0

    return-void
.end method

.method static synthetic zzfa()Lcom/google/android/gms/common/internal/GmsLogger;
    .registers 1

    sget-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

    return-object v0
.end method


# virtual methods
.method public final declared-synchronized zza(Lcom/google/android/gms/internal/firebase_ml/zzgx;)V
    .registers 5

    monitor-enter p0

    :try_start_1
    const-string v0, "Model source can not be null"

    invoke-static {p1, v0}, Lcom/google/android/gms/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    sget-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

    const-string v1, "ModelResourceManager"

    const-string v2, "Add auto-managed model resource"

    invoke-virtual {v0, v1, v2}, Lcom/google/android/gms/common/internal/GmsLogger;->d(Ljava/lang/String;Ljava/lang/String;)V

    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsv:Ljava/util/Set;

    invoke-interface {v0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_22

    sget-object v0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsa:Lcom/google/android/gms/common/internal/GmsLogger;

    const-string v1, "ModelResourceManager"

    const-string v2, "The model resource is already registered."

    invoke-virtual {v0, v1, v2}, Lcom/google/android/gms/common/internal/GmsLogger;->i(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_20
    .catchall {:try_start_1 .. :try_end_20} :catchall_2b

    :goto_20
    monitor-exit p0

    return-void

    :cond_22
    :try_start_22
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsv:Ljava/util/Set;

    invoke-interface {v0, p1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z

    invoke-virtual {p0, p1}, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzb(Lcom/google/android/gms/internal/firebase_ml/zzgx;)Lcom/google/android/gms/tasks/Task;
    :try_end_2a
    .catchall {:try_start_22 .. :try_end_2a} :catchall_2b

    goto :goto_20

    :catchall_2b
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method final declared-synchronized zzb(Lcom/google/android/gms/internal/firebase_ml/zzgx;)Lcom/google/android/gms/tasks/Task;
    .registers 5
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Lcom/google/android/gms/internal/firebase_ml/zzgx;",
            ")",
            "Lcom/google/android/gms/tasks/Task",
            "<",
            "Ljava/lang/Void;",
            ">;"
        }
    .end annotation

    monitor-enter p0

    if-nez p1, :cond_a

    const/4 v0, 0x0

    :try_start_4
    invoke-static {v0}, Lcom/google/android/gms/tasks/Tasks;->forResult(Ljava/lang/Object;)Lcom/google/android/gms/tasks/Task;
    :try_end_7
    .catchall {:try_start_4 .. :try_end_7} :catchall_46

    move-result-object v0

    :goto_8
    monitor-exit p0

    return-object v0

    :cond_a
    :try_start_a
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_20

    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/tasks/Task;

    invoke-virtual {v0}, Lcom/google/android/gms/tasks/Task;->getException()Ljava/lang/Exception;

    move-result-object v0

    if-eqz v0, :cond_32

    :cond_20
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

    new-instance v1, Lcom/google/android/gms/internal/firebase_ml/zzha;

    const-string v2, "OPERATION_LOAD"

    invoke-direct {v1, p0, p1, v2}, Lcom/google/android/gms/internal/firebase_ml/zzha;-><init>(Lcom/google/android/gms/internal/firebase_ml/zzgy;Lcom/google/android/gms/internal/firebase_ml/zzgx;Ljava/lang/String;)V

    invoke-virtual {v0, v1}, Lcom/google/android/gms/internal/firebase_ml/zzgp;->zza(Ljava/util/concurrent/Callable;)Lcom/google/android/gms/tasks/Task;

    move-result-object v0

    iget-object v1, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v1, p1, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    :cond_32
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsv:Ljava/util/Set;

    invoke-interface {v0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_3d

    invoke-direct {p0, p1}, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzc(Lcom/google/android/gms/internal/firebase_ml/zzgx;)V

    :cond_3d
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/tasks/Task;
    :try_end_45
    .catchall {:try_start_a .. :try_end_45} :catchall_46

    goto :goto_8

    :catchall_46
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method final declared-synchronized zzd(Lcom/google/android/gms/internal/firebase_ml/zzgx;)V
    .registers 6

    monitor-enter p0

    if-eqz p1, :cond_b

    :try_start_3
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
    :try_end_8
    .catchall {:try_start_3 .. :try_end_8} :catchall_1e

    move-result v0

    if-nez v0, :cond_d

    :cond_b
    :goto_b
    monitor-exit p0

    return-void

    :cond_d
    :try_start_d
    invoke-direct {p0, p1}, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zze(Lcom/google/android/gms/internal/firebase_ml/zzgx;)Lcom/google/android/gms/internal/firebase_ml/zzha;

    move-result-object v0

    iget-object v1, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

    invoke-virtual {v1, v0}, Lcom/google/android/gms/internal/firebase_ml/zzgp;->zzb(Ljava/util/concurrent/Callable;)V

    iget-object v1, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzst:Lcom/google/android/gms/internal/firebase_ml/zzgp;

    const-wide/16 v2, 0x0

    invoke-virtual {v1, v0, v2, v3}, Lcom/google/android/gms/internal/firebase_ml/zzgp;->zza(Ljava/util/concurrent/Callable;J)V
    :try_end_1d
    .catchall {:try_start_d .. :try_end_1d} :catchall_1e

    goto :goto_b

    :catchall_1e
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method final declared-synchronized zzf(Lcom/google/android/gms/internal/firebase_ml/zzgx;)V
    .registers 6

    monitor-enter p0

    if-nez p1, :cond_5

    :cond_3
    monitor-exit p0

    return-void

    :cond_5
    :try_start_5
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z

    move-result v0

    if-nez v0, :cond_1a

    new-instance v0, Lcom/google/firebase/ml/common/FirebaseMLException;

    const-string v1, "The task should be loaded first"

    const/16 v2, 0xd

    invoke-direct {v0, v1, v2}, Lcom/google/firebase/ml/common/FirebaseMLException;-><init>(Ljava/lang/String;I)V

    throw v0
    :try_end_17
    .catchall {:try_start_5 .. :try_end_17} :catchall_17

    :catchall_17
    move-exception v0

    monitor-exit p0

    throw v0

    :cond_1a
    :try_start_1a
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/tasks/Task;

    invoke-virtual {v0}, Lcom/google/android/gms/tasks/Task;->isComplete()Z

    move-result v0

    if-nez v0, :cond_32

    new-instance v0, Lcom/google/firebase/ml/common/FirebaseMLException;

    const-string v1, "The load task should already finished"

    const/16 v2, 0xd

    invoke-direct {v0, v1, v2}, Lcom/google/firebase/ml/common/FirebaseMLException;-><init>(Ljava/lang/String;I)V

    throw v0

    :cond_32
    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/tasks/Task;

    invoke-virtual {v0}, Lcom/google/android/gms/tasks/Task;->isSuccessful()Z

    move-result v0

    if-nez v0, :cond_3

    new-instance v1, Lcom/google/firebase/ml/common/FirebaseMLException;

    const-string v2, "The load task failed"

    const/16 v3, 0xd

    iget-object v0, p0, Lcom/google/android/gms/internal/firebase_ml/zzgy;->zzsw:Ljava/util/Map;

    invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/google/android/gms/tasks/Task;

    invoke-virtual {v0}, Lcom/google/android/gms/tasks/Task;->getException()Ljava/lang/Exception;

    move-result-object v0

    invoke-direct {v1, v2, v3, v0}, Lcom/google/firebase/ml/common/FirebaseMLException;-><init>(Ljava/lang/String;ILjava/lang/Throwable;)V

    throw v1
    :try_end_56
    .catchall {:try_start_1a .. :try_end_56} :catchall_17
.end method