Ruby 4.1.0dev (2025-12-27 revision a8c3d5e127776d74eb068c95610277feb99adcf0)
symbol.h
Go to the documentation of this file.
1#ifndef RBIMPL_SYMBOL_H /*-*-C++-*-vi:se ft=cpp:*/
2#define RBIMPL_SYMBOL_H
23#include "ruby/internal/config.h"
24
25#ifdef STDC_HEADERS
26# include <stddef.h>
27#endif
28
29#ifdef HAVE_STRING_H
30# include <string.h>
31#endif
32
36#include "ruby/internal/cast.h"
40#include "ruby/internal/value.h"
41
42#define RB_ID2SYM rb_id2sym
43#define RB_SYM2ID rb_sym2id
44#define ID2SYM RB_ID2SYM
45#define SYM2ID RB_SYM2ID
46#define CONST_ID_CACHE RUBY_CONST_ID_CACHE
47#define CONST_ID RUBY_CONST_ID
50#define rb_intern_const rb_intern_const
54
55
62ID rb_sym2id(VALUE obj);
63
72
85ID rb_intern(const char *name);
86
101ID rb_intern2(const char *name, long len);
102
117ID rb_intern_str(VALUE str);
118
135const char *rb_id2name(ID id);
136
177ID rb_check_id(volatile VALUE *namep);
178
197ID rb_to_id(VALUE str);
198
213VALUE rb_id2str(ID id);
214
223VALUE rb_sym2str(VALUE symbol);
224
241
261VALUE rb_check_symbol(volatile VALUE *namep);
263
284static inline ID
285rb_intern_const(const char *str)
286{
287 size_t len = strlen(str);
288 return rb_intern2(str, RBIMPL_CAST((long)len));
289}
290
298static inline ID
299rbimpl_intern_const(ID *ptr, const char *str)
300{
301 while (! *ptr) {
302 *ptr = rb_intern_const(str);
303 }
304
305 return *ptr;
306}
307
312#define RUBY_CONST_ID_CACHE(result, str) \
313 { \
314 static ID rb_intern_id_cache; \
315 rbimpl_intern_const(&rb_intern_id_cache, (str)); \
316 result rb_intern_id_cache; \
317 }
318
324#define RUBY_CONST_ID(var, str) \
325 do { \
326 static ID rbimpl_id; \
327 (var) = rbimpl_intern_const(&rbimpl_id, (str)); \
328 } while (0)
329
330#if defined(HAVE_STMT_AND_DECL_IN_EXPR)
331/* GCC specific shorthand for RUBY_CONST_ID().
332 * __builtin_constant_p and statement expression is available
333 * since gcc-2.7.2.3 at least. */
334#define rb_intern(str) \
335 (RBIMPL_CONSTANT_P(str) ? \
336 __extension__ ({ \
337 static ID rbimpl_id; \
338 rbimpl_intern_const(&rbimpl_id, (str)); \
339 }) : \
340 (rb_intern)(str))
341#endif
342
343#endif /* RBIMPL_SYMBOL_H */
Defines RBIMPL_CONSTANT_P.
Tweaking visibility of C variables/functions.
#define RBIMPL_SYMBOL_EXPORT_END()
Counterpart of RBIMPL_SYMBOL_EXPORT_BEGIN.
Definition dllexport.h:74
#define RBIMPL_SYMBOL_EXPORT_BEGIN()
Shortcut macro equivalent to RUBY_SYMBOL_EXPORT_BEGIN extern "C" {.
Definition dllexport.h:65
Defines RBIMPL_HAS_BUILTIN.
VALUE rb_check_symbol(volatile VALUE *namep)
Identical to rb_check_id(), except it returns an instance of rb_cSymbol instead.
Definition symbol.c:1190
static ID rb_intern_const(const char *str)
This is a "tiny optimisation" over rb_intern().
Definition symbol.h:285
VALUE rb_id2sym(ID id)
Allocates an instance of rb_cSymbol that has the given id.
Definition symbol.c:974
ID rb_check_id(volatile VALUE *namep)
Detects if the given name is already interned or not.
Definition symbol.c:1133
VALUE rb_sym2str(VALUE symbol)
Obtain a frozen string representation of a symbol (not including the leading colon).
Definition symbol.c:993
VALUE rb_to_symbol(VALUE name)
Identical to rb_intern_str(), except it generates a dynamic symbol if necessary.
Definition string.c:12672
ID rb_sym2id(VALUE obj)
Converts an instance of rb_cSymbol into an ID.
Definition symbol.c:943
ID rb_to_id(VALUE str)
Identical to rb_intern_str(), except it tries to convert the parameter object to an instance of rb_cS...
Definition string.c:12662
int len
Length of the buffer.
Definition io.h:8
Defines RBIMPL_ATTR_NOALIAS.
#define RBIMPL_ATTR_NOALIAS()
Wraps (or simulates) __declspec((noalias))
Definition noalias.h:66
Defines RBIMPL_ATTR_NONNULL.
#define RBIMPL_ATTR_NONNULL(list)
Wraps (or simulates) __attribute__((nonnull))
Definition nonnull.h:30
#define inline
Old Visual Studio versions do not support the inline keyword, so we need to define it to be __inline.
Definition defines.h:91
Defines RBIMPL_ATTR_PURE.
#define RBIMPL_ATTR_PURE()
Wraps (or simulates) __attribute__((pure))
Definition pure.h:33
Defines VALUE and ID.
uintptr_t ID
Type that represents a Ruby identifier such as a variable name.
Definition value.h:52
uintptr_t VALUE
Type that represents a Ruby object.
Definition value.h:40