summaryrefslogtreecommitdiffhomepage
path: root/mrbgems/mruby-compiler/core/y.tab.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2021-02-13 14:06:37 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2021-02-13 14:06:37 +0900
commit94fb86f89b131814201596d301f584dfe4547526 (patch)
tree02ec7cfd84cf600196dd71f8de46f17cda59e7ec /mrbgems/mruby-compiler/core/y.tab.c
parentadb50df71a4e5c45cdf9c626fb90f95ef2d10b13 (diff)
downloadmruby-94fb86f89b131814201596d301f584dfe4547526.tar.gz
mruby-94fb86f89b131814201596d301f584dfe4547526.zip
parse.y: string buffer (`tokbuf`) can overflow.
Check if `esclen` is smaller than `len` (original string length).
Diffstat (limited to 'mrbgems/mruby-compiler/core/y.tab.c')
-rw-r--r--mrbgems/mruby-compiler/core/y.tab.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/mrbgems/mruby-compiler/core/y.tab.c b/mrbgems/mruby-compiler/core/y.tab.c
index 6c7940a7b..0ba1c8d7f 100644
--- a/mrbgems/mruby-compiler/core/y.tab.c
+++ b/mrbgems/mruby-compiler/core/y.tab.c
@@ -10718,6 +10718,7 @@ heredoc_remove_indent(parser_state *p, parser_heredoc_info *hinf)
start = 0;
while (start < len) {
end = escaped ? (size_t)escaped->car : len;
+ if (end > len) end = len;
spaces = (size_t)nspaces->car;
size_t esclen = end - start;
heredoc_count_indent(hinf, str + start, esclen, spaces, &offset);