4 template<typename Type> cell tag(Type *value)
6 return RETAG(value,Type::type_number);
9 inline static cell tag_dynamic(object *value)
11 return RETAG(value,value->h.hi_tag());
14 template<typename Type>
23 bool type_p(cell type_) const
25 return type() == type_;
30 if(Type::type_number == TYPE_COUNT)
33 return type_p(Type::type_number);
42 Type *untagged() const {
46 return (Type *)(UNTAG(value_));
49 Type *untag_check(factor_vm *parent) const {
51 parent->type_error(Type::type_number,value_);
55 explicit tagged(cell tagged) : value_(tagged) {}
56 explicit tagged(Type *untagged) : value_(factor::tag(untagged)) {}
58 Type *operator->() const { return untagged(); }
59 cell *operator&() const { return &value_; }
61 const tagged<Type> &operator=(const Type *x) { value_ = tag(x); return *this; }
62 const tagged<Type> &operator=(const cell &x) { value_ = x; return *this; }
64 bool operator==(const tagged<Type> &x) { return value_ == x.value_; }
65 bool operator!=(const tagged<Type> &x) { return value_ != x.value_; }
67 template<typename NewType> tagged<NewType> as() { return tagged<NewType>(value_); }
70 template<typename Type> Type *factor_vm::untag_check(cell value)
72 return tagged<Type>(value).untag_check(this);
75 template<typename Type> Type *untag(cell value)
77 return tagged<Type>(value).untagged();