Skip to content

Commit

Permalink
Emit extended name section
Browse files Browse the repository at this point in the history
Emit names of types, tables, memories, global, elements
and data.
  • Loading branch information
surban committed Nov 26, 2024
1 parent 258fc30 commit f0b94d4
Show file tree
Hide file tree
Showing 4 changed files with 122 additions and 7 deletions.
4 changes: 2 additions & 2 deletions crates/tests/tests/round_trip/gc_keep_used_globals.wat
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,6 @@

(; CHECK-ALL:
(module
(global (;0;) i32 i32.const 666)
(export "g" (global 0))
(global $used (;0;) i32 i32.const 666)
(export "g" (global $used))
;)
4 changes: 2 additions & 2 deletions crates/tests/tests/round_trip/gc_keep_used_memories.wat
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,6 @@

(; CHECK-ALL:
(module
(memory (;0;) 2)
(export "m" (memory 0))
(memory $m (;0;) 2)
(export "m" (memory $m))
;)
5 changes: 3 additions & 2 deletions src/module/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,9 @@ impl ModuleConfig {
/// Sets a flag to whether the custom "name" section is generated for this
/// module.
///
/// The "name" section contains symbol names for the module, functions, and
/// locals. When enabled, stack traces will use these names, instead of
/// The "name" section contains symbol names for the module, functions,
/// locals, types, memories, tables, data, elements and globals.
/// When enabled, stack traces will use these names, instead of
/// `wasm-function[123]`.
///
/// By default this flag is `true`.
Expand Down
116 changes: 115 additions & 1 deletion src/module/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -566,10 +566,76 @@ fn emit_name_section(cx: &mut EmitContext) {
.collect::<Vec<_>>();
locals.sort_by_key(|p| p.0); // sort by index

if cx.module.name.is_none() && funcs.is_empty() && locals.is_empty() {
let mut types = cx
.module
.types
.iter()
.filter_map(|typ| typ.name.as_ref().map(|name| (typ, name)))
.map(|(typ, name)| (cx.indices.get_type_index(typ.id()), name))
.collect::<Vec<_>>();
types.sort_by_key(|p| p.0); // sort by index

let mut tables = cx
.module
.tables
.iter()
.filter_map(|table| table.name.as_ref().map(|name| (table, name)))
.map(|(table, name)| (cx.indices.get_table_index(table.id()), name))
.collect::<Vec<_>>();
tables.sort_by_key(|p| p.0); // sort by index

let mut memories = cx
.module
.memories
.iter()
.filter_map(|memory| memory.name.as_ref().map(|name| (memory, name)))
.map(|(memory, name)| (cx.indices.get_memory_index(memory.id()), name))
.collect::<Vec<_>>();
memories.sort_by_key(|p| p.0); // sort by index

let mut globals = cx
.module
.globals
.iter()
.filter_map(|global| global.name.as_ref().map(|name| (global, name)))
.map(|(global, name)| (cx.indices.get_global_index(global.id()), name))
.collect::<Vec<_>>();
globals.sort_by_key(|p| p.0); // sort by index

let mut elements = cx
.module
.elements
.iter()
.filter_map(|element| element.name.as_ref().map(|name| (element, name)))
.map(|(element, name)| (cx.indices.get_element_index(element.id()), name))
.collect::<Vec<_>>();
elements.sort_by_key(|p| p.0); // sort by index

let mut data = cx
.module
.data
.iter()
.filter_map(|data| data.name.as_ref().map(|name| (data, name)))
.map(|(data, name)| (cx.indices.get_data_index(data.id()), name))
.collect::<Vec<_>>();
data.sort_by_key(|p| p.0); // sort by index

if cx.module.name.is_none()
&& funcs.is_empty()
&& locals.is_empty()
&& types.is_empty()
&& tables.is_empty()
&& memories.is_empty()
&& globals.is_empty()
&& elements.is_empty()
&& data.is_empty()
{
return;
}

// Order of written subsections must match order defined in
// `wasm_encorder::names::Subsection`.

if let Some(name) = &cx.module.name {
wasm_name_section.module(name);
}
Expand All @@ -595,5 +661,53 @@ fn emit_name_section(cx: &mut EmitContext) {
wasm_name_section.locals(&indirect_name_map);
}

if !types.is_empty() {
let mut name_map = wasm_encoder::NameMap::new();
for (index, name) in types {
name_map.append(index, name);
}
wasm_name_section.types(&name_map);
}

if !tables.is_empty() {
let mut name_map = wasm_encoder::NameMap::new();
for (index, name) in tables {
name_map.append(index, name);
}
wasm_name_section.tables(&name_map);
}

if !memories.is_empty() {
let mut name_map = wasm_encoder::NameMap::new();
for (index, name) in memories {
name_map.append(index, name);
}
wasm_name_section.memories(&name_map);
}

if !globals.is_empty() {
let mut name_map = wasm_encoder::NameMap::new();
for (index, name) in globals {
name_map.append(index, name);
}
wasm_name_section.globals(&name_map);
}

if !elements.is_empty() {
let mut name_map = wasm_encoder::NameMap::new();
for (index, name) in elements {
name_map.append(index, name);
}
wasm_name_section.elements(&name_map);
}

if !data.is_empty() {
let mut name_map = wasm_encoder::NameMap::new();
for (index, name) in data {
name_map.append(index, name);
}
wasm_name_section.data(&name_map);
}

cx.wasm_module.section(&wasm_name_section);
}

0 comments on commit f0b94d4

Please sign in to comment.