From a8a25b36f1db3812087a6547021846d8c9893d4d Mon Sep 17 00:00:00 2001 From: nobu Date: Fri, 1 Dec 2017 04:27:32 +0000 Subject: prelude.c.tmpl: escape comments git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@60955 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- template/prelude.c.tmpl | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'template') diff --git a/template/prelude.c.tmpl b/template/prelude.c.tmpl index 52f5968f19..8ffc2b8ac4 100644 --- a/template/prelude.c.tmpl +++ b/template/prelude.c.tmpl @@ -9,6 +9,8 @@ class Prelude LINE_LIMIT = 509 # by C89 C_ESC = { + "/*" => "/\\*", + "*/" => "*\\/", "\\" => "\\\\", '"' => '\"', "\n" => '\n', @@ -19,7 +21,7 @@ class Prelude C_ESC_PAT = Regexp.union(*C_ESC.keys) def c_esc(str) - '"' + str.gsub(C_ESC_PAT) { C_ESC[$&] } + '"' + str.gsub(C_ESC_PAT) { C_ESC[$&] } end def prelude_base(filename) filename.chomp(".rb") @@ -83,7 +85,7 @@ Prelude.new(output && output[/\w+(?=_prelude.c\b)/] || 'prelude', ARGV, vpath).i % preludes = @preludes.values.sort % preludes.each {|i, prelude, lines, sub| -static const char prelude_name<%=i%><%=%>[] = <%=c_esc(prelude_name(*prelude))%><%=%>; +static const char prelude_name<%=i%><%=%>[] = "<%=c_esc(prelude_name(*prelude))%>"; static const struct { % size = beg = 0 % lines.each_with_index {|(line, comment), n| @@ -100,15 +102,15 @@ static const struct { % end } prelude_code<%=i%><%=%> = { % size = 0 -#line 1 <%=c_esc(prelude)%> +#line 1 "<%=c_esc(prelude)%>" % lines.each_with_index {|(line, comment), n| % if size + line.size >= Prelude::LINE_LIMIT % size = 0 , -#line <%=n+1%> <%=c_esc(prelude)%> +#line <%=n+1%> "<%=c_esc(prelude)%>" % end % size += line.size -<%=c_esc(line)%><%=%><%if comment%>/* <%=comment%> */<%end%> +"<%=c_esc(line)%>"<%if comment%>/* <%=c_esc(comment)%> */<%end%> % } #line <%=_erbout.count("\n")+2%> "<%=@init_name%>.c" }; -- cgit v1.2.3