summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-02-25 10:33:39 -0800
committerAlon Zakai <alonzakai@gmail.com>2016-02-25 10:33:39 -0800
commit324962ecf1dd63eebfc94993df0d7e91c86a96f0 (patch)
treea0f84857aa5cd7ceda6c34e7949140877ef5eff6 /src
parent51c52bb5e1547c4abece7e9ee0ca0c5fa1e8f4e2 (diff)
downloadbinaryen-324962ecf1dd63eebfc94993df0d7e91c86a96f0.tar.gz
binaryen-324962ecf1dd63eebfc94993df0d7e91c86a96f0.tar.bz2
binaryen-324962ecf1dd63eebfc94993df0d7e91c86a96f0.zip
support function indexes in tables
Diffstat (limited to 'src')
-rw-r--r--src/wasm-s-parser.h9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/wasm-s-parser.h b/src/wasm-s-parser.h
index 30a9e683f..d0206bcc2 100644
--- a/src/wasm-s-parser.h
+++ b/src/wasm-s-parser.h
@@ -222,6 +222,7 @@ class SExpressionWasmBuilder {
AllocatingModule& wasm;
MixedArena& allocator;
std::function<void ()> onError;
+ std::vector<Name> functionNames;
int functionCounter;
int importCounter;
std::map<Name, WasmType> functionTypes; // we need to know function return types before we parse their contents
@@ -258,6 +259,7 @@ private:
// unnamed, use an index
name = Name::fromInt(functionCounter);
}
+ functionNames.push_back(name);
functionCounter++;
for (;i < s.size(); i++) {
Element& curr = *s[i];
@@ -1036,7 +1038,12 @@ private:
void parseTable(Element& s) {
for (size_t i = 1; i < s.size(); i++) {
- wasm.table.names.push_back(s[i]->str());
+ Name name = s[i]->str();
+ if (!s[i]->dollared()) {
+ // index, we haven't
+ name = functionNames[atoi(name.str)];
+ }
+ wasm.table.names.push_back(name);
}
}