static void dr_metalib_validate_align_i(error_monitor_t em, LPDRMETALIB metalib) { int meta_pos; int meta_count; meta_count = dr_lib_meta_num(metalib); for(meta_pos = 0; meta_pos < meta_count; ++meta_pos) { LPDRMETA meta; int entry_pos; int entry_count; meta = dr_lib_meta_at(metalib, meta_pos); entry_count = dr_meta_entry_num(meta); for(entry_pos = 0; entry_pos < entry_count; ++entry_pos) { LPDRMETAENTRY entry = dr_meta_entry_at(meta, entry_pos); int align = dr_entry_align(entry); if (align != 1 && align != 2 && align != 4 && align != 8) { CPE_ERROR( em, "%s.%s: type align %d error", dr_meta_name(meta), dr_entry_name(entry), align); continue; } if ((int)dr_entry_data_start_pos(entry) % align) { CPE_ERROR( em, "%s.%s: start pos error, align is %d, startpos is %d", dr_meta_name(meta), dr_entry_name(entry), align, (int)dr_entry_data_start_pos(entry)); continue; } } } }
static void cpe_dr_generate_h_metas(write_stream_t stream, dr_metalib_source_t source, cpe_dr_generate_ctx_t ctx) { struct dr_metalib_source_element_it element_it; dr_metalib_source_element_t element; int curent_pack; int packed; curent_pack = 0; packed = 0; dr_metalib_source_elements(&element_it, source); while((element = dr_metalib_source_element_next(&element_it))) { LPDRMETA meta; int entry_pos; if (dr_metalib_source_element_type(element) != dr_metalib_source_element_type_meta) continue; meta = dr_lib_find_meta_by_name(ctx->m_metalib, dr_metalib_source_element_name(element)); if (meta == NULL) continue; if (dr_meta_align(meta) != curent_pack) { stream_printf(stream, "\n#pragma pack(1)\n"); curent_pack = dr_meta_align(meta); packed = 1; } stream_printf(stream, "\nstruct %s {", dr_meta_name(meta)); for(entry_pos = 0; entry_pos < dr_meta_entry_num(meta); ++entry_pos) { LPDRMETAENTRY entry = dr_meta_entry_at(meta, entry_pos); stream_printf(stream, "\n"); stream_printf(stream, " "); switch(dr_entry_type(entry)) { case CPE_DR_TYPE_UNION: case CPE_DR_TYPE_STRUCT: { LPDRMETA ref_meta; ref_meta = dr_entry_ref_meta(entry); if (ref_meta == NULL) continue; stream_printf(stream, "%s %s %s", dr_type_name(dr_entry_type(entry)), dr_meta_name(ref_meta), dr_entry_name(entry)); break; } case CPE_DR_TYPE_STRING: { stream_printf(stream, "char %s[%d]", dr_entry_name(entry), dr_entry_size(entry)); break; } default: { stream_printf(stream, "%s_t %s", dr_type_name(dr_entry_type(entry)), dr_entry_name(entry)); break; } } if (dr_entry_array_count(entry) != 1) { stream_printf(stream, "[%d]", dr_entry_array_count(entry) < 1 ? 1 : dr_entry_array_count(entry)); } stream_printf(stream, ";"); } stream_printf(stream, "\n};\n"); } if (packed) { stream_printf(stream, "\n#pragma pack()\n\n"); } }