提交 dc4225cc 编写于 作者: B Behdad Esfahbod

Don't retry creating again and again in lazy_loader if create failed

Still does that if get_null() returns nullptr.  Our shaper data objects
are like that.  Shrug.
上级 086235f5
...@@ -752,16 +752,19 @@ struct hb_data_wrapper_t ...@@ -752,16 +752,19 @@ struct hb_data_wrapper_t
return *(((Data **) (void *) this) - WheresData); return *(((Data **) (void *) this) - WheresData);
} }
inline bool is_inert (void) const { return !get_data (); }
template <typename Stored, typename Subclass> template <typename Stored, typename Subclass>
inline Stored * call_create (void) const inline Stored * call_create (void) const
{ {
Data *data = this->get_data (); return Subclass::create (this->get_data ());
return likely (data) ? Subclass::create (data) : nullptr;
} }
}; };
template <> template <>
struct hb_data_wrapper_t<void, 0> struct hb_data_wrapper_t<void, 0>
{ {
inline bool is_inert (void) const { return false; }
template <typename Stored, typename Funcs> template <typename Stored, typename Funcs>
inline Stored * call_create (void) const inline Stored * call_create (void) const
{ {
...@@ -800,7 +803,7 @@ struct hb_lazy_loader_t : hb_data_wrapper_t<Data, WheresData> ...@@ -800,7 +803,7 @@ struct hb_lazy_loader_t : hb_data_wrapper_t<Data, WheresData>
static inline void do_destroy (Stored *p) static inline void do_destroy (Stored *p)
{ {
if (p) if (p && p != const_cast<Stored *> (Funcs::get_null ()))
Funcs::destroy (p); Funcs::destroy (p);
} }
...@@ -814,9 +817,12 @@ struct hb_lazy_loader_t : hb_data_wrapper_t<Data, WheresData> ...@@ -814,9 +817,12 @@ struct hb_lazy_loader_t : hb_data_wrapper_t<Data, WheresData>
Stored *p = this->instance.get (); Stored *p = this->instance.get ();
if (unlikely (!p)) if (unlikely (!p))
{ {
if (unlikely (this->is_inert ()))
return const_cast<Stored *> (Funcs::get_null ());
p = this->template call_create<Stored, Funcs> (); p = this->template call_create<Stored, Funcs> ();
if (unlikely (!p)) if (unlikely (!p))
return const_cast<Stored *> (Funcs::get_null ()); p = const_cast<Stored *> (Funcs::get_null ());
if (unlikely (!this->instance.cmpexch (nullptr, p))) if (unlikely (!this->instance.cmpexch (nullptr, p)))
{ {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册