/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | www.openfoam.com \\/ M anipulation | ------------------------------------------------------------------------------- Copyright (C) 2011 OpenFOAM Foundation Copyright (C) 2017-2023 OpenCFD Ltd. ------------------------------------------------------------------------------- License This file is part of OpenFOAM. OpenFOAM 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. OpenFOAM 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 OpenFOAM. If not, see . Application Description Test label ranges \*---------------------------------------------------------------------------*/ #include "argList.H" #include "labelRanges.H" using namespace Foam; void printInfo(const labelRange& range) { Info<< "min " << range.min() << nl << "max " << range.max() << nl << "end " << range.end_value() << nl << "begin/end " << *range.cbegin() << ' ' << *range.cend() << nl; // Info<< "rbegin rend " << *range.rbegin() << ' ' << *range.rend() << nl; } // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // // Main program: int main(int argc, char *argv[]) { argList::noParallel(); argList::noFunctionObjects(); argList::addArgument("start size .. startN sizeN"); argList::addVerboseOption("enable labelRange::debug"); argList::addNote ( "The default is to add ranges, use 'add' and 'del' to toggle\n\n" "Eg, 0 10 30 10 del 20 15" ); argList args(argc, argv, false, true); if (args.verbose()) { labelRange::debug = 1; } Info<< nl; { labelRange range(5, 10); Info<< "identity: " << identity(range) << nl; } { Info<< "test sorting" << endl; labelRanges list1(10); list1.emplace_back(25, 8); list1.emplace_back(8); list1.emplace_back(15, 5); list1.emplace_back(50, -10, true); // Move construct labelRanges ranges(std::move(list1)); if (!list1.empty()) { Info<< "Move construct failed? " << flatOutput(list1.ranges()) << nl; } Info<< "unsorted: "; ranges.writeList(Info) << nl; ranges.sort(); Info<< "sorted: "; ranges.writeList(Info) << nl; Info<< nl << "list linear length = " << ranges.totalSize() << nl; Info<< "list labels = "; ranges.labels().writeList(Info) << nl; Info<< nl; for (int i : { -1, 0, 5, 8, 10, 20, 26 }) { Info<< "value at [" << i << "] = " << ranges[i] << nl; } } { Info<< "test intersections" << endl; labelRange range1(-15, 25); labelRange range2(7, 8); labelRange range3(-20, 8); labelRange range4(50, 8); Info<(argI); label size = args.get