2010-07-22 16:50:58 +00:00
|
|
|
/*
|
|
|
|
* This file is part of OpenTTD.
|
|
|
|
* OpenTTD 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, version 2.
|
|
|
|
* OpenTTD 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 OpenTTD. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file newgrf_railtype.h NewGRF handling of rail types. */
|
|
|
|
|
2010-02-07 22:22:54 +00:00
|
|
|
#ifndef NEWGRF_RAILTYPE_H
|
|
|
|
#define NEWGRF_RAILTYPE_H
|
|
|
|
|
|
|
|
#include "rail.h"
|
2010-08-09 07:10:42 +00:00
|
|
|
#include "newgrf_commons.h"
|
2012-11-10 20:41:45 +00:00
|
|
|
#include "newgrf_spritegroup.h"
|
|
|
|
|
2012-11-10 20:46:39 +00:00
|
|
|
/** Resolver for the railtype scope. */
|
2012-11-10 20:41:45 +00:00
|
|
|
struct RailTypeScopeResolver : public ScopeResolver {
|
|
|
|
TileIndex tile; ///< Tracktile. For track on a bridge this is the southern bridgehead.
|
|
|
|
TileContext context; ///< Are we resolving sprites for the upper halftile, or on a bridge?
|
2023-09-11 08:55:12 +00:00
|
|
|
const RailTypeInfo *rti;
|
2012-11-10 20:41:45 +00:00
|
|
|
|
2018-03-11 13:19:41 +00:00
|
|
|
/**
|
|
|
|
* Constructor of the railtype scope resolvers.
|
|
|
|
* @param ro Surrounding resolver.
|
|
|
|
* @param tile %Tile containing the track. For track on a bridge this is the southern bridgehead.
|
|
|
|
* @param context Are we resolving sprites for the upper halftile, or on a bridge?
|
|
|
|
*/
|
2023-09-11 08:55:12 +00:00
|
|
|
RailTypeScopeResolver(ResolverObject &ro, const RailTypeInfo *rti, TileIndex tile, TileContext context)
|
2020-01-26 12:45:51 +00:00
|
|
|
: ScopeResolver(ro), tile(tile), context(context), rti(rti)
|
2018-03-11 13:19:41 +00:00
|
|
|
{
|
|
|
|
}
|
2012-11-10 20:41:45 +00:00
|
|
|
|
2023-05-08 17:01:06 +00:00
|
|
|
uint32_t GetRandomBits() const override;
|
2023-09-16 20:20:53 +00:00
|
|
|
uint32_t GetVariable(byte variable, [[maybe_unused]] uint32_t parameter, bool *available) const override;
|
2012-11-10 20:41:45 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/** Resolver object for rail types. */
|
|
|
|
struct RailTypeResolverObject : public ResolverObject {
|
2012-11-10 20:46:39 +00:00
|
|
|
RailTypeScopeResolver railtype_scope; ///< Resolver for the railtype scope.
|
2012-11-10 20:41:45 +00:00
|
|
|
|
2023-09-11 08:55:12 +00:00
|
|
|
RailTypeResolverObject(const RailTypeInfo *rti, TileIndex tile, TileContext context, RailTypeSpriteGroup rtsg, uint32_t param1 = 0, uint32_t param2 = 0);
|
2012-11-10 20:41:45 +00:00
|
|
|
|
2019-03-03 22:25:13 +00:00
|
|
|
ScopeResolver *GetScope(VarSpriteGroupScope scope = VSG_SCOPE_SELF, byte relative = 0) override
|
2012-11-10 20:41:45 +00:00
|
|
|
{
|
|
|
|
switch (scope) {
|
|
|
|
case VSG_SCOPE_SELF: return &this->railtype_scope;
|
2012-11-10 20:45:59 +00:00
|
|
|
default: return ResolverObject::GetScope(scope, relative);
|
2012-11-10 20:41:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-26 12:45:51 +00:00
|
|
|
GrfSpecFeature GetFeature() const override;
|
2023-05-08 17:01:06 +00:00
|
|
|
uint32_t GetDebugID() const override;
|
2012-11-10 20:41:45 +00:00
|
|
|
};
|
2010-02-07 22:22:54 +00:00
|
|
|
|
2023-09-11 08:55:12 +00:00
|
|
|
SpriteID GetCustomRailSprite(const RailTypeInfo *rti, TileIndex tile, RailTypeSpriteGroup rtsg, TileContext context = TCX_NORMAL, uint *num_results = nullptr);
|
|
|
|
SpriteID GetCustomSignalSprite(const RailTypeInfo *rti, TileIndex tile, SignalType type, SignalVariant var, SignalState state, bool gui = false);
|
2010-02-07 22:22:54 +00:00
|
|
|
|
2023-05-08 17:01:06 +00:00
|
|
|
RailType GetRailTypeTranslation(uint8_t railtype, const GRFFile *grffile);
|
|
|
|
uint8_t GetReverseRailTypeTranslation(RailType railtype, const GRFFile *grffile);
|
2010-02-07 22:22:54 +00:00
|
|
|
|
|
|
|
#endif /* NEWGRF_RAILTYPE_H */
|