From 1ee62de5ae283068baa8275a01d2245fd2cb7759 Mon Sep 17 00:00:00 2001
From: Andrei Karas <akaras@inbox.ru>
Date: Sun, 18 May 2014 20:11:02 +0300
Subject: Move particlevector into separate file.

---
 src/CMakeLists.txt                 |   2 +
 src/Makefile.am                    |   2 +
 src/being/actorsprite.h            |   1 +
 src/particle/particlecontainer.cpp |  76 +--------------------------
 src/particle/particlecontainer.h   | 104 ++++++++++++-------------------------
 src/particle/particlevector.cpp    |  99 +++++++++++++++++++++++++++++++++++
 src/particle/particlevector.h      |  66 +++++++++++++++++++++++
 7 files changed, 206 insertions(+), 144 deletions(-)
 create mode 100644 src/particle/particlevector.cpp
 create mode 100644 src/particle/particlevector.h

(limited to 'src')

diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 1443f2cdf..e757f3e6d 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -832,6 +832,8 @@ SET(SRCS
     particle/particleinfo.h
     particle/particlelist.cpp
     particle/particlelist.h
+    particle/particlevector.cpp
+    particle/particlevector.h
     party.cpp
     party.h
     being/playerignorestrategy.h
diff --git a/src/Makefile.am b/src/Makefile.am
index a5b54c0a1..18b4df265 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -934,6 +934,8 @@ manaplus_SOURCES += gui/widgets/avatarlistbox.cpp \
 	      particle/particleinfo.h \
 	      particle/particlelist.cpp \
 	      particle/particlelist.h \
+	      particle/particlevector.cpp \
+	      particle/particlevector.h \
 	      party.cpp \
 	      party.h \
 	      being/playerignorestrategy.h \
diff --git a/src/being/actorsprite.h b/src/being/actorsprite.h
index 243fbd8d0..bad6ee219 100644
--- a/src/being/actorsprite.h
+++ b/src/being/actorsprite.h
@@ -35,6 +35,7 @@
 
 #include "particle/particlecontainer.h"
 #include "particle/particlelist.h"
+#include "particle/particlevector.h"
 
 #include <set>
 #include <list>
diff --git a/src/particle/particlecontainer.cpp b/src/particle/particlecontainer.cpp
index 68e0c9d6c..c537a163b 100644
--- a/src/particle/particlecontainer.cpp
+++ b/src/particle/particlecontainer.cpp
@@ -20,9 +20,10 @@
  *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 
-#include "particle/particle.h"
 #include "particle/particlecontainer.h"
 
+#include "particle/particle.h"
+
 #include "utils/delete2.h"
 
 #include "debug.h"
@@ -54,76 +55,3 @@ void ParticleContainer::moveTo(const float x, const float y)
     if (mNext)
         mNext->moveTo(x, y);
 }
-
-// -- particle vector ----------------------------------------
-
-ParticleVector::ParticleVector(ParticleContainer *const parent,
-                               const bool delParent) :
-    ParticleContainer(parent, delParent),
-    mIndexedElements()
-{}
-
-ParticleVector::~ParticleVector()
-{}
-
-void ParticleVector::setLocally(const int index, Particle *const particle)
-{
-    if (index < 0)
-        return;
-
-    delLocally(index);
-
-    if (mIndexedElements.size() <= static_cast<size_t>(index))
-        mIndexedElements.resize(index + 1, nullptr);
-
-    if (particle)
-        particle->disableAutoDelete();
-    mIndexedElements[index] = particle;
-}
-
-void ParticleVector::delLocally(const int index)
-{
-    if (index < 0)
-        return;
-
-    if (mIndexedElements.size() <= static_cast<size_t>(index))
-        return;
-
-    Particle *const p = mIndexedElements[index];
-    if (p)
-    {
-        mIndexedElements[index] = nullptr;
-        p->kill();
-    }
-}
-
-void ParticleVector::clearLocally()
-{
-    for (unsigned int i = 0;
-         i < static_cast<unsigned int>(mIndexedElements.size());
-         i++)
-    {
-        delLocally(i);
-    }
-}
-
-void ParticleVector::moveTo(const float x, const float y)
-{
-    ParticleContainer::moveTo(x, y);
-
-    for (std::vector<Particle *>::iterator it = mIndexedElements.begin();
-         it != mIndexedElements.end(); ++it)
-    {
-        Particle *const p = *it;
-        if (p)
-        {
-            p->moveTo(x, y);
-
-            if (p->isExtinct())
-            {
-                p->kill();
-                *it = nullptr;
-            }
-        }
-    }
-}
diff --git a/src/particle/particlecontainer.h b/src/particle/particlecontainer.h
index 81037ce3a..6128688b6 100644
--- a/src/particle/particlecontainer.h
+++ b/src/particle/particlecontainer.h
@@ -23,13 +23,8 @@
 #ifndef PARTICLE_PARTICLECONTAINER_H
 #define PARTICLE_PARTICLECONTAINER_H
 
