/*---------------------------------------------------------------------------*\ ========= | \\ / 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-2021 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 . Description \*---------------------------------------------------------------------------*/ #include #include #include "autoPtr.H" #include "HashPtrTable.H" using namespace Foam; class Scalar { scalar data_; public: Scalar() : data_(0) {} Scalar(scalar val) : data_(val) {} ~Scalar() { Info<<"delete Scalar: " << data_ << endl; } const scalar& value() const { return data_; } scalar& value() { return data_; } friend Ostream& operator<<(Ostream& os, const Scalar& val) { os << val.data_; return os; } }; template void printTable(const HashPtrTable& table) { Info<< table.size() << nl << "(" << nl; forAllConstIters(table, iter) { const T* ptr = iter.val(); Info<< iter.key() << " = "; if (ptr) { Info<< *ptr << " (" << name(ptr) << ")"; } else { Info<< "nullptr"; } Info<< nl; } Info<< ")" << endl; // Iterate across values, with for-range Info<< "values ("; for (const auto& ptr : table) { Info<< ' '; if (ptr) { Info<< *ptr; } else { Info<< "nullptr"; } } Info<< " )" << nl; } // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // // Main program: int main() { HashPtrTable myTable; myTable.set("abc", new double(42.1)); myTable.set("def", nullptr); myTable.set("pi", new double(3.14159)); myTable.set("natlog", new double(2.718282)); myTable.insert("sqrt2", autoPtr::New(1.414214)); myTable.insert("euler", autoPtr::New(0.577216)); HashTable> myTable1; myTable1.set("abc", std::unique_ptr(new double(42.1))); myTable1.set("pi", std::unique_ptr(new double(3.14159))); myTable1.set("natlog", std::unique_ptr(new double(2.718282))); HashTable> myTable2; myTable2.set("abc", autoPtr(new double(42.1))); myTable2.set("pi", autoPtr(new double(3.14159))); myTable2.set("natlog", autoPtr(new double(2.718282))); myTable2.insert("sqrt2", autoPtr::New(1.414214)); Info<< "Initial table" << nl; printTable(myTable); Info<< "print" << nl; Info<< myTable2 << nl; { auto iter2 = myTable2.find("pi"); Info<< nl << "Got pi="; if (iter2.good()) { Info<< **iter2 << nl; } else { Info<< "not-found" << nl; } } HashPtrTable copy(myTable); // Info<< copy << endl; printTable(copy); Info<< copy << endl; Info<<"\nerase some existing and non-existing entries" << nl; auto iter = myTable.find("pi"); myTable.erase(iter); iter = myTable.find("unknownKey"); myTable.erase(iter); myTable.erase("abc"); myTable.erase("unknownKey"); myTable.release("euler"); Info<< "After erasure" << nl; printTable(myTable); HashPtrTable moved(std::move(copy)); Info<< nl << "test movable" << nl; Info<<"input:" << nl; printTable(copy); Info<<"output:" << nl; printTable(moved); HashPtrTable other; Info<<"move assign" << nl; other = std::move(moved); printTable(other); Info<<"old" << nl; printTable(moved); Info<< "Verifying deletion characteristics" << nl; { HashPtrTable tbl; tbl.set("abc", new Scalar(42.1)); tbl.set("def", nullptr); tbl.set("pi", new Scalar(3.14159)); tbl.set("natlog", new Scalar(2.718282)); tbl.insert("sqrt2", autoPtr::New(1.414214)); Info<< "Table: " << tbl << nl; Info<< nl << "Check exists, non-null" << nl; for (const word& k : { "abc", "foo", "pi" }) { Info<< " " << k << ' '; const auto* inspect = tbl.get(k); if (inspect) { Info<< *inspect << nl; } else { Info<< "(null)" << nl; } } Info<< nl << "... overwrite again" << nl; tbl.set("abc", new Scalar(42.1)); tbl.set("def", nullptr); tbl.set("pi", new Scalar(3.14159)); tbl.set("natlog", new Scalar(2.718282)); tbl.emplace("other", 15.6); Info<< "Table: " << tbl << nl; Info << nl << "Test emplace and emplace_set" << nl; tbl.emplace("abc", 100); tbl.emplace_set("def", 100); tbl.emplace_set("other", 100); Info<< "Table: " << tbl << nl; } return 0; } // ************************************************************************* //