diff --git a/src/arbits/slbt_archive_meta.c b/src/arbits/slbt_archive_meta.c index 1af0ab8..8c8f999 100644 --- a/src/arbits/slbt_archive_meta.c +++ b/src/arbits/slbt_archive_meta.c @@ -762,7 +762,8 @@ int slbt_get_archive_meta( symrefs_32 = m->armaps.armap_symrefs_32; for (idx=0; idxarmaps.armap_nsyms; idx++) { - symrefs_32[idx].ar_name_offset = m->symstrv[idx] - m->symstrv[0]; + if (m->armaps.armap_common_32.ar_armap_attr & AR_ARMAP_ATTR_SYSV) + symrefs_32[idx].ar_name_offset = m->symstrv[idx] - m->symstrv[0]; if (!slbt_archive_member_from_offset(m,symrefs_32[idx].ar_member_offset)) return slbt_free_archive_meta_impl( @@ -787,7 +788,8 @@ int slbt_get_archive_meta( symrefs_64 = m->armaps.armap_symrefs_64; for (idx=0; idxarmaps.armap_nsyms; idx++) { - symrefs_64[idx].ar_name_offset = m->symstrv[idx] - m->symstrv[0]; + if (m->armaps.armap_common_64.ar_armap_attr & AR_ARMAP_ATTR_SYSV) + symrefs_64[idx].ar_name_offset = m->symstrv[idx] - m->symstrv[0]; if (!slbt_archive_member_from_offset(m,symrefs_64[idx].ar_member_offset)) return slbt_free_archive_meta_impl( diff --git a/src/arbits/slbt_armap_bsd_32.c b/src/arbits/slbt_armap_bsd_32.c index ed236b6..f41c500 100644 --- a/src/arbits/slbt_armap_bsd_32.c +++ b/src/arbits/slbt_armap_bsd_32.c @@ -118,13 +118,22 @@ int slbt_ar_parse_primary_armap_bsd_32( mark = armap->ar_first_name_offset; symrefs = m->armaps.armap_symrefs_32; - for (idx=0,uch=*++mark; idxar_string_table = m->symstrv; diff --git a/src/arbits/slbt_armap_bsd_64.c b/src/arbits/slbt_armap_bsd_64.c index b7b7d6d..6dcc737 100644 --- a/src/arbits/slbt_armap_bsd_64.c +++ b/src/arbits/slbt_armap_bsd_64.c @@ -127,7 +127,21 @@ int slbt_ar_parse_primary_armap_bsd_64( mark = armap->ar_first_name_offset; symrefs = m->armaps.armap_symrefs_64; - for (idx=0,uch=*++mark; idxar_string_table = m->symstrv;