-#include <list>
-#include <vector>
-
 #include "localconsts.h"
 
-class Particle;
-
 /**
  * Set of particle effects.  May be stacked with other ParticleContainers.  All
  * operations herein affect such stacked containers, unless the operations end
@@ -37,71 +32,40 @@ class Particle;
  */
 class ParticleContainer
 {
-public:
-    /**
-     * Constructs a new particle container and assumes responsibility for
-     * its parent (for all operations defined herein, except when ending in `Locally')
-     *
-     * delParent means that the destructor should also free the parent.
-     */
-    explicit ParticleContainer(ParticleContainer *const parent = nullptr,
-                               const bool delParent = true);
-
-    A_DELETE_COPY(ParticleContainer)
-
-    virtual ~ParticleContainer();
-
-    /**
-     * Kills and removes all particle effects
-     */
-    void clear();
-
-    /**
-     * Kills and removes all particle effects (only in this container)
-     */
-    virtual void clearLocally()
-    { }
-
-    /**
-     * Sets the positions of all elements
-     */
-    virtual void moveTo(const float x, const float y);
-
-protected:
-    ParticleContainer *mNext;           /**< Contained container, if any */
-    bool mDelParent;                    /**< Delete mNext in destructor */
-};
-
-/**
- * Particle container with indexing facilities
- */
-class ParticleVector final : public ParticleContainer
-{
-public:
-    explicit ParticleVector(ParticleContainer *const parent = nullptr,
-                            const bool delParent = true);
-
-    A_DELETE_COPY(ParticleVector)
-
-    ~ParticleVector();
-
-    /**
-     * Sets a particle at a specified index.  Kills the previous particle
-     * there, if needed.
-     */
-    void setLocally(const int index, Particle *const particle);
-
-    /**
-     * Removes a particle at a specified index
-     */
-    void delLocally(const int index);
-
-    void clearLocally() override final;
-
-    void moveTo(const float x, const float y) override final;
-
-protected:
-    std::vector<Particle *> mIndexedElements;
+    public:
+        /**
+         * Constructs a new particle container and assumes responsibility for
+         * its parent (for all operations defined herein,
+         * except when ending in `Locally')
+         *
+         * delParent means that the destructor should also free the parent.
+         */
+        explicit ParticleContainer(ParticleContainer *const parent = nullptr,
+                                   const bool delParent = true);
+
+        A_DELETE_COPY(ParticleContainer)
+
+        virtual ~ParticleContainer();
+
+        /**
+         * Kills and removes all particle effects
+         */
+        void clear();
+
+        /**
+         * Kills and removes all particle effects (only in this container)
+         */
+        virtual void clearLocally()
+        { }
+
+        /**
+         * Sets the positions of all elements
+         */
+        virtual void moveTo(const float x, const float y);
+
+    protected:
+        ParticleContainer *mNext;           /**< Contained container, if any */
+        bool mDelParent;                    /**< Delete mNext in destructor */
 };
 
 #endif  // PARTICLE_PARTICLECONTAINER_H
diff --git a/src/particle/particlevector.cpp b/src/particle/particlevector.cpp
new file mode 100644
index 000000000..3a0b7f3f6
--- /dev/null
+++ b/src/particle/particlevector.cpp
@@ -0,0 +1,99 @@
+/*
+ *  The ManaPlus Client
+ *  Copyright (C) 2008-2009  The Mana World Development Team
+ *  Copyright (C) 2009-2010  The Mana Developers
+ *  Copyright (C) 2011-2014  The ManaPlus Developers
+ *
+ *  This file is part of The ManaPlus Client.
+ *
+ *  This program 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 2 of the License, or
+ *  any later version.
+ *
+ *  This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "particle/particle.h"
+#include "particle/particlevector.h"
+
+#include "utils/delete2.h"
+
+#include "debug.h"
+
+ParticleVector::ParticleVector(ParticleContainer *const parent,
+                               const bool delParent) :
+    ParticleContainer(parent, delParent),
+    mIndexedElements()
+{}
+
+ParticleVector::~ParticleVector()
+{}
+
+void ParticleVector::setLocally(const int index, Particle *const particle)
+{
+    if (index < 0)
+        return;
+
+    delLocally(index);
+
+    if (mIndexedElements.size() <= static_cast<size_t>(index))
+        mIndexedElements.resize(index + 1, nullptr);
+
+    if (particle)
+        particle->disableAutoDelete();
+    mIndexedElements[index] = particle;
+}
+
+void ParticleVector::delLocally(const int index)
+{
+    if (index < 0)
+        return;
+
+    if (mIndexedElements.size() <= static_cast<size_t>(index))
+        return;
+
+    Particle *const p = mIndexedElements[index];
+    if (p)
+    {
+        mIndexedElements[index] = nullptr;
+        p->kill();
+    }
+}
+
+void ParticleVector::clearLocally()
+{
+    for (unsigned int i = 0;
+         i < static_cast<unsigned int>(mIndexedElements.size());
+         i++)
+    {
+        delLocally(i);
+    }
+}
+
+void ParticleVector::moveTo(const float x, const float y)
+{
+    ParticleContainer::moveTo(x, y);
+
+    for (std::vector<Particle *>::iterator it = mIndexedElements.begin();
+         it != mIndexedElements.end(); ++it)
+    {
+        Particle *const p = *it;
+        if (p)
+        {
+            p->moveTo(x, y);
+
+            if (p->isExtinct())
+            {
+                p->kill();
+                *it = nullptr;
+            }
+        }
+    }
+}
diff --git a/src/particle/particlevector.h b/src/particle/particlevector.h
new file mode 100644
index 000000000..25fe8f3bb
--- /dev/null
+++ b/src/particle/particlevector.h
@@ -0,0 +1,66 @@
+/*
+ *  The ManaPlus Client
+ *  Copyright (C) 2008-2009  The Mana World Development Team
+ *  Copyright (C) 2009-2010  The Mana Developers
+ *  Copyright (C) 2011-2014  The ManaPlus Developers
+ *
+ *  This file is part of The ManaPlus Client.
+ *
+ *  This program 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 2 of the License, or
+ *  any later version.
+ *
+ *  This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef PARTICLE_PARTICLEVECTOR_H
+#define PARTICLE_PARTICLEVECTOR_H
+
+#include "particle/particlecontainer.h"
+
+#include <vector>
+
+#include "localconsts.h"
+
+class Particle;
+
+/**
+ * Particle container with indexing facilities
+ */
+class ParticleVector final : public ParticleContainer
+{
+    public:
+        explicit ParticleVector(ParticleContainer *const parent = nullptr,
+                                const bool delParent = true);
+
+        A_DELETE_COPY(ParticleVector)
+
+        ~ParticleVector();
+
+        /**
+         * Sets a particle at a specified index.  Kills the previous particle
+         * there, if needed.
+         */
+        void setLocally(const int index, Particle *const particle);
+
+        /**
+         * Removes a particle at a specified index
+         */
+        void delLocally(const int index);
+
+        void clearLocally() override final;
+
+        void moveTo(const float x, const float y) override final;
+
+    protected:
+        std::vector<Particle *> mIndexedElements;
+};
+
+#endif  // PARTICLE_PARTICLEVECTOR_H
-- 
cgit v1.2.3-70-g09d2