/* * esodata - data structures and other things, of varying utility * Copyright 2022, Ben Culkin * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ package bjc.esodata; import java.util.*; import bjc.data.Pair; import bjc.data.TransformIterator; import bjc.funcdata.FunctionalList; import bjc.funcdata.ListEx; /** * A labeled tree, where you can reference sub-nodes by their label as long as * the reference is unambiguous. * * Inspired by the way that you can reference COBOL members by their name, as * long as it is unambiguous. If it is ambiguous, you can instead use parent * nodes to disambiguate. * * Additional note: The base iterator will give you all of the child nodes, but * in no defined order. * * @param