/** * Copyright 2015 Santhosh Kumar Tekuri * * The JLibs authors license this file to you under the Apache License, * version 2.0 (the "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. */ package jlibs.core.graph.navigators; import jlibs.core.graph.Sequence; import jlibs.core.graph.sequences.EmptySequence; import jlibs.core.graph.sequences.FilteredTreeSequence; import jlibs.core.graph.Filter; import jlibs.core.graph.Navigator; /** * @author Santhosh Kumar T */ public class FilteredTreeNavigator<E> implements Navigator<E>{ private Navigator<E> delegate; private Filter<E> filter; public FilteredTreeNavigator(Navigator<E> delegate){ this(delegate, null); } public FilteredTreeNavigator(Navigator<E> delegate, Filter<E> filter){ this.delegate = delegate; this.filter = filter; } @Override public Sequence<? extends E> children(E elem){ Sequence<? extends E> seq = delegate.children(elem); if(seq==null) return EmptySequence.getInstance(); if(filter!=null) seq = new FilteredTreeSequence<E>(seq, this, filter); return seq; } }