From d2a81a3aa319d7f1c24c32e315dbf2b7c0e099a9 Mon Sep 17 00:00:00 2001 From: nobu Date: Thu, 2 Jun 2005 14:43:10 +0000 Subject: * parse.y: pragma support on ripper. [ruby-dev:26266] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@8549 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- parse.y | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'parse.y') diff --git a/parse.y b/parse.y index 99cab85b7a..b5e040944d 100644 --- a/parse.y +++ b/parse.y @@ -4559,7 +4559,7 @@ rb_compile_string(f, s, line) { VALUE volatile vparser = rb_parser_s_new(); struct parser_params *parser; - + Data_Get_Struct(vparser, struct parser_params, parser); lex_gets = lex_get_str; lex_gets_ptr = 0; @@ -5359,6 +5359,7 @@ lvar_defined_gen(parser, id) } /* emacsen -*- hack */ +#ifndef RIPPER typedef void (*rb_pragma_setter_t) _((struct parser_params *parser, const char *name, const char *val)); static void pragma_encoding _((struct parser_params *, const char *, const char *)); @@ -5380,6 +5381,7 @@ struct pragma { static const struct pragma pragmas[] = { {"coding", pragma_encoding}, }; +#endif static const char * pragma_marker(str, len) @@ -5437,7 +5439,9 @@ parser_pragma(parser, str, len) /* %r"([^\\s\'\":;]+)\\s*:\\s*(\"(?:\\\\.|[^\"])*\"|[^\"\\s;]+)[\\s;]*" */ while (len > 0) { +#ifndef RIPPER const struct pragma *p = pragmas; +#endif int n = 0; for (; len > 0 && *str; str++, --len) { @@ -5485,6 +5489,7 @@ parser_pragma(parser, str, len) n = end - beg; str_copy(name, beg, n); rb_funcall(name, rb_intern("downcase!"), 0); +#ifndef RIPPER do { if (strncmp(p->name, RSTRING(name)->ptr, n) == 0) { str_copy(val, vbeg, vend - vbeg); @@ -5492,6 +5497,9 @@ parser_pragma(parser, str, len) break; } } while (++p < pragmas + sizeof(pragmas) / sizeof(*p)); +#else + dispatch2(pragma, name, val); +#endif } return Qtrue; -- cgit v1.2.3