.class final Lcom/google/common/collect/TreeTraverser$PostOrderIterator; .super Lcom/google/common/collect/AbstractIterator; .source "TreeTraverser.java" # annotations .annotation system Ldalvik/annotation/EnclosingClass; value = Lcom/google/common/collect/TreeTraverser; .end annotation .annotation system Ldalvik/annotation/InnerClass; accessFlags = 0x11 name = "PostOrderIterator" .end annotation .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/collect/AbstractIterator<", "TT;>;" } .end annotation # instance fields .field private final stack:Ljava/util/ArrayDeque; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/ArrayDeque<", "Lcom/google/common/collect/TreeTraverser$PostOrderNode<", "TT;>;>;" } .end annotation .end field .field public final synthetic this$0:Lcom/google/common/collect/TreeTraverser; # direct methods .method public constructor (Lcom/google/common/collect/TreeTraverser;Ljava/lang/Object;)V .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(TT;)V" } .end annotation .line 1 iput-object p1, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->this$0:Lcom/google/common/collect/TreeTraverser; invoke-direct {p0}, Lcom/google/common/collect/AbstractIterator;->()V .line 2 new-instance p1, Ljava/util/ArrayDeque; invoke-direct {p1}, Ljava/util/ArrayDeque;->()V iput-object p1, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->stack:Ljava/util/ArrayDeque; .line 3 invoke-direct {p0, p2}, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->expand(Ljava/lang/Object;)Lcom/google/common/collect/TreeTraverser$PostOrderNode; move-result-object p2 invoke-virtual {p1, p2}, Ljava/util/ArrayDeque;->addLast(Ljava/lang/Object;)V return-void .end method .method private expand(Ljava/lang/Object;)Lcom/google/common/collect/TreeTraverser$PostOrderNode; .locals 2 .annotation system Ldalvik/annotation/Signature; value = { "(TT;)", "Lcom/google/common/collect/TreeTraverser$PostOrderNode<", "TT;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeTraverser$PostOrderNode; iget-object v1, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->this$0:Lcom/google/common/collect/TreeTraverser; invoke-virtual {v1, p1}, Lcom/google/common/collect/TreeTraverser;->children(Ljava/lang/Object;)Ljava/lang/Iterable; move-result-object v1 invoke-interface {v1}, Ljava/lang/Iterable;->iterator()Ljava/util/Iterator; move-result-object v1 invoke-direct {v0, p1, v1}, Lcom/google/common/collect/TreeTraverser$PostOrderNode;->(Ljava/lang/Object;Ljava/util/Iterator;)V return-object v0 .end method # virtual methods .method public computeNext()Ljava/lang/Object; .locals 2 .annotation system Ldalvik/annotation/Signature; value = { "()TT;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 :goto_0 iget-object v0, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->stack:Ljava/util/ArrayDeque; invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z move-result v0 if-nez v0, :cond_1 .line 2 iget-object v0, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->stack:Ljava/util/ArrayDeque; invoke-virtual {v0}, Ljava/util/ArrayDeque;->getLast()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeTraverser$PostOrderNode; .line 3 iget-object v1, v0, Lcom/google/common/collect/TreeTraverser$PostOrderNode;->childIterator:Ljava/util/Iterator; invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_0 .line 4 iget-object v0, v0, Lcom/google/common/collect/TreeTraverser$PostOrderNode;->childIterator:Ljava/util/Iterator; invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 .line 5 iget-object v1, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->stack:Ljava/util/ArrayDeque; invoke-direct {p0, v0}, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->expand(Ljava/lang/Object;)Lcom/google/common/collect/TreeTraverser$PostOrderNode; move-result-object v0 invoke-virtual {v1, v0}, Ljava/util/ArrayDeque;->addLast(Ljava/lang/Object;)V goto :goto_0 .line 6 :cond_0 iget-object v1, p0, Lcom/google/common/collect/TreeTraverser$PostOrderIterator;->stack:Ljava/util/ArrayDeque; invoke-virtual {v1}, Ljava/util/ArrayDeque;->removeLast()Ljava/lang/Object; .line 7 iget-object v0, v0, Lcom/google/common/collect/TreeTraverser$PostOrderNode;->root:Ljava/lang/Object; return-object v0 .line 8 :cond_1 invoke-virtual {p0}, Lcom/google/common/collect/AbstractIterator;->endOfData()Ljava/lang/Object; move-result-object v0 return-object v0 .end method