len += rc;
if (nbuf-len < 4) goto err;
- export->package = unpack_32_le(buf+len);
+ export->package = unpack_s32_le(buf+len);
len += 4;
rc = upkg_decode_index(&tmp, buf+len, nbuf-len);
len += rc;
if (nbuf-len < 4) goto err;
- import->package = unpack_32_le(buf+len);
+ import->package = unpack_s32_le(buf+len);
len += 4;
rc = upkg_decode_index(&tmp, buf+len, nbuf-len);
}
const char *upkg_export_class(struct upkg *pkg, unsigned long idx,
- const char **package, const char **group)
+ const char **package)
{
struct upkg_export *export;
struct upkg_import *iclass, *ipackage;
return NULL;
}
- /* ASSUMPTION: group references are always exports */
- if (export->package < 0) {
- fprintf(stderr, "Assumption Violated: group not export\n");
- return NULL;
- }
-
- /* Get the group name. */
- if (export->package > 0) {
- pkg_idx = export->package - 1;
-
- if (pkg_idx >= pkg->export_count) {
- return NULL;
- }
-
- /* Lots more to handle. Function arguments are stupid. */
-
- if (group) *group = pkg->priv->exports[pkg_idx].name;
- } else {
- if (group) *group = NULL;
- }
-
/* Get the class. */
if (export->class == 0) {
if (package) *package = "Core";