Handle DMAP long type properly in dmap_add_field()

This commit is contained in:
Julien BLACHE 2010-02-02 21:03:00 +01:00
parent 58faeaceca
commit 1a3620d0a4

View File

@ -490,18 +490,31 @@ dmap_find_field(uint32_t hash)
} }
static void static void
dmap_add_field(struct evbuffer *evbuf, struct dmap_field_map *dfm, char *strval, int intval) dmap_add_field(struct evbuffer *evbuf, struct dmap_field_map *dfm, char *strval, int32_t intval)
{ {
int64_t val64;
int32_t val; int32_t val;
int ret; int ret;
val = intval; if (strval && (dfm->type != DMAP_TYPE_STRING))
if ((dfm->type != DMAP_TYPE_STRING) && (val == 0) && strval)
{ {
ret = safe_atoi32(strval, &val); if (dfm->type == DMAP_TYPE_LONG)
if (ret < 0) {
val = 0; ret = safe_atoi64(strval, &val64);
if (ret < 0)
val64 = 0;
}
else
{
ret = safe_atoi32(strval, &val);
if (ret < 0)
val = 0;
}
}
else
{
val = intval;
val64 = intval;
} }
switch (dfm->type) switch (dfm->type)
@ -524,9 +537,8 @@ dmap_add_field(struct evbuffer *evbuf, struct dmap_field_map *dfm, char *strval,
break; break;
case DMAP_TYPE_LONG: case DMAP_TYPE_LONG:
/* FIXME: "long" is thought of as a 64bit value */ if (val64)
if (val) dmap_add_long(evbuf, dfm->tag, val64);
dmap_add_long(evbuf, dfm->tag, val);
break; break;
case DMAP_TYPE_STRING: case DMAP_TYPE_STRING: