summaryrefslogtreecommitdiff
path: root/src/wasm-s-parser.h
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2016-05-20 11:21:47 -0700
committerAlon Zakai <alonzakai@gmail.com>2016-05-20 11:21:47 -0700
commitb28a3a6eba4c4fbe64333dd544977a0c4f37c650 (patch)
tree0919805194011cc453e7074030dc15c1342f67c3 /src/wasm-s-parser.h
parent244da920eedafec42da4e91b83c09d0021a36a7f (diff)
parenta2f3fbdc80b72fcf04a789e723de7f5561387dcc (diff)
downloadbinaryen-b28a3a6eba4c4fbe64333dd544977a0c4f37c650.tar.gz
binaryen-b28a3a6eba4c4fbe64333dd544977a0c4f37c650.tar.bz2
binaryen-b28a3a6eba4c4fbe64333dd544977a0c4f37c650.zip
Merge pull request #531 from WebAssembly/fixes
Type checking fixes
Diffstat (limited to 'src/wasm-s-parser.h')
-rw-r--r--src/wasm-s-parser.h5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/wasm-s-parser.h b/src/wasm-s-parser.h
index b59af7215..dae321866 100644
--- a/src/wasm-s-parser.h
+++ b/src/wasm-s-parser.h
@@ -1031,6 +1031,7 @@ private:
}
Expression* makeMaybeBlock(Element& s, size_t i, size_t stopAt=-1) {
+ if (s.size() == i) return allocator.alloc<Nop>();
if (s.size() == i+1) return parseExpression(s[i]);
auto ret = allocator.alloc<Block>();
for (; i < s.size() && i < stopAt; i++) {
@@ -1046,13 +1047,13 @@ private:
Expression* makeLoop(Element& s) {
auto ret = allocator.alloc<Loop>();
size_t i = 1;
- if (s[i]->isStr() && s[i+1]->isStr()) { // out can only be named if both are
+ if (s.size() > i + 1 && s[i]->isStr() && s[i + 1]->isStr()) { // out can only be named if both are
ret->out = s[i]->str();
i++;
} else {
ret->out = getPrefixedName("loop-out");
}
- if (s[i]->isStr()) {
+ if (s.size() > i && s[i]->isStr()) {
ret->in = s[i]->str();
i++;
} else {