passing around an int as a void* is a very bad idea
This commit is contained in:
parent
d78aea8b8e
commit
2cdd4d56ff
@ -247,18 +247,15 @@ rpm_index **rpm_gettags(int fd, int *num_tags)
|
|||||||
|
|
||||||
int bsearch_rpmtag(const void *key, const void *item)
|
int bsearch_rpmtag(const void *key, const void *item)
|
||||||
{
|
{
|
||||||
|
int *tag = (int *)key;
|
||||||
rpm_index **tmp = (rpm_index **) item;
|
rpm_index **tmp = (rpm_index **) item;
|
||||||
/* gcc throws warnings here when sizeof(void*)!=sizeof(int) ...
|
return (*tag - tmp[0]->tag);
|
||||||
* it's ok to ignore it because this isn't a 'real' pointer */
|
|
||||||
return ((int) key - tmp[0]->tag);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int rpm_getcount(int tag)
|
int rpm_getcount(int tag)
|
||||||
{
|
{
|
||||||
rpm_index **found;
|
rpm_index **found;
|
||||||
/* gcc throws warnings here when sizeof(void*)!=sizeof(int) ...
|
found = bsearch(&tag, mytags, tagcount, sizeof(struct rpmtag *), bsearch_rpmtag);
|
||||||
* it's ok to ignore it because tag won't be used as a pointer */
|
|
||||||
found = bsearch((void *) tag, mytags, tagcount, sizeof(struct rpmtag *), bsearch_rpmtag);
|
|
||||||
if (!found) return 0;
|
if (!found) return 0;
|
||||||
else return found[0]->count;
|
else return found[0]->count;
|
||||||
}
|
}
|
||||||
@ -266,9 +263,7 @@ int rpm_getcount(int tag)
|
|||||||
char *rpm_getstring(int tag, int itemindex)
|
char *rpm_getstring(int tag, int itemindex)
|
||||||
{
|
{
|
||||||
rpm_index **found;
|
rpm_index **found;
|
||||||
/* gcc throws warnings here when sizeof(void*)!=sizeof(int) ...
|
found = bsearch(&tag, mytags, tagcount, sizeof(struct rpmtag *), bsearch_rpmtag);
|
||||||
* it's ok to ignore it because tag won't be used as a pointer */
|
|
||||||
found = bsearch((void *) tag, mytags, tagcount, sizeof(struct rpmtag *), bsearch_rpmtag);
|
|
||||||
if (!found || itemindex >= found[0]->count) return NULL;
|
if (!found || itemindex >= found[0]->count) return NULL;
|
||||||
if (found[0]->type == RPM_STRING_TYPE || found[0]->type == RPM_I18NSTRING_TYPE || found[0]->type == RPM_STRING_ARRAY_TYPE) {
|
if (found[0]->type == RPM_STRING_TYPE || found[0]->type == RPM_I18NSTRING_TYPE || found[0]->type == RPM_STRING_ARRAY_TYPE) {
|
||||||
int n;
|
int n;
|
||||||
@ -284,7 +279,7 @@ int rpm_getint(int tag, int itemindex)
|
|||||||
int n, *tmpint;
|
int n, *tmpint;
|
||||||
/* gcc throws warnings here when sizeof(void*)!=sizeof(int) ...
|
/* gcc throws warnings here when sizeof(void*)!=sizeof(int) ...
|
||||||
* it's ok to ignore it because tag won't be used as a pointer */
|
* it's ok to ignore it because tag won't be used as a pointer */
|
||||||
found = bsearch((void *) tag, mytags, tagcount, sizeof(struct rpmtag *), bsearch_rpmtag);
|
found = bsearch(&tag, mytags, tagcount, sizeof(struct rpmtag *), bsearch_rpmtag);
|
||||||
if (!found || itemindex >= found[0]->count) return -1;
|
if (!found || itemindex >= found[0]->count) return -1;
|
||||||
tmpint = (int *) (map + found[0]->offset);
|
tmpint = (int *) (map + found[0]->offset);
|
||||||
if (found[0]->type == RPM_INT32_TYPE) {
|
if (found[0]->type == RPM_INT32_TYPE) {
|
||||||
|
Loading…
Reference in New Issue
Block a user