1 | /* |
1 | /* |
2 | * This file is part of Deliantra, the Roguelike Realtime MMORPG. |
2 | * This file is part of Deliantra, the Roguelike Realtime MMORPG. |
3 | * |
3 | * |
4 | * Copyright (©) 2005,2006,2007,2008,2009,2010 Marc Alexander Lehmann / Robin Redeker / the Deliantra team |
4 | * Copyright (©) 2005,2006,2007,2008,2009,2010,2011 Marc Alexander Lehmann / Robin Redeker / the Deliantra team |
5 | * Copyright (©) 2002 Mark Wedel & Crossfire Development Team |
5 | * Copyright (©) 2002 Mark Wedel & Crossfire Development Team |
6 | * Copyright (©) 1992 Frank Tore Johansen |
6 | * Copyright (©) 1992 Frank Tore Johansen |
7 | * |
7 | * |
8 | * Deliantra is free software: you can redistribute it and/or modify it under |
8 | * Deliantra is free software: you can redistribute it and/or modify it under |
9 | * the terms of the Affero GNU General Public License as published by the |
9 | * the terms of the Affero GNU General Public License as published by the |
… | |
… | |
549 | |
549 | |
550 | if (at->refcnt_cnt () > 1) // all arches have ONE refcount from their object |
550 | if (at->refcnt_cnt () > 1) // all arches have ONE refcount from their object |
551 | ++idx; |
551 | ++idx; |
552 | else |
552 | else |
553 | { |
553 | { |
554 | LOG (llevDebug, "garbage collect arch %s", &at->archname); |
554 | //LOG (llevDebug, "garbage collect arch %s", &at->archname); |
555 | assert (at->arch == at); // verify that refcnt == 1 is truly valid |
555 | assert (at->arch == at); // verify that refcnt == 1 is truly valid |
556 | allarch.erase (idx); |
556 | allarch.erase (idx); |
557 | |
557 | |
558 | // break chain |
558 | // break chain |
559 | for (object *op = at->head_ (); op; ) |
559 | for (object *op = at->head_ (); op; ) |