mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
ENH: optionally eliminate duplicates on hashedWordList construction (issue #375)
- makes it easier to use as a wordHashSet replacement for situations where we want to avoid duplicates but retain the input order. - support construction from HashTable, which means it works like the HashTable::sortedToc but with its own hashing for these keys. - expose rehash() method for the user. There is normally no need for using it directly, but also no reason to lock it away as private.
This commit is contained in:
@ -42,7 +42,7 @@ int main(int argc, char *argv[])
|
|||||||
"def",
|
"def",
|
||||||
"ghi"
|
"ghi"
|
||||||
};
|
};
|
||||||
words = { "def", "ghi", "xy", "all", "begin", "all" };
|
words = { "def", "ghi", "xy", "all", "end", "all" };
|
||||||
|
|
||||||
wordHashSet setA
|
wordHashSet setA
|
||||||
{
|
{
|
||||||
@ -84,6 +84,26 @@ int main(int argc, char *argv[])
|
|||||||
Info<< "hashedWordList: " << words << nl
|
Info<< "hashedWordList: " << words << nl
|
||||||
<< "with lookup: " << words.lookup() << endl;
|
<< "with lookup: " << words.lookup() << endl;
|
||||||
|
|
||||||
|
{
|
||||||
|
List<word> input = { "def", "ghi", "xy", "all", "end", "all", "def" };
|
||||||
|
hashedWordList words1(input, true);
|
||||||
|
|
||||||
|
Info<< "input word list: " << input << nl
|
||||||
|
<< "without dup: " << words1 << endl;
|
||||||
|
|
||||||
|
Info<< "from wordHashSet: " << hashedWordList(setA) << endl;
|
||||||
|
Info<< "from HashTable: " << hashedWordList(tableA) << endl;
|
||||||
|
Info<< "from HashTable: " << hashedWordList(tableB) << endl;
|
||||||
|
|
||||||
|
// even this works
|
||||||
|
Info<< "from hashSet: "
|
||||||
|
<< hashedWordList
|
||||||
|
(
|
||||||
|
wordHashSet(setA)
|
||||||
|
| wordHashSet(tableA) | wordHashSet(tableB)
|
||||||
|
) << endl;
|
||||||
|
}
|
||||||
|
|
||||||
Info<< "wordHashSet: " << setA << endl;
|
Info<< "wordHashSet: " << setA << endl;
|
||||||
Info<< "Table-HashSet: " << tableA << endl;
|
Info<< "Table-HashSet: " << tableA << endl;
|
||||||
Info<< "Map<label>: " << mapA << endl;
|
Info<< "Map<label>: " << mapA << endl;
|
||||||
|
|||||||
@ -52,7 +52,6 @@ int main(int argc, char *argv[])
|
|||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Info<< "Cell centres" << nl << mesh.cellCentres() << endl;
|
Info<< "Cell centres" << nl << mesh.cellCentres() << endl;
|
||||||
Info<< "Cell volumes" << nl << mesh.cellVolumes() << endl;
|
Info<< "Cell volumes" << nl << mesh.cellVolumes() << endl;
|
||||||
Info<< "Cell shapes" << nl << mesh.cellShapes() << endl;
|
Info<< "Cell shapes" << nl << mesh.cellShapes() << endl;
|
||||||
|
|||||||
@ -3,7 +3,7 @@
|
|||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
\\ / O peration |
|
\\ / O peration |
|
||||||
\\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
|
\\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
|
||||||
\\/ M anipulation | Copyright (C) 2016 OpenCFD Ltd.
|
\\/ M anipulation | Copyright (C) 2016-2017 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -25,94 +25,46 @@ License
|
|||||||
|
|
||||||
#include "hashedWordList.H"
|
#include "hashedWordList.H"
|
||||||
|
|
||||||
// * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
|
|
||||||
|
|
||||||
void Foam::hashedWordList::rehash()
|
|
||||||
{
|
|
||||||
indices_.clear();
|
|
||||||
forAll(*this, i)
|
|
||||||
{
|
|
||||||
indices_.insert(List<word>::operator[](i), i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
Foam::hashedWordList::hashedWordList()
|
Foam::hashedWordList::hashedWordList
|
||||||
|
(
|
||||||
|
const label count,
|
||||||
|
const char** lst,
|
||||||
|
const bool removeDuplicates
|
||||||
|
)
|
||||||
:
|
:
|
||||||
List<word>()
|
List<word>(count)
|
||||||
{}
|
|
||||||
|
|
||||||
|
|
||||||
Foam::hashedWordList::hashedWordList(const UList<word>& names)
|
|
||||||
:
|
|
||||||
List<word>(names)
|
|
||||||
{
|
{
|
||||||
rehash();
|
forAll(*this, i)
|
||||||
}
|
{
|
||||||
|
List<word>::operator[](i) = lst[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
rehash(removeDuplicates);
|
||||||
Foam::hashedWordList::hashedWordList(const hashedWordList& names)
|
|
||||||
:
|
|
||||||
List<word>(static_cast<const UList<word>&>(names))
|
|
||||||
{
|
|
||||||
rehash();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Foam::hashedWordList::hashedWordList(const Xfer<List<word>>& names)
|
|
||||||
:
|
|
||||||
List<word>(names)
|
|
||||||
{
|
|
||||||
rehash();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Foam::hashedWordList::hashedWordList(std::initializer_list<word> lst)
|
|
||||||
:
|
|
||||||
List<word>(lst)
|
|
||||||
{
|
|
||||||
rehash();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Foam::hashedWordList::hashedWordList
|
Foam::hashedWordList::hashedWordList
|
||||||
(
|
(
|
||||||
const label nNames,
|
const char** lst,
|
||||||
const char** names
|
const bool removeDuplicates
|
||||||
)
|
|
||||||
:
|
|
||||||
List<word>(nNames)
|
|
||||||
{
|
|
||||||
forAll(*this, i)
|
|
||||||
{
|
|
||||||
List<word>::operator[](i) = names[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
rehash();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Foam::hashedWordList::hashedWordList
|
|
||||||
(
|
|
||||||
const char** names
|
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
// count names
|
// Determine the number of entries
|
||||||
label nNames = 0;
|
label count = 0;
|
||||||
for (unsigned i = 0; names[i] && *(names[i]); ++i)
|
for (unsigned i = 0; lst[i] && *(lst[i]); ++i)
|
||||||
{
|
{
|
||||||
++nNames;
|
++count;
|
||||||
}
|
}
|
||||||
|
|
||||||
List<word>::setSize(nNames);
|
List<word>::setSize(count);
|
||||||
forAll(*this, i)
|
forAll(*this, i)
|
||||||
{
|
{
|
||||||
List<word>::operator[](i) = names[i];
|
List<word>::operator[](i) = lst[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
rehash();
|
rehash(removeDuplicates);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -124,42 +76,32 @@ Foam::hashedWordList::hashedWordList(Istream& is)
|
|||||||
|
|
||||||
// * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
void Foam::hashedWordList::clear()
|
void Foam::hashedWordList::transfer
|
||||||
{
|
(
|
||||||
List<word>::clear();
|
List<word>& lst,
|
||||||
indices_.clear();
|
const bool removeDuplicates
|
||||||
}
|
)
|
||||||
|
|
||||||
|
|
||||||
void Foam::hashedWordList::append(const word& name)
|
|
||||||
{
|
|
||||||
const label idx = size();
|
|
||||||
List<word>::append(name);
|
|
||||||
indices_.insert(name, idx);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Foam::hashedWordList::transfer(List<word>& lst)
|
|
||||||
{
|
{
|
||||||
List<word>::transfer(lst);
|
List<word>::transfer(lst);
|
||||||
rehash();
|
rehash(removeDuplicates);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Foam::hashedWordList::sort()
|
void Foam::hashedWordList::rehash() const
|
||||||
{
|
{
|
||||||
Foam::sort(*this);
|
indices_.clear();
|
||||||
rehash();
|
|
||||||
|
forAll(*this, i)
|
||||||
|
{
|
||||||
|
indices_.insert(List<word>::operator[](i), i);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Foam::hashedWordList::uniq()
|
void Foam::hashedWordList::uniq()
|
||||||
{
|
{
|
||||||
if (size() != indices_.size())
|
|
||||||
{
|
|
||||||
// sizes don't match, which means there appear to be duplicates
|
|
||||||
|
|
||||||
indices_.clear();
|
indices_.clear();
|
||||||
|
|
||||||
label nElem = 0;
|
label nElem = 0;
|
||||||
forAll(*this, i)
|
forAll(*this, i)
|
||||||
{
|
{
|
||||||
@ -176,7 +118,6 @@ void Foam::hashedWordList::uniq()
|
|||||||
}
|
}
|
||||||
|
|
||||||
List<word>::setSize(nElem);
|
List<word>::setSize(nElem);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -193,7 +134,7 @@ Foam::Istream& Foam::operator>>(Istream& is, hashedWordList& lst)
|
|||||||
|
|
||||||
Foam::Ostream& Foam::operator<<(Ostream& os, const hashedWordList& lst)
|
Foam::Ostream& Foam::operator<<(Ostream& os, const hashedWordList& lst)
|
||||||
{
|
{
|
||||||
os << static_cast<const List<word>&>(lst);
|
os << static_cast<const UList<word>&>(lst);
|
||||||
return os;
|
return os;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,7 @@
|
|||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
\\ / O peration |
|
\\ / O peration |
|
||||||
\\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
|
\\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
|
||||||
\\/ M anipulation | Copyright (C) 2016 OpenCFD Ltd.
|
\\/ M anipulation | Copyright (C) 2016-2017 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -25,7 +25,7 @@ Class
|
|||||||
Foam::hashedWordList
|
Foam::hashedWordList
|
||||||
|
|
||||||
Description
|
Description
|
||||||
A wordList with hashed indices for faster lookup by name.
|
A wordList with hashed indices for additional fast lookup by name.
|
||||||
|
|
||||||
SourceFiles
|
SourceFiles
|
||||||
hashedWordListI.H
|
hashedWordListI.H
|
||||||
@ -62,38 +62,64 @@ class hashedWordList
|
|||||||
// Private data
|
// Private data
|
||||||
|
|
||||||
//- Hash of words/indices
|
//- Hash of words/indices
|
||||||
HashTable<label,word> indices_;
|
mutable HashTable<label,word> indices_;
|
||||||
|
|
||||||
|
|
||||||
// Private Member Functions
|
// Private Member Functions
|
||||||
|
|
||||||
//- Rebuild the hash of indices
|
//- Rebuild the lookup hash or make unique entries first.
|
||||||
void rehash();
|
inline void rehash(const bool unique);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// Constructors
|
// Constructors
|
||||||
|
|
||||||
//- Construct null
|
//- Construct null
|
||||||
hashedWordList();
|
inline hashedWordList();
|
||||||
|
|
||||||
//- Copy constructor.
|
//- Copy constructor.
|
||||||
hashedWordList(const hashedWordList&);
|
inline hashedWordList(const hashedWordList& lst);
|
||||||
|
|
||||||
//- Construct from list of words
|
//- Construct from list of words,
|
||||||
hashedWordList(const UList<word>&);
|
// optionally eliminating duplicates
|
||||||
|
inline hashedWordList
|
||||||
|
(
|
||||||
|
const UList<word>& lst,
|
||||||
|
const bool removeDuplicates=false
|
||||||
|
);
|
||||||
|
|
||||||
|
//- Construct by transferring the parameter contents,
|
||||||
|
// optionally eliminating duplicates
|
||||||
|
inline hashedWordList
|
||||||
|
(
|
||||||
|
const Xfer<List<word>>& lst,
|
||||||
|
const bool removeDuplicates=false
|
||||||
|
);
|
||||||
|
|
||||||
//- Construct from an initializer list
|
//- Construct from an initializer list
|
||||||
hashedWordList(std::initializer_list<word>);
|
inline hashedWordList(std::initializer_list<word>);
|
||||||
|
|
||||||
//- Construct by transferring the parameter contents
|
//- Construct from the word keys of any HashTable, sorting immediately.
|
||||||
hashedWordList(const Xfer<List<word>>&);
|
// This also handles a wordHashSet, which is derived from a HashTable.
|
||||||
|
// The result is similar to a HashTable::sortedToc.
|
||||||
|
template<class AnyType, class AnyHash>
|
||||||
|
explicit inline hashedWordList
|
||||||
|
(
|
||||||
|
const HashTable<AnyType, word, AnyHash>& h
|
||||||
|
);
|
||||||
|
|
||||||
//- Construct from number and list of names
|
//- Construct from number and list of words,
|
||||||
hashedWordList(const label nNames, const char** names);
|
// optionally eliminating duplicates
|
||||||
|
hashedWordList
|
||||||
|
(
|
||||||
|
const label count,
|
||||||
|
const char** lst,
|
||||||
|
const bool removeDuplicates=false
|
||||||
|
);
|
||||||
|
|
||||||
//- Construct from a nullptr-terminated list of names
|
//- Construct from a nullptr-terminated list of words,
|
||||||
hashedWordList(const char** names);
|
// optionally eliminating duplicates
|
||||||
|
hashedWordList(const char** lst, const bool removeDuplicates=false);
|
||||||
|
|
||||||
//- Construct from Istream
|
//- Construct from Istream
|
||||||
hashedWordList(Istream&);
|
hashedWordList(Istream&);
|
||||||
@ -102,47 +128,53 @@ public:
|
|||||||
// Member Functions
|
// Member Functions
|
||||||
|
|
||||||
//- Clear the list, i.e. set size to zero.
|
//- Clear the list, i.e. set size to zero.
|
||||||
void clear();
|
inline void clear();
|
||||||
|
|
||||||
//- Append an element at the end of the list
|
//- Append an element at the end of the list,
|
||||||
void append(const word&);
|
// optionally avoid append if it would be a duplicate entry
|
||||||
|
inline void append(const word& name, const bool avoidDuplicates=false);
|
||||||
|
|
||||||
//- Does the list contain the specified name
|
//- Does the list contain the specified name
|
||||||
inline bool found(const word&) const;
|
inline bool found(const word& name) const;
|
||||||
|
|
||||||
//- Does the list contain the specified name
|
//- Does the list contain the specified name
|
||||||
inline bool contains(const word&) const;
|
inline bool contains(const word& name) const;
|
||||||
|
|
||||||
//- Return the hash of words/indices for inspection
|
//- Return the hash of words/indices for inspection
|
||||||
inline const HashTable<label,word>& lookup() const;
|
inline const HashTable<label,word>& lookup() const;
|
||||||
|
|
||||||
//- Transfer the contents of the argument List into this list
|
//- Transfer the contents of the argument List into this list
|
||||||
// and annul the argument list.
|
// and annul the argument list,
|
||||||
void transfer(List<word>&);
|
// optionally eliminating duplicates
|
||||||
|
void transfer(List<word>& lst, const bool removeDuplicates=false);
|
||||||
|
|
||||||
|
//- Rebuild the lookup hash indices
|
||||||
|
void rehash() const;
|
||||||
|
|
||||||
//- Sort the list and rehash the indices
|
//- Sort the list and rehash the indices
|
||||||
void sort();
|
inline void sort();
|
||||||
|
|
||||||
//- Adjust the list if necessary to eliminate duplicate entries
|
//- Adjust the list if necessary to eliminate duplicate entries,
|
||||||
|
// and rehash the indices
|
||||||
void uniq();
|
void uniq();
|
||||||
|
|
||||||
|
|
||||||
// Member Operators
|
// Member Operators
|
||||||
|
|
||||||
//- Assignment operator from list of words
|
//- Assignment operator from list of words
|
||||||
inline void operator=(const UList<word>&);
|
inline void operator=(const UList<word>& lst);
|
||||||
|
|
||||||
//- Assignment operator from initializer list
|
//- Assignment operator from initializer list
|
||||||
inline void operator=(std::initializer_list<word>);
|
inline void operator=(std::initializer_list<word> lst);
|
||||||
|
|
||||||
//- Assignment operator.
|
//- Assignment operator.
|
||||||
inline void operator=(const hashedWordList&);
|
inline void operator=(const hashedWordList& lst);
|
||||||
|
|
||||||
//- Return name corresponding to specified index
|
//- Return name corresponding to specified index
|
||||||
inline const word& operator[](const label index) const;
|
inline const word& operator[](const label index) const;
|
||||||
|
|
||||||
//- Return index corresponding to specified name
|
//- Return index corresponding to specified name
|
||||||
inline label operator[](const word&) const;
|
inline label operator[](const word& name) const;
|
||||||
|
|
||||||
|
|
||||||
// Istream operators
|
// Istream operators
|
||||||
|
|||||||
@ -3,7 +3,7 @@
|
|||||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
\\ / O peration |
|
\\ / O peration |
|
||||||
\\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
|
\\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
|
||||||
\\/ M anipulation | Copyright (C) 2016 OpenCFD Ltd.
|
\\/ M anipulation | Copyright (C) 2016-2017 OpenCFD Ltd.
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
License
|
License
|
||||||
This file is part of OpenFOAM.
|
This file is part of OpenFOAM.
|
||||||
@ -23,8 +23,117 @@ License
|
|||||||
|
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
|
||||||
|
|
||||||
|
inline void Foam::hashedWordList::rehash(const bool unique)
|
||||||
|
{
|
||||||
|
if (unique)
|
||||||
|
{
|
||||||
|
uniq();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
rehash();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
inline Foam::hashedWordList::hashedWordList()
|
||||||
|
:
|
||||||
|
List<word>(),
|
||||||
|
indices_()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
inline Foam::hashedWordList::hashedWordList(const hashedWordList& lst)
|
||||||
|
:
|
||||||
|
List<word>(static_cast<const UList<word>&>(lst))
|
||||||
|
{
|
||||||
|
rehash();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline Foam::hashedWordList::hashedWordList
|
||||||
|
(
|
||||||
|
const UList<word>& lst,
|
||||||
|
const bool removeDuplicates
|
||||||
|
)
|
||||||
|
:
|
||||||
|
List<word>(lst)
|
||||||
|
{
|
||||||
|
rehash(removeDuplicates);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline Foam::hashedWordList::hashedWordList
|
||||||
|
(
|
||||||
|
const Xfer<List<word>>& lst,
|
||||||
|
const bool removeDuplicates
|
||||||
|
)
|
||||||
|
:
|
||||||
|
List<word>(lst)
|
||||||
|
{
|
||||||
|
rehash(removeDuplicates);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline Foam::hashedWordList::hashedWordList(std::initializer_list<word> lst)
|
||||||
|
:
|
||||||
|
List<word>(lst)
|
||||||
|
{
|
||||||
|
rehash();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template<class AnyType, class AnyHash>
|
||||||
|
inline Foam::hashedWordList::hashedWordList
|
||||||
|
(
|
||||||
|
const HashTable<AnyType, word, AnyHash>& h
|
||||||
|
)
|
||||||
|
:
|
||||||
|
List<word>(h.size())
|
||||||
|
{
|
||||||
|
label nElem = 0;
|
||||||
|
for
|
||||||
|
(
|
||||||
|
typename HashTable<AnyType, word, AnyHash>::const_iterator
|
||||||
|
iter = h.cbegin();
|
||||||
|
iter != h.cend();
|
||||||
|
++iter
|
||||||
|
)
|
||||||
|
{
|
||||||
|
List<word>::operator[](nElem++) = iter.key();
|
||||||
|
}
|
||||||
|
|
||||||
|
this->sort();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
inline void Foam::hashedWordList::clear()
|
||||||
|
{
|
||||||
|
List<word>::clear();
|
||||||
|
indices_.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline void Foam::hashedWordList::append
|
||||||
|
(
|
||||||
|
const word& name,
|
||||||
|
const bool avoidDuplicates
|
||||||
|
)
|
||||||
|
{
|
||||||
|
// name is either unique or we don't care about duplicates
|
||||||
|
if (indices_.insert(name, size()) || !avoidDuplicates)
|
||||||
|
{
|
||||||
|
List<word>::append(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
inline const Foam::HashTable<Foam::label,Foam::word>&
|
inline const Foam::HashTable<Foam::label,Foam::word>&
|
||||||
Foam::hashedWordList::lookup() const
|
Foam::hashedWordList::lookup() const
|
||||||
{
|
{
|
||||||
@ -44,6 +153,13 @@ inline bool Foam::hashedWordList::contains(const word& name) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
inline void Foam::hashedWordList::sort()
|
||||||
|
{
|
||||||
|
Foam::sort(*this);
|
||||||
|
rehash();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * Member Operators * * * * * * * * * * * * * //
|
||||||
|
|
||||||
inline void Foam::hashedWordList::operator=(const UList<word>& lst)
|
inline void Foam::hashedWordList::operator=(const UList<word>& lst)
|
||||||
@ -75,9 +191,9 @@ inline const Foam::word& Foam::hashedWordList::operator[]
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// could return -1 instead of bombing out
|
|
||||||
inline Foam::label Foam::hashedWordList::operator[](const word& name) const
|
inline Foam::label Foam::hashedWordList::operator[](const word& name) const
|
||||||
{
|
{
|
||||||
|
// Could return -1 instead of bombing out
|
||||||
return indices_[name];
|
return indices_[name];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user