# HG changeset patch # User frosch # Date 2012-04-22 16:28:27 # Node ID a55aa4bf5bd3f1022746814d65877202e0335d9a # Parent e2eff9dbb4f22a3a60d9b7657c3b37ed577e558b (svn r24169) -Add: Make NewGRFClass distinguish between defined specs and specs visible for the user. diff --git a/src/newgrf_airport.cpp b/src/newgrf_airport.cpp --- a/src/newgrf_airport.cpp +++ b/src/newgrf_airport.cpp @@ -31,6 +31,12 @@ template name = STR_AIRPORT_CLASS_HELIPORTS; } +template +bool NewGRFClass::IsUIAvailable(uint index) const +{ + return true; +} + INSTANTIATE_NEWGRF_CLASS_METHODS(AirportClass, AirportSpec, AirportClassID, APC_MAX) diff --git a/src/newgrf_class.h b/src/newgrf_class.h --- a/src/newgrf_class.h +++ b/src/newgrf_class.h @@ -21,6 +21,7 @@ template count; } + /** Get the number of potentially user-available specs within the class. */ + uint GetUISpecCount() const { return this->ui_count; } const Tspec *GetSpec(uint index) const; + /** Check whether the spec will be available to the user at some point in time. */ + bool IsUIAvailable(uint index) const; + static void Reset(); static Tid Allocate(uint32 global_id); static void Assign(Tspec *spec); static uint GetClassCount(); + static uint GetUIClassCount(); static NewGRFClass *Get(Tid cls_id); static const Tspec *GetByGrf(uint32 grfid, byte local_id, int *index); diff --git a/src/newgrf_class_func.h b/src/newgrf_class_func.h --- a/src/newgrf_class_func.h +++ b/src/newgrf_class_func.h @@ -31,6 +31,7 @@ DEFINE_NEWGRF_CLASS_METHOD(void)::ResetC this->global_id = 0; this->name = STR_EMPTY; this->count = 0; + this->ui_count = 0; free(this->spec); this->spec = NULL; @@ -80,6 +81,8 @@ DEFINE_NEWGRF_CLASS_METHOD(void)::Insert this->spec = ReallocT(this->spec, this->count); this->spec[i] = spec; + + if (this->IsUIAvailable(i)) this->ui_count++; } /** @@ -117,6 +120,19 @@ DEFINE_NEWGRF_CLASS_METHOD(uint)::GetCla } /** + * Get the number of classes available to the user. + * @return The number of classes. + */ +DEFINE_NEWGRF_CLASS_METHOD(uint)::GetUIClassCount() +{ + uint cnt = 0; + for (uint i = 0; i < Tmax && classes[i].global_id != 0; i++) { + if (classes[i].GetUISpecCount() > 0) cnt++; + } + return cnt; +} + +/** * Get a spec from the class at a given index. * @param index The index where to find the spec. * @return The spec at given location. @@ -163,5 +179,6 @@ DEFINE_NEWGRF_CLASS_METHOD(const Tspec * template void name::Assign(Tspec *spec); \ template NewGRFClass *name::Get(Tid cls_id); \ template uint name::GetClassCount(); \ + template uint name::GetUIClassCount(); \ template const Tspec *name::GetSpec(uint index) const; \ template const Tspec *name::GetByGrf(uint32 grfid, byte localidx, int *index); diff --git a/src/newgrf_object.cpp b/src/newgrf_object.cpp --- a/src/newgrf_object.cpp +++ b/src/newgrf_object.cpp @@ -113,6 +113,12 @@ template +bool NewGRFClass::IsUIAvailable(uint index) const +{ + return this->GetSpec(index)->IsEverAvailable(); +} + INSTANTIATE_NEWGRF_CLASS_METHODS(ObjectClass, ObjectSpec, ObjectClassID, OBJECT_CLASS_MAX) diff --git a/src/newgrf_station.cpp b/src/newgrf_station.cpp --- a/src/newgrf_station.cpp +++ b/src/newgrf_station.cpp @@ -40,6 +40,12 @@ template +bool NewGRFClass::IsUIAvailable(uint index) const +{ + return true; +} + INSTANTIATE_NEWGRF_CLASS_METHODS(StationClass, StationSpec, StationClassID, STAT_CLASS_MAX) static const uint MAX_SPECLIST = 255;