prevent potential premature GC in byte_xs
authorEric Wong <normalperson@yhbt.net>
Sat, 15 Feb 2014 22:29:49 +0000 (15 22:29 +0000)
committerEric Wong <normalperson@yhbt.net>
Sat, 15 Feb 2014 22:29:49 +0000 (15 22:29 +0000)
If we convert an object to string, there is a potential the
compiler may optimize away the converted string if escaping
is needed.  Prevent that with RB_GC_GUARD.

ext/clogger_ext/clogger.c

index ed01534..8b05c34 100644 (file)
@@ -166,10 +166,11 @@ static inline int need_escape(unsigned c)
 }
 
 /* we are encoding-agnostic, clients can send us all sorts of junk */
-static VALUE byte_xs_str(VALUE from)
+static VALUE byte_xs(VALUE obj)
 {
        static const char esc[] = "0123456789ABCDEF";
        unsigned char *new_ptr;
+       VALUE from = rb_obj_as_string(obj);
        const unsigned char *ptr = (const unsigned char *)RSTRING_PTR(from);
        long len = RSTRING_LEN(from);
        long new_len = len;
@@ -203,14 +204,10 @@ static VALUE byte_xs_str(VALUE from)
        }
        assert(RSTRING_PTR(rv)[RSTRING_LEN(rv)] == '\0');
 
+       RB_GC_GUARD(from);
        return rv;
 }
 
-static VALUE byte_xs(VALUE from)
-{
-       return byte_xs_str(rb_obj_as_string(from));
-}
-
 static void clogger_mark(void *ptr)
 {
        struct clogger *c = ptr;