ignore obsolete "lua" attributes in ancient data files.

fix a small bug in the mechanism for reading deprecated attrib_types.
This commit is contained in:
Enno Rehling 2014-12-13 22:08:57 +01:00
parent 1ae44db7ca
commit 455b3dc90e
3 changed files with 14 additions and 2 deletions

View file

@ -81,6 +81,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#endif #endif
/* external libraries */ /* external libraries */
#include <storage.h>
#include <iniparser.h> #include <iniparser.h>
#include <critbit.h> #include <critbit.h>
@ -2132,6 +2133,16 @@ bool has_limited_skills(const struct unit * u)
} }
} }
static int read_ext(attrib * a, void *owner, struct storage *store)
{
int len;
READ_INT(store, &len);
store->api->r_bin(store->handle, NULL, (size_t)len);
return AT_READ_OK;
}
void attrib_init(void) void attrib_init(void)
{ {
/* Alle speicherbaren Attribute müssen hier registriert werden */ /* Alle speicherbaren Attribute müssen hier registriert werden */
@ -2178,6 +2189,7 @@ void attrib_init(void)
at_register(&at_germs); at_register(&at_germs);
at_deprecate("xontormiaexpress", a_readint); /* required for old datafiles */ at_deprecate("xontormiaexpress", a_readint); /* required for old datafiles */
at_deprecate("lua", read_ext); /* required for old datafiles */
} }
void kernel_init(void) void kernel_init(void)

View file

@ -4701,7 +4701,7 @@ int sp_gooddreams(castorder * co)
} }
/* ------------------------------------------------------------- */ /* ------------------------------------------------------------- */
/* Name: /* Name: Seelenkopie / Doppelganger
* Stufe: 9 * Stufe: 9
* Kategorie: * Kategorie:
* Wirkung: * Wirkung:

View file

@ -299,7 +299,7 @@ int a_read(struct storage *store, attrib ** attribs, void *owner)
na = a_new(at); na = a_new(at);
} }
else { else {
const void * kv; const void * kv = 0;
cb_find_prefix(&cb_deprecated, zText, strlen(zText) + 1, &kv, 1, 0); cb_find_prefix(&cb_deprecated, zText, strlen(zText) + 1, &kv, 1, 0);
if (kv) { if (kv) {
cb_get_kv(kv, &reader, sizeof(reader)); cb_get_kv(kv, &reader, sizeof(reader));