.class Lcom/google/firebase/components/CycleDetector; .super Ljava/lang/Object; .source "CycleDetector.java" # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/google/firebase/components/CycleDetector$ComponentNode;, Lcom/google/firebase/components/CycleDetector$Dep; } .end annotation # direct methods .method public constructor ()V .locals 0 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V return-void .end method .method public static detect(Ljava/util/List;)V .locals 7 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/List<", "Lcom/google/firebase/components/Component<", "*>;>;)V" } .end annotation .line 1 invoke-static {p0}, Lcom/google/firebase/components/CycleDetector;->toGraph(Ljava/util/List;)Ljava/util/Set; move-result-object v0 .line 2 invoke-static {v0}, Lcom/google/firebase/components/CycleDetector;->getRoots(Ljava/util/Set;)Ljava/util/Set; move-result-object v1 const/4 v2, 0x0 .line 3 :cond_0 invoke-interface {v1}, Ljava/util/Set;->isEmpty()Z move-result v3 if-nez v3, :cond_2 .line 4 invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v3 invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v3 check-cast v3, Lcom/google/firebase/components/CycleDetector$ComponentNode; .line 5 invoke-interface {v1, v3}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z add-int/lit8 v2, v2, 0x1 .line 6 invoke-virtual {v3}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->getDependencies()Ljava/util/Set; move-result-object v4 invoke-interface {v4}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v4 :cond_1 :goto_0 invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z move-result v5 if-eqz v5, :cond_0 invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v5 check-cast v5, Lcom/google/firebase/components/CycleDetector$ComponentNode; .line 7 invoke-virtual {v5, v3}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->removeDependent(Lcom/google/firebase/components/CycleDetector$ComponentNode;)V .line 8 invoke-virtual {v5}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->isRoot()Z move-result v6 if-eqz v6, :cond_1 .line 9 invoke-interface {v1, v5}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_0 .line 10 :cond_2 invoke-interface {p0}, Ljava/util/List;->size()I move-result p0 if-ne v2, p0, :cond_3 return-void .line 11 :cond_3 new-instance p0, Ljava/util/ArrayList; invoke-direct {p0}, Ljava/util/ArrayList;->()V .line 12 invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v0 :cond_4 :goto_1 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_5 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/google/firebase/components/CycleDetector$ComponentNode; .line 13 invoke-virtual {v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->isRoot()Z move-result v2 if-nez v2, :cond_4 invoke-virtual {v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->isLeaf()Z move-result v2 if-nez v2, :cond_4 .line 14 invoke-virtual {v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->getComponent()Lcom/google/firebase/components/Component; move-result-object v1 invoke-virtual {p0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z goto :goto_1 .line 15 :cond_5 new-instance v0, Lcom/google/firebase/components/DependencyCycleException; invoke-direct {v0, p0}, Lcom/google/firebase/components/DependencyCycleException;->(Ljava/util/List;)V throw v0 .end method .method private static getRoots(Ljava/util/Set;)Ljava/util/Set; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Set<", "Lcom/google/firebase/components/CycleDetector$ComponentNode;", ">;)", "Ljava/util/Set<", "Lcom/google/firebase/components/CycleDetector$ComponentNode;", ">;" } .end annotation .line 1 new-instance v0, Ljava/util/HashSet; invoke-direct {v0}, Ljava/util/HashSet;->()V .line 2 invoke-interface {p0}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object p0 :cond_0 :goto_0 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_1 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/google/firebase/components/CycleDetector$ComponentNode; .line 3 invoke-virtual {v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->isRoot()Z move-result v2 if-eqz v2, :cond_0 .line 4 invoke-virtual {v0, v1}, Ljava/util/HashSet;->add(Ljava/lang/Object;)Z goto :goto_0 :cond_1 return-object v0 .end method .method private static toGraph(Ljava/util/List;)Ljava/util/Set; .locals 10 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/List<", "Lcom/google/firebase/components/Component<", "*>;>;)", "Ljava/util/Set<", "Lcom/google/firebase/components/CycleDetector$ComponentNode;", ">;" } .end annotation .line 1 new-instance v0, Ljava/util/HashMap; invoke-interface {p0}, Ljava/util/List;->size()I move-result v1 invoke-direct {v0, v1}, Ljava/util/HashMap;->(I)V .line 2 invoke-interface {p0}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p0 :cond_0 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v1 const/4 v2, 0x0 if-eqz v1, :cond_4 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/google/firebase/components/Component; .line 3 new-instance v3, Lcom/google/firebase/components/CycleDetector$ComponentNode; invoke-direct {v3, v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->(Lcom/google/firebase/components/Component;)V .line 4 invoke-virtual {v1}, Lcom/google/firebase/components/Component;->getProvidedInterfaces()Ljava/util/Set; move-result-object v4 invoke-interface {v4}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v4 :goto_0 invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z move-result v5 if-eqz v5, :cond_0 invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v5 check-cast v5, Ljava/lang/Class; .line 5 new-instance v6, Lcom/google/firebase/components/CycleDetector$Dep; invoke-virtual {v1}, Lcom/google/firebase/components/Component;->isValue()Z move-result v7 const/4 v8, 0x1 xor-int/2addr v7, v8 invoke-direct {v6, v5, v7, v2}, Lcom/google/firebase/components/CycleDetector$Dep;->(Ljava/lang/Class;ZLcom/google/firebase/components/CycleDetector$1;)V .line 6 invoke-virtual {v0, v6}, Ljava/util/HashMap;->containsKey(Ljava/lang/Object;)Z move-result v7 if-nez v7, :cond_1 .line 7 new-instance v7, Ljava/util/HashSet; invoke-direct {v7}, Ljava/util/HashSet;->()V invoke-virtual {v0, v6, v7}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 8 :cond_1 invoke-virtual {v0, v6}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v7 check-cast v7, Ljava/util/Set; .line 9 invoke-interface {v7}, Ljava/util/Set;->isEmpty()Z move-result v9 if-nez v9, :cond_3 invoke-static {v6}, Lcom/google/firebase/components/CycleDetector$Dep;->access$100(Lcom/google/firebase/components/CycleDetector$Dep;)Z move-result v6 if-eqz v6, :cond_2 goto :goto_1 .line 10 :cond_2 new-instance p0, Ljava/lang/IllegalArgumentException; new-array v0, v8, [Ljava/lang/Object; const/4 v1, 0x0 aput-object v5, v0, v1 const-string v1, "Multiple components provide %s." .line 11 invoke-static {v1, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object v0 invoke-direct {p0, v0}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p0 .line 12 :cond_3 :goto_1 invoke-interface {v7, v3}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_0 .line 13 :cond_4 invoke-virtual {v0}, Ljava/util/HashMap;->values()Ljava/util/Collection; move-result-object p0 invoke-interface {p0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator; move-result-object p0 :cond_5 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_a invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/util/Set; .line 14 invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v1 :cond_6 invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z move-result v3 if-eqz v3, :cond_5 invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v3 check-cast v3, Lcom/google/firebase/components/CycleDetector$ComponentNode; .line 15 invoke-virtual {v3}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->getComponent()Lcom/google/firebase/components/Component; move-result-object v4 invoke-virtual {v4}, Lcom/google/firebase/components/Component;->getDependencies()Ljava/util/Set; move-result-object v4 invoke-interface {v4}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v4 :cond_7 :goto_2 invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z move-result v5 if-eqz v5, :cond_6 invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v5 check-cast v5, Lcom/google/firebase/components/Dependency; .line 16 invoke-virtual {v5}, Lcom/google/firebase/components/Dependency;->isDirectInjection()Z move-result v6 if-nez v6, :cond_8 goto :goto_2 .line 17 :cond_8 new-instance v6, Lcom/google/firebase/components/CycleDetector$Dep; .line 18 invoke-virtual {v5}, Lcom/google/firebase/components/Dependency;->getInterface()Ljava/lang/Class; move-result-object v7 invoke-virtual {v5}, Lcom/google/firebase/components/Dependency;->isSet()Z move-result v5 invoke-direct {v6, v7, v5, v2}, Lcom/google/firebase/components/CycleDetector$Dep;->(Ljava/lang/Class;ZLcom/google/firebase/components/CycleDetector$1;)V invoke-virtual {v0, v6}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v5 check-cast v5, Ljava/util/Set; if-nez v5, :cond_9 goto :goto_2 .line 19 :cond_9 invoke-interface {v5}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object v5 :goto_3 invoke-interface {v5}, Ljava/util/Iterator;->hasNext()Z move-result v6 if-eqz v6, :cond_7 invoke-interface {v5}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v6 check-cast v6, Lcom/google/firebase/components/CycleDetector$ComponentNode; .line 20 invoke-virtual {v3, v6}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->addDependency(Lcom/google/firebase/components/CycleDetector$ComponentNode;)V .line 21 invoke-virtual {v6, v3}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->addDependent(Lcom/google/firebase/components/CycleDetector$ComponentNode;)V goto :goto_3 .line 22 :cond_a new-instance p0, Ljava/util/HashSet; invoke-direct {p0}, Ljava/util/HashSet;->()V .line 23 invoke-virtual {v0}, Ljava/util/HashMap;->values()Ljava/util/Collection; move-result-object v0 invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator; move-result-object v0 :goto_4 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_b invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/util/Set; .line 24 invoke-virtual {p0, v1}, Ljava/util/HashSet;->addAll(Ljava/util/Collection;)Z goto :goto_4 :cond_b return-object p0 .end method