aboutsummaryrefslogtreecommitdiff
path: root/Carpet/CarpetLib/src/gh.cc
diff options
context:
space:
mode:
authorErik Schnetter <schnetter@gmail.com>2013-08-04 00:25:49 -0400
committerErik Schnetter <schnetter@gmail.com>2013-08-04 00:25:49 -0400
commit9166952a1e2571bf5656345d7f8f1d1246e033d7 (patch)
tree81715eab307797c498c1a1f56671f480e3b14eaf /Carpet/CarpetLib/src/gh.cc
parentdbe1636f5ed6ec4859719ff08f731735e123c59e (diff)
CarpetLib: Store registered gh, dh, th, gf, data etc. via sets, not via lists
Use set instead of list to store registered gh, dh, th, gf, data. Do not store an iterator as handle for de-registering. This corrects some memory corruption with the Intel compiler; the previous code may have been illegal.
Diffstat (limited to 'Carpet/CarpetLib/src/gh.cc')
-rw-r--r--Carpet/CarpetLib/src/gh.cc46
1 files changed, 22 insertions, 24 deletions
diff --git a/Carpet/CarpetLib/src/gh.cc b/Carpet/CarpetLib/src/gh.cc
index 3659f977c..5c13d0b6a 100644
--- a/Carpet/CarpetLib/src/gh.cc
+++ b/Carpet/CarpetLib/src/gh.cc
@@ -19,7 +19,7 @@ using namespace std;
-list<gh*> gh::allgh;
+set<gh*> gh::allgh;
@@ -70,14 +70,14 @@ gh (vector<ivect> const & reffacts_, centering const refcent_,
}
}
- allghi = allgh.insert(allgh.end(), this);
+ allgh.insert (this);
}
// Destructors
gh::
~gh ()
{
- allgh.erase(allghi);
+ allgh.erase (this);
}
@@ -233,11 +233,11 @@ regrid (rregs const & superregs, mregs const & regs, bool const do_init)
// Regrid the other hierarchies
- for (list<th*>::iterator t=ths.begin(); t!=ths.end(); ++t) {
+ for (set<th*>::iterator t=ths.begin(); t!=ths.end(); ++t) {
(*t)->regrid();
}
- for (list<dh*>::iterator d=dhs.begin(); d!=dhs.end(); ++d) {
+ for (set<dh*>::iterator d=dhs.begin(); d!=dhs.end(); ++d) {
(*d)->regrid(do_init);
}
@@ -254,11 +254,11 @@ regrid_free (bool const do_init)
old_global_components_.clear();
old_local_components_.clear();
- for (list<th*>::iterator t=ths.begin(); t!=ths.end(); ++t) {
+ for (set<th*>::iterator t=ths.begin(); t!=ths.end(); ++t) {
(*t)->regrid_free();
}
- for (list<dh*>::iterator d=dhs.begin(); d!=dhs.end(); ++d) {
+ for (set<dh*>::iterator d=dhs.begin(); d!=dhs.end(); ++d) {
(*d)->regrid_free(do_init);
}
}
@@ -275,7 +275,7 @@ recompose (int const rl,
if (do_recompose) {
// Recompose the other hierarchies
- for (list<dh*>::iterator d=dhs.begin(); d!=dhs.end(); ++d) {
+ for (set<dh*>::iterator d=dhs.begin(); d!=dhs.end(); ++d) {
(*d)->recompose (rl, do_prolongate);
}
@@ -454,7 +454,7 @@ locate_position (rvect const & rpos,
// Find associated dh
assert (dhs.size() == 1);
- dh const& dd = *dhs.front();
+ dh const& dd = **dhs.begin();
// Try finer levels first
for (rl = maxrl-1; rl >= minrl; --rl) {
@@ -515,7 +515,7 @@ locate_position (ivect const & ipos,
// Find associated dh
assert (dhs.size() == 1);
- dh const& dd = *dhs.front();
+ dh const& dd = **dhs.begin();
// Try finer levels first
for (rl = maxrl-1; rl >= minrl; --rl) {
@@ -566,36 +566,36 @@ locate_position (ivect const & ipos,
// Time hierarchy management
-gh::th_handle
+void
gh::
-add (th * const t)
+insert (th * const t)
{
- return ths.insert(ths.end(), t);
+ ths.insert(t);
}
void
gh::
-erase (th_handle const ti)
+erase (th * const t)
{
- ths.erase(ti);
+ ths.erase(t);
}
// Data hierarchy management
-gh::dh_handle
+void
gh::
-add (dh * const d)
+insert (dh * const d)
{
- return dhs.insert(dhs.end(), d);
+ dhs.insert(d);
}
void
gh::
-erase (dh_handle di)
+erase (dh * const d)
{
- dhs.erase (di);
+ dhs.erase(d);
}
@@ -608,7 +608,6 @@ memory ()
const
{
return
- sizeof allghi + // memoryof (allghi) +
memoryof (reffacts) +
memoryof (refcent) +
memoryof (mgfact) +
@@ -630,8 +629,7 @@ gh::
allmemory ()
{
size_t mem = memoryof(allgh);
- for (list<gh*>::const_iterator
- ghi = allgh.begin(); ghi != allgh.end(); ++ ghi)
+ for (set<gh*>::const_iterator ghi = allgh.begin(); ghi != allgh.end(); ++ ghi)
{
mem += memoryof(**ghi);
}
@@ -692,7 +690,7 @@ output (ostream & os)
<< "dhs={";
{
bool isfirst = true;
- for (list<dh*>::const_iterator
+ for (set<dh*>::const_iterator
d = dhs.begin(); d != dhs.end(); ++ d, isfirst = false)
{
if (not isfirst) os << ",";