Add explicit to hb_auto_t 1param constructors

This commit is contained in:
Behdad Esfahbod 2018-08-28 18:18:02 -07:00
parent c0a3f38f78
commit 967741e4c4
1 changed files with 4 additions and 3 deletions

View File

@ -497,9 +497,10 @@ struct hb_auto_t : Type
* *
* Apparently if we template for all types, then gcc seems to * Apparently if we template for all types, then gcc seems to
* capture a reference argument in the type, but clang doesn't, * capture a reference argument in the type, but clang doesn't,
* causing unwanted copies and bugs that come with it. */ * causing unwanted copies and bugs that come with it. Ideally
template <typename T1> hb_auto_t (T1 *t1) { Type::init (t1); } * we should use C++11-style rvalue reference &&t1. */
template <typename T1> hb_auto_t (T1 &t1) { Type::init (t1); } template <typename T1> explicit hb_auto_t (T1 *t1) { Type::init (t1); }
template <typename T1> explicit hb_auto_t (T1 &t1) { Type::init (t1); }
~hb_auto_t (void) { Type::fini (); } ~hb_auto_t (void) { Type::fini (); }
private: /* Hide */ private: /* Hide */
void init (void) {} void init (void) {}