summaryrefslogtreecommitdiffhomepage
path: root/include
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2020-08-07 14:46:53 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2020-10-12 16:21:29 +0900
commit73e289c54e3e28b6f58a05adccc280478ca59a6a (patch)
tree8b3f6f05b56ba53340ad853e3bff43f95118c752 /include
parentce372122ed4a8eb7baa34487df20a59c56ac0d9d (diff)
downloadmruby-73e289c54e3e28b6f58a05adccc280478ca59a6a.tar.gz
mruby-73e289c54e3e28b6f58a05adccc280478ca59a6a.zip
Simplify `mrb_value` structure for `MRB_NAN_BOXING`.
Diffstat (limited to 'include')
-rw-r--r--include/mruby/boxing_nan.h97
1 files changed, 47 insertions, 50 deletions
diff --git a/include/mruby/boxing_nan.h b/include/mruby/boxing_nan.h
index dbc55ec4b..e65123e23 100644
--- a/include/mruby/boxing_nan.h
+++ b/include/mruby/boxing_nan.h
@@ -32,96 +32,93 @@
*/
typedef uint64_t mrb_value;
-struct mrb_value {
- union {
- mrb_float f;
- uint64_t u;
- union {
+union mrb_value {
+ mrb_float f;
+ uint64_t u;
#ifdef MRB_64BIT
- void *p;
+ void *p;
#endif
- struct {
- MRB_ENDIAN_LOHI(
- uint32_t ttt;
- ,union {
- mrb_int i;
- mrb_sym sym;
+ struct {
+ MRB_ENDIAN_LOHI(
+ uint32_t ttt;
+ ,union {
+ mrb_int i;
+ mrb_sym sym;
#ifdef MRB_32BIT
- void *p;
+ void *p;
#endif
- };
- )
};
- } value;
+ )
};
};
-static inline struct mrb_value
-mrb_val_stru(mrb_value v)
+static inline union mrb_value
+mrb_val_union(mrb_value v)
{
- struct mrb_value mrb_value_struct_variable = {.u = v};
- return mrb_value_struct_variable;
+ union mrb_value x;
+ x.u = v;
+ return x;
}
-#define mrb_tt(o) ((enum mrb_vtype)((mrb_val_stru(o).value.ttt & 0xfc000)>>14)-1)
-#define mrb_type(o) (enum mrb_vtype)((uint32_t)0xfff00000 < mrb_val_stru(o).value.ttt ? mrb_tt(o) : MRB_TT_FLOAT)
-#define mrb_float(o) mrb_val_stru(o).f
-#define mrb_fixnum(o) mrb_val_stru(o).value.i
-#define mrb_symbol(o) mrb_val_stru(o).value.sym
+#define mrb_tt(o) ((enum mrb_vtype)((mrb_val_union(o).ttt & 0xfc000)>>14)-1)
+#define mrb_type(o) (enum mrb_vtype)((uint32_t)0xfff00000 < mrb_val_union(o).ttt ? mrb_tt(o) : MRB_TT_FLOAT)
+#define mrb_float(o) mrb_val_union(o).f
+#define mrb_fixnum(o) mrb_val_union(o).i
+#define mrb_symbol(o) mrb_val_union(o).sym
#ifdef MRB_64BIT
-#define mrb_ptr(o) ((void*)((((uintptr_t)0x3fffffffffff)&((uintptr_t)(mrb_val_stru(o).value.p)))<<2))
-MRB_API mrb_value mrb_nan_boxing_cptr_value(struct mrb_state*, void*);
+#define mrb_ptr(o) ((void*)((((uintptr_t)0x3fffffffffff)&((uintptr_t)(mrb_val_union(o).p)))<<2))
#define mrb_cptr(o) (((struct RCptr*)mrb_ptr(o))->p)
#define BOXNAN_SHIFT_LONG_POINTER(v) (((uintptr_t)(v)>>34)&0x3fff)
#else
-#define mrb_ptr(o) (mrb_val_stru(o).value.p)
+#define mrb_ptr(o) (mrb_val_union(o).p)
#define mrb_cptr(o) mrb_ptr(o)
#define BOXNAN_SHIFT_LONG_POINTER(v) 0
#endif
#define BOXNAN_SET_VALUE(o, tt, attr, v) do { \
- struct mrb_value mrb_value_struct_variable; \
- mrb_value_struct_variable.attr = (v);\
- mrb_value_struct_variable.value.ttt = 0xfff00000 | (((tt)+1)<<14);\
- o = mrb_value_struct_variable.u;\
+ union mrb_value mrb_value_union_variable; \
+ mrb_value_union_variable.attr = (v);\
+ mrb_value_union_variable.ttt = 0xfff00000 | (((tt)+1)<<14);\
+ o = mrb_value_union_variable.u;\
} while (0)
#ifdef MRB_64BIT
#define BOXNAN_SET_OBJ_VALUE(o, tt, v) do {\
- struct mrb_value mrb_value_struct_variable;\
- mrb_value_struct_variable.value.p = (void*)((uintptr_t)(v)>>2);\
- mrb_value_struct_variable.value.ttt = (0xfff00000|(((tt)+1)<<14)|BOXNAN_SHIFT_LONG_POINTER(v));\
- o = mrb_value_struct_variable.u;\
+ union mrb_value mrb_value_union_variable;\
+ mrb_value_union_variable.p = (void*)((uintptr_t)(v)>>2);\
+ mrb_value_union_variable.ttt = (0xfff00000|(((tt)+1)<<14)|BOXNAN_SHIFT_LONG_POINTER(v));\
+ o = mrb_value_union_variable.u;\
} while (0)
#else
-#define BOXNAN_SET_OBJ_VALUE(o, tt, v) BOXNAN_SET_VALUE(o, tt, value.p, v)
+#define BOXNAN_SET_OBJ_VALUE(o, tt, v) BOXNAN_SET_VALUE(o, tt, p, v)
#endif
#define SET_FLOAT_VALUE(mrb,r,v) do { \
- struct mrb_value mrb_value_struct_variable; \
+ union mrb_value mrb_value_union_variable; \
if ((v) != (v)) { /* NaN */ \
- mrb_value_struct_variable.value.ttt = 0x7ff80000; \
- mrb_value_struct_variable.value.i = 0; \
+ mrb_value_union_variable.ttt = 0x7ff80000; \
+ mrb_value_union_variable.i = 0; \
} \
else { \
- mrb_value_struct_variable.f = (v); \
+ mrb_value_union_variable.f = (v); \
} \
- r = mrb_value_struct_variable.u; \
+ r = mrb_value_union_variable.u; \
} while(0)
-#define SET_NIL_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, value.i, 0)
-#define SET_FALSE_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, value.i, 1)
-#define SET_TRUE_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_TRUE, value.i, 1)
-#define SET_BOOL_VALUE(r,b) BOXNAN_SET_VALUE(r, b ? MRB_TT_TRUE : MRB_TT_FALSE, value.i, 1)
-#define SET_INT_VALUE(r,n) BOXNAN_SET_VALUE(r, MRB_TT_FIXNUM, value.i, (n))
-#define SET_SYM_VALUE(r,v) BOXNAN_SET_VALUE(r, MRB_TT_SYMBOL, value.sym, (v))
+#define SET_NIL_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, i, 0)
+#define SET_FALSE_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_FALSE, i, 1)
+#define SET_TRUE_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_TRUE, i, 1)
+#define SET_BOOL_VALUE(r,b) BOXNAN_SET_VALUE(r, b ? MRB_TT_TRUE : MRB_TT_FALSE, i, 1)
+#define SET_INT_VALUE(r,n) BOXNAN_SET_VALUE(r, MRB_TT_FIXNUM, i, (n))
+#define SET_SYM_VALUE(r,v) BOXNAN_SET_VALUE(r, MRB_TT_SYMBOL, sym, (v))
#define SET_OBJ_VALUE(r,v) BOXNAN_SET_OBJ_VALUE(r, (((struct RObject*)(v))->tt), (v))
#ifdef MRB_64BIT
+MRB_API mrb_value mrb_nan_boxing_cptr_value(struct mrb_state*, void*);
#define SET_CPTR_VALUE(mrb,r,v) ((r) = mrb_nan_boxing_cptr_value(mrb, v))
#else
-#define SET_CPTR_VALUE(mrb,r,v) BOXNAN_SET_VALUE(r, MRB_TT_CPTR, value.p, v)
+#define SET_CPTR_VALUE(mrb,r,v) BOXNAN_SET_VALUE(r, MRB_TT_CPTR, p, v)
#endif
-#define SET_UNDEF_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_UNDEF, value.i, 0)
+#define SET_UNDEF_VALUE(r) BOXNAN_SET_VALUE(r, MRB_TT_UNDEF, i, 0)
#endif /* MRUBY_BOXING_NAN_H */