From 5bacbba9f22010b2bd54ebfc7b4cc8713db6c9ea Mon Sep 17 00:00:00 2001 From: yexo Date: Thu, 5 Aug 2010 12:04:33 +0000 Subject: [PATCH] (svn r20371) -Codechange: add general function to call text callbacks for airports --- src/newgrf_airport.cpp | 14 ++++++++++++++ src/newgrf_airport.h | 2 ++ 2 files changed, 16 insertions(+) diff --git a/src/newgrf_airport.cpp b/src/newgrf_airport.cpp index 20533bc675..d077ae14fa 100644 --- a/src/newgrf_airport.cpp +++ b/src/newgrf_airport.cpp @@ -349,3 +349,17 @@ uint16 GetAirportCallback(CallbackID callback, uint32 param1, uint32 param2, Sta return group->GetCallbackResult(); } + +StringID GetAirportTextCallback(const AirportSpec *as, byte layout, uint16 callback) +{ + const SpriteGroup *group; + ResolverObject object; + + NewAirportResolver(&object, INVALID_TILE, NULL, as->GetIndex(), layout); + object.callback = (CallbackID)callback; + + group = SpriteGroup::Resolve(as->grf_prop.spritegroup, &object); + if (group == NULL) return STR_UNDEFINED; + + return GetGRFStringID(as->grf_prop.grffile->grfid, 0xD000 + group->GetResult()); +} diff --git a/src/newgrf_airport.h b/src/newgrf_airport.h index 20c6aa046e..a20be0f540 100644 --- a/src/newgrf_airport.h +++ b/src/newgrf_airport.h @@ -117,4 +117,6 @@ uint GetNumAirportsInClass(AirportClassID id); void BindAirportSpecs(); const AirportSpec *GetAirportSpecFromClass(AirportClassID aclass, uint airport); +StringID GetAirportTextCallback(const AirportSpec *as, byte layout, uint16 callback); + #endif /* NEWGRF_AIRPORT_H */