mirror of
https://gitea.wildfiregames.com/0ad/0ad
synced 2026-06-16 13:23:56 -07:00
Bug introduced in 76acc4e146.
The previous CUnit code had logic to select random aesthetic variants
once initially. The new code removed that, as I completely missed its
purpose, assuming that the random selection, being based on a seed,
would pick the same variants every time. This is incorrect because
entity selections can change the RNG calls, thus the variants, and thus
entity appearance can change when the animation changes (typically, a
horse will change color when walking and running).
The solution is to re-introduce the choice of actor selections on CUnit
creation. This makes sure that units don't change their purely-aesthetic
selections when e.g. animations change.
Reported by: Wowgetoffyourcellphone
Tested By: Stan
Differential Revision: https://code.wildfiregames.com/D4205
This was SVN commit r25844.
67 lines
1.8 KiB
C++
67 lines
1.8 KiB
C++
/* Copyright (C) 2021 Wildfire Games.
|
|
* This file is part of 0 A.D.
|
|
*
|
|
* 0 A.D. 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
|
|
* (at your option) any later version.
|
|
*
|
|
* 0 A.D. 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 0 A.D. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/*
|
|
* Container that owns all units
|
|
*/
|
|
|
|
#ifndef INCLUDED_UNITMANAGER
|
|
#define INCLUDED_UNITMANAGER
|
|
|
|
#include <vector>
|
|
#include <set>
|
|
|
|
class CUnit;
|
|
class CVector3D;
|
|
class CObjectManager;
|
|
class CStr8;
|
|
class CStrW;
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// CUnitManager: simple container class holding all units within the world
|
|
class CUnitManager
|
|
{
|
|
public:
|
|
// constructor, destructor
|
|
CUnitManager();
|
|
~CUnitManager();
|
|
|
|
// add given unit to world
|
|
void AddUnit(CUnit* unit);
|
|
// remove given unit from world, but don't delete it
|
|
void RemoveUnit(CUnit* unit);
|
|
// remove given unit from world and delete it
|
|
void DeleteUnit(CUnit* unit);
|
|
// remove and delete all units
|
|
void DeleteAll();
|
|
|
|
// creates a new unit and adds it to the world
|
|
CUnit* CreateUnit(const CStrW& actorName, uint32_t seed);
|
|
|
|
// return the units
|
|
const std::vector<CUnit*>& GetUnits() const { return m_Units; }
|
|
|
|
void SetObjectManager(CObjectManager& objectManager) { m_ObjectManager = &objectManager; }
|
|
|
|
private:
|
|
// list of all known units
|
|
std::vector<CUnit*> m_Units;
|
|
// graphical object manager; may be NULL if not set up
|
|
CObjectManager* m_ObjectManager;
|
|
};
|
|
|
|
#endif
|