mirror of
https://github.com/JGRennison/OpenTTD-patches.git
synced 2024-11-16 00:12:51 +00:00
(svn r24165) -Codechange: Split parts of static NewGRFClass::Assign() into non-static Insert().
This commit is contained in:
parent
48c44a8d21
commit
cb43494488
@ -39,6 +39,8 @@ public:
|
||||
uint32 global_id; ///< Global ID for class, e.g. 'DFLT', 'WAYP', etc.
|
||||
StringID name; ///< Name of this class.
|
||||
|
||||
void Insert(Tspec *spec);
|
||||
|
||||
static void Reset();
|
||||
static Tid Allocate(uint32 global_id);
|
||||
static void Assign(Tspec *spec);
|
||||
|
@ -70,6 +70,18 @@ DEFINE_NEWGRF_CLASS_METHOD(Tid)::Allocate(uint32 global_id)
|
||||
return (Tid)0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Insert a spec into the class.
|
||||
* @param spec The spec to insert.
|
||||
*/
|
||||
DEFINE_NEWGRF_CLASS_METHOD(void)::Insert(Tspec *spec)
|
||||
{
|
||||
uint i = this->count++;
|
||||
this->spec = ReallocT(this->spec, this->count);
|
||||
|
||||
this->spec[i] = spec;
|
||||
}
|
||||
|
||||
/**
|
||||
* Assign a spec to one of the classes.
|
||||
* @param spec The spec to assign.
|
||||
@ -78,12 +90,7 @@ DEFINE_NEWGRF_CLASS_METHOD(Tid)::Allocate(uint32 global_id)
|
||||
DEFINE_NEWGRF_CLASS_METHOD(void)::Assign(Tspec *spec)
|
||||
{
|
||||
assert(spec->cls_id < Tmax);
|
||||
NewGRFClass<Tspec, Tid, Tmax> *cls = &classes[spec->cls_id];
|
||||
|
||||
uint i = cls->count++;
|
||||
cls->spec = ReallocT(cls->spec, cls->count);
|
||||
|
||||
cls->spec[i] = spec;
|
||||
Get(spec->cls_id)->Insert(spec);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -169,6 +176,7 @@ DEFINE_NEWGRF_CLASS_METHOD(const Tspec *)::GetByGrf(uint32 grfid, byte local_id,
|
||||
template void name::ResetClass(); \
|
||||
template void name::Reset(); \
|
||||
template Tid name::Allocate(uint32 global_id); \
|
||||
template void name::Insert(Tspec *spec); \
|
||||
template void name::Assign(Tspec *spec); \
|
||||
template NewGRFClass<Tspec, Tid, Tmax> *name::Get(Tid cls_id); \
|
||||
template uint name::GetCount(); \
|
||||
|
Loading…
Reference in New Issue
Block a user