(svn r23494) -Feature: [NewGRF] action14 node INFO->URL_ to add an url

This commit is contained in:
yexo 2011-12-11 12:55:04 +00:00
parent f3b78bf076
commit 7a7d9a7b6b
4 changed files with 27 additions and 0 deletions

View File

@ -421,6 +421,9 @@ void ClientNetworkUDPSocketHandler::HandleIncomingNetworkGameInfoGRFConfig(GRFCo
config->info->Release(); config->info->Release();
config->info = f->info; config->info = f->info;
config->info->AddRef(); config->info->AddRef();
config->url->Release();
config->url = f->url;
config->url->AddRef();
} }
SetBit(config->flags, GCF_COPY); SetBit(config->flags, GCF_COPY);
} }

View File

@ -7065,6 +7065,13 @@ static bool ChangeGRFDescription(byte langid, const char *str)
return true; return true;
} }
/** Callback function for 'INFO'->'URL_' to set the newgrf url. */
static bool ChangeGRFURL(byte langid, const char *str)
{
AddGRFTextToList(&_cur.grfconfig->url->text, langid, _cur.grfconfig->ident.grfid, false, str);
return true;
}
/** Callback function for 'INFO'->'NPAR' to set the number of valid parameters. */ /** Callback function for 'INFO'->'NPAR' to set the number of valid parameters. */
static bool ChangeGRFNumUsedParams(size_t len, ByteReader *buf) static bool ChangeGRFNumUsedParams(size_t len, ByteReader *buf)
{ {
@ -7412,6 +7419,7 @@ static bool HandleParameterInfo(ByteReader *buf)
AllowedSubtags _tags_info[] = { AllowedSubtags _tags_info[] = {
AllowedSubtags('NAME', ChangeGRFName), AllowedSubtags('NAME', ChangeGRFName),
AllowedSubtags('DESC', ChangeGRFDescription), AllowedSubtags('DESC', ChangeGRFDescription),
AllowedSubtags('URL_', ChangeGRFURL),
AllowedSubtags('NPAR', ChangeGRFNumUsedParams), AllowedSubtags('NPAR', ChangeGRFNumUsedParams),
AllowedSubtags('PALS', ChangeGRFPalette), AllowedSubtags('PALS', ChangeGRFPalette),
AllowedSubtags('BLTR', ChangeGRFBlitter), AllowedSubtags('BLTR', ChangeGRFBlitter),

View File

@ -44,11 +44,13 @@ GRFTextWrapper::~GRFTextWrapper()
GRFConfig::GRFConfig(const char *filename) : GRFConfig::GRFConfig(const char *filename) :
name(new GRFTextWrapper()), name(new GRFTextWrapper()),
info(new GRFTextWrapper()), info(new GRFTextWrapper()),
url(new GRFTextWrapper()),
num_valid_params(lengthof(param)) num_valid_params(lengthof(param))
{ {
if (filename != NULL) this->filename = strdup(filename); if (filename != NULL) this->filename = strdup(filename);
this->name->AddRef(); this->name->AddRef();
this->info->AddRef(); this->info->AddRef();
this->url->AddRef();
} }
/** /**
@ -60,6 +62,7 @@ GRFConfig::GRFConfig(const GRFConfig &config) :
ident(config.ident), ident(config.ident),
name(config.name), name(config.name),
info(config.info), info(config.info),
url(config.url),
version(config.version), version(config.version),
min_loadable_version(config.min_loadable_version), min_loadable_version(config.min_loadable_version),
flags(config.flags & ~(1 << GCF_COPY)), flags(config.flags & ~(1 << GCF_COPY)),
@ -75,6 +78,7 @@ GRFConfig::GRFConfig(const GRFConfig &config) :
if (config.filename != NULL) this->filename = strdup(config.filename); if (config.filename != NULL) this->filename = strdup(config.filename);
this->name->AddRef(); this->name->AddRef();
this->info->AddRef(); this->info->AddRef();
this->url->AddRef();
if (config.error != NULL) this->error = new GRFError(*config.error); if (config.error != NULL) this->error = new GRFError(*config.error);
for (uint i = 0; i < config.param_info.Length(); i++) { for (uint i = 0; i < config.param_info.Length(); i++) {
if (config.param_info[i] == NULL) { if (config.param_info[i] == NULL) {
@ -95,6 +99,7 @@ GRFConfig::~GRFConfig()
} }
this->name->Release(); this->name->Release();
this->info->Release(); this->info->Release();
this->url->Release();
for (uint i = 0; i < this->param_info.Length(); i++) delete this->param_info[i]; for (uint i = 0; i < this->param_info.Length(); i++) delete this->param_info[i];
} }
@ -119,6 +124,15 @@ const char *GRFConfig::GetDescription() const
return GetGRFStringFromGRFText(this->info->text); return GetGRFStringFromGRFText(this->info->text);
} }
/**
* Get the grf url.
* @return A string with an url of this grf.
*/
const char *GRFConfig::GetURL() const
{
return GetGRFStringFromGRFText(this->url->text);
}
/** Set the default value for all parameters as specified by action14. */ /** Set the default value for all parameters as specified by action14. */
void GRFConfig::SetParameterDefaults() void GRFConfig::SetParameterDefaults()
{ {

View File

@ -169,6 +169,7 @@ struct GRFConfig : ZeroedMemoryAllocator {
char *filename; ///< Filename - either with or without full path char *filename; ///< Filename - either with or without full path
GRFTextWrapper *name; ///< NOSAVE: GRF name (Action 0x08) GRFTextWrapper *name; ///< NOSAVE: GRF name (Action 0x08)
GRFTextWrapper *info; ///< NOSAVE: GRF info (author, copyright, ...) (Action 0x08) GRFTextWrapper *info; ///< NOSAVE: GRF info (author, copyright, ...) (Action 0x08)
GRFTextWrapper *url; ///< NOSAVE: URL belonging to this GRF.
GRFError *error; ///< NOSAVE: Error/Warning during GRF loading (Action 0x0B) GRFError *error; ///< NOSAVE: Error/Warning during GRF loading (Action 0x0B)
uint32 version; ///< NOSAVE: Version a NewGRF can set so only the newest NewGRF is shown uint32 version; ///< NOSAVE: Version a NewGRF can set so only the newest NewGRF is shown
@ -190,6 +191,7 @@ struct GRFConfig : ZeroedMemoryAllocator {
const char *GetTextfile(TextfileType type) const; const char *GetTextfile(TextfileType type) const;
const char *GetName() const; const char *GetName() const;
const char *GetDescription() const; const char *GetDescription() const;
const char *GetURL() const;
void SetParameterDefaults(); void SetParameterDefaults();
void SetSuitablePalette(); void SetSuitablePalette();