.class public abstract Lcom/google/firebase/components/CycleDetector; .super Ljava/lang/Object; .source "SourceFile" # 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 static detect(Ljava/util/List;)V .locals 7 .line 100 invoke-static {p0}, Lcom/google/firebase/components/CycleDetector;->toGraph(Ljava/util/List;)Ljava/util/Set; move-result-object v0 .line 101 invoke-static {v0}, Lcom/google/firebase/components/CycleDetector;->getRoots(Ljava/util/Set;)Ljava/util/Set; move-result-object v1 const/4 v2, 0x0 .line 104 :cond_0 invoke-interface {v1}, Ljava/util/Set;->isEmpty()Z move-result v3 if-nez v3, :cond_2 .line 105 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 106 invoke-interface {v1, v3}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z add-int/lit8 v2, v2, 0x1 .line 109 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 110 invoke-virtual {v5, v3}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->removeDependent(Lcom/google/firebase/components/CycleDetector$ComponentNode;)V .line 111 invoke-virtual {v5}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->isRoot()Z move-result v6 if-eqz v6, :cond_1 .line 112 invoke-interface {v1, v5}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_0 .line 119 :cond_2 invoke-interface {p0}, Ljava/util/List;->size()I move-result p0 if-ne v2, p0, :cond_3 return-void .line 124 :cond_3 new-instance p0, Ljava/util/ArrayList; invoke-direct {p0}, Ljava/util/ArrayList;->()V .line 125 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 126 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 127 invoke-virtual {v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->getComponent()Lcom/google/firebase/components/Component; move-result-object v1 invoke-interface {p0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z goto :goto_1 .line 131 :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 public static getRoots(Ljava/util/Set;)Ljava/util/Set; .locals 3 .line 182 new-instance v0, Ljava/util/HashSet; invoke-direct {v0}, Ljava/util/HashSet;->()V .line 183 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 184 invoke-virtual {v1}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->isRoot()Z move-result v2 if-eqz v2, :cond_0 .line 185 invoke-interface {v0, v1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_0 :cond_1 return-object v0 .end method .method public static toGraph(Ljava/util/List;)Ljava/util/Set; .locals 9 .line 135 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 136 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 137 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 138 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, Lcom/google/firebase/components/Qualified; .line 139 new-instance v6, Lcom/google/firebase/components/CycleDetector$Dep; invoke-virtual {v1}, Lcom/google/firebase/components/Component;->isValue()Z move-result v7 xor-int/lit8 v7, v7, 0x1 invoke-direct {v6, v5, v7, v2}, Lcom/google/firebase/components/CycleDetector$Dep;->(Lcom/google/firebase/components/Qualified;ZLcom/google/firebase/components/CycleDetector$1;)V .line 140 invoke-interface {v0, v6}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z move-result v7 if-nez v7, :cond_1 .line 141 new-instance v7, Ljava/util/HashSet; invoke-direct {v7}, Ljava/util/HashSet;->()V invoke-interface {v0, v6, v7}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 143 :cond_1 invoke-interface {v0, v6}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v7 check-cast v7, Ljava/util/Set; .line 144 invoke-interface {v7}, Ljava/util/Set;->isEmpty()Z move-result v8 if-nez v8, :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 145 :cond_2 new-instance p0, Ljava/lang/IllegalArgumentException; const-string v0, "Multiple components provide %s." filled-new-array {v5}, [Ljava/lang/Object; move-result-object v1 .line 146 invoke-static {v0, v1}, 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 148 :cond_3 :goto_1 invoke-interface {v7, v3}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_0 .line 152 :cond_4 invoke-interface {v0}, Ljava/util/Map;->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 153 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 154 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 155 invoke-virtual {v5}, Lcom/google/firebase/components/Dependency;->isDirectInjection()Z move-result v6 if-nez v6, :cond_8 goto :goto_2 .line 159 :cond_8 new-instance v6, Lcom/google/firebase/components/CycleDetector$Dep; .line 160 invoke-virtual {v5}, Lcom/google/firebase/components/Dependency;->getInterface()Lcom/google/firebase/components/Qualified; 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;->(Lcom/google/firebase/components/Qualified;ZLcom/google/firebase/components/CycleDetector$1;)V invoke-interface {v0, v6}, Ljava/util/Map;->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 164 :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 165 invoke-virtual {v3, v6}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->addDependency(Lcom/google/firebase/components/CycleDetector$ComponentNode;)V .line 166 invoke-virtual {v6, v3}, Lcom/google/firebase/components/CycleDetector$ComponentNode;->addDependent(Lcom/google/firebase/components/CycleDetector$ComponentNode;)V goto :goto_3 .line 172 :cond_a new-instance p0, Ljava/util/HashSet; invoke-direct {p0}, Ljava/util/HashSet;->()V .line 173 invoke-interface {v0}, Ljava/util/Map;->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 174 invoke-virtual {p0, v1}, Ljava/util/AbstractCollection;->addAll(Ljava/util/Collection;)Z goto :goto_4 :cond_b return-object p0 .end method