From ce2c97d738d6eb374e6dedf6e082b06a61ab6ef9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=8D=9C=E9=83=A8=E6=98=8C=E5=B9=B3?= Date: Wed, 4 Dec 2019 14:15:46 +0900 Subject: [PATCH] internal/symbol.h rework Some declatations are moved from internal/parse.h, to reflect the fact that they are defined in symbol.c. --- internal/parse.h | 8 -------- internal/symbol.h | 26 +++++++++++++++++--------- 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/internal/parse.h b/internal/parse.h index f70e8e75a3..0132557951 100644 --- a/internal/parse.h +++ b/internal/parse.h @@ -19,13 +19,5 @@ RUBY_SYMBOL_EXPORT_BEGIN VALUE rb_parser_set_context(VALUE, const struct rb_iseq_struct *, int); RUBY_SYMBOL_EXPORT_END void *rb_parser_load_file(VALUE parser, VALUE name); -int rb_is_const_name(VALUE name); -int rb_is_class_name(VALUE name); -int rb_is_instance_name(VALUE name); -int rb_is_local_name(VALUE name); -PUREFUNC(int rb_is_const_sym(VALUE sym)); -PUREFUNC(int rb_is_attrset_sym(VALUE sym)); -ID rb_make_internal_id(void); -void rb_gc_free_dsymbol(VALUE); #endif /* INTERNAL_PARSE_H */ diff --git a/internal/symbol.h b/internal/symbol.h index 8423cb4dc8..0317f66561 100644 --- a/internal/symbol.h +++ b/internal/symbol.h @@ -9,21 +9,29 @@ * modify this file, provided that the conditions mentioned in the * file COPYING are met. Consult the file for details. */ +#include "ruby/ruby.h" /* for VALUE */ +#include "ruby/encoding.h" /* for rb_encoding */ +#include "internal/compilers.h" /* for __has_builtin */ /* symbol.c */ -#ifdef RUBY_ENCODING_H +VALUE rb_to_symbol_type(VALUE obj); VALUE rb_sym_intern(const char *ptr, long len, rb_encoding *enc); -#endif VALUE rb_sym_intern_ascii(const char *ptr, long len); VALUE rb_sym_intern_ascii_cstr(const char *ptr); -#ifdef __GNUC__ -#define rb_sym_intern_ascii_cstr(ptr) __extension__ ( \ -{ \ - (__builtin_constant_p(ptr)) ? \ +int rb_is_const_name(VALUE name); +int rb_is_class_name(VALUE name); +int rb_is_instance_name(VALUE name); +int rb_is_local_name(VALUE name); +PUREFUNC(int rb_is_const_sym(VALUE sym)); +PUREFUNC(int rb_is_attrset_sym(VALUE sym)); +ID rb_make_internal_id(void); +void rb_gc_free_dsymbol(VALUE); + +#if __has_builtin(__builtin_constant_p) +#define rb_sym_intern_ascii_cstr(ptr) \ + (__builtin_constant_p(ptr) ? \ rb_sym_intern_ascii((ptr), (long)strlen(ptr)) : \ - rb_sym_intern_ascii_cstr(ptr); \ -}) + rb_sym_intern_ascii_cstr(ptr)) #endif -VALUE rb_to_symbol_type(VALUE obj); #endif /* INTERNAL_SYMBOL_H */