2020-05-04 02:52:56 -04:00
|
|
|
#ifndef RBIMPL_ROBJECT_H /*-*-C++-*-vi:se ft=cpp:*/
|
|
|
|
#define RBIMPL_ROBJECT_H
|
2020-04-10 01:11:40 -04:00
|
|
|
/**
|
2020-04-08 00:28:13 -04:00
|
|
|
* @file
|
|
|
|
* @author Ruby developers <ruby-core@ruby-lang.org>
|
|
|
|
* @copyright This file is a part of the programming language Ruby.
|
|
|
|
* Permission is hereby granted, to either redistribute and/or
|
|
|
|
* modify this file, provided that the conditions mentioned in the
|
|
|
|
* file COPYING are met. Consult the file for details.
|
2020-05-04 03:27:48 -04:00
|
|
|
* @warning Symbols prefixed with either `RBIMPL` or `rbimpl` are
|
2020-04-08 00:28:13 -04:00
|
|
|
* implementation details. Don't take them as canon. They could
|
|
|
|
* rapidly appear then vanish. The name (path) of this header file
|
|
|
|
* is also an implementation detail. Do not expect it to persist
|
|
|
|
* at the place it is now. Developers are free to move it anywhere
|
|
|
|
* anytime at will.
|
|
|
|
* @note To ruby-core: remember that this header can be possibly
|
|
|
|
* recursively included from extension libraries written in C++.
|
|
|
|
* Do not expect for instance `__VA_ARGS__` is always available.
|
|
|
|
* We assume C99 for ruby itself but we don't assume languages of
|
|
|
|
* extension libraries. They could be written in C++98.
|
|
|
|
* @brief Defines struct ::RObject.
|
|
|
|
*/
|
2020-05-08 05:31:09 -04:00
|
|
|
#include "ruby/internal/config.h"
|
2020-04-08 00:28:13 -04:00
|
|
|
|
|
|
|
#ifdef HAVE_STDINT_H
|
|
|
|
# include <stdint.h>
|
|
|
|
#endif
|
|
|
|
|
2020-05-08 05:31:09 -04:00
|
|
|
#include "ruby/internal/attr/artificial.h"
|
2020-08-17 00:51:23 -04:00
|
|
|
#include "ruby/internal/attr/deprecated.h"
|
2020-05-08 05:31:09 -04:00
|
|
|
#include "ruby/internal/attr/pure.h"
|
|
|
|
#include "ruby/internal/cast.h"
|
|
|
|
#include "ruby/internal/fl_type.h"
|
|
|
|
#include "ruby/internal/value.h"
|
|
|
|
#include "ruby/internal/value_type.h"
|
2020-04-08 00:28:13 -04:00
|
|
|
|
2020-05-04 02:52:56 -04:00
|
|
|
#define ROBJECT(obj) RBIMPL_CAST((struct RObject *)(obj))
|
2020-04-08 00:28:13 -04:00
|
|
|
#define ROBJECT_EMBED_LEN_MAX ROBJECT_EMBED_LEN_MAX
|
|
|
|
#define ROBJECT_EMBED ROBJECT_EMBED
|
|
|
|
/** @cond INTERNAL_MACRO */
|
|
|
|
#define ROBJECT_NUMIV ROBJECT_NUMIV
|
|
|
|
#define ROBJECT_IVPTR ROBJECT_IVPTR
|
2020-08-17 00:51:23 -04:00
|
|
|
#define ROBJECT_IV_INDEX_TBL ROBJECT_IV_INDEX_TBL
|
2020-04-08 00:28:13 -04:00
|
|
|
/** @endcond */
|
|
|
|
|
|
|
|
enum ruby_robject_flags { ROBJECT_EMBED = RUBY_FL_USER1 };
|
|
|
|
|
2020-05-04 02:52:56 -04:00
|
|
|
enum ruby_robject_consts { ROBJECT_EMBED_LEN_MAX = RBIMPL_EMBED_LEN_MAX_OF(VALUE) };
|
2020-04-08 00:28:13 -04:00
|
|
|
|
2020-08-17 00:51:23 -04:00
|
|
|
struct st_table;
|
|
|
|
|
2020-04-08 00:28:13 -04:00
|
|
|
struct RObject {
|
|
|
|
struct RBasic basic;
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
uint32_t numiv;
|
|
|
|
VALUE *ivptr;
|
2020-08-17 00:51:23 -04:00
|
|
|
struct st_table *iv_index_tbl; /* shortcut for RCLASS_IV_INDEX_TBL(rb_obj_class(obj)) */
|
2020-04-08 00:28:13 -04:00
|
|
|
} heap;
|
|
|
|
VALUE ary[ROBJECT_EMBED_LEN_MAX];
|
|
|
|
} as;
|
|
|
|
};
|
|
|
|
|
2020-05-19 22:38:44 -04:00
|
|
|
RBIMPL_ATTR_PURE_UNLESS_DEBUG()
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_ATTR_ARTIFICIAL()
|
2020-04-08 00:28:13 -04:00
|
|
|
static inline uint32_t
|
|
|
|
ROBJECT_NUMIV(VALUE obj)
|
|
|
|
{
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_ASSERT_TYPE(obj, RUBY_T_OBJECT);
|
2020-04-08 00:28:13 -04:00
|
|
|
|
|
|
|
if (RB_FL_ANY_RAW(obj, ROBJECT_EMBED)) {
|
|
|
|
return ROBJECT_EMBED_LEN_MAX;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return ROBJECT(obj)->as.heap.numiv;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-19 22:38:44 -04:00
|
|
|
RBIMPL_ATTR_PURE_UNLESS_DEBUG()
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_ATTR_ARTIFICIAL()
|
2020-04-08 00:28:13 -04:00
|
|
|
static inline VALUE *
|
|
|
|
ROBJECT_IVPTR(VALUE obj)
|
|
|
|
{
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_ASSERT_TYPE(obj, RUBY_T_OBJECT);
|
2020-04-08 00:28:13 -04:00
|
|
|
|
|
|
|
struct RObject *const ptr = ROBJECT(obj);
|
|
|
|
|
|
|
|
if (RB_FL_ANY_RAW(obj, ROBJECT_EMBED)) {
|
|
|
|
return ptr->as.ary;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return ptr->as.heap.ivptr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-04 02:52:56 -04:00
|
|
|
#endif /* RBIMPL_ROBJECT_H */
|