summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorLamont Granquist <lamont@scriptkiddie.org>2014-06-14 11:53:45 -0700
committerLamont Granquist <lamont@scriptkiddie.org>2014-06-14 11:53:45 -0700
commit63f0054a3d8fea181d086a632c0c134719ceb1cb (patch)
tree156d7b2f4e0bba877f25b028007500a7eb49b923 /ext
parentbf3e03e18faab91902baadfc8b4e650ecf1abeef (diff)
downloadffi-yajl-63f0054a3d8fea181d086a632c0c134719ceb1cb.tar.gz
cache the symbolize_keys lookup in C
Diffstat (limited to 'ext')
-rw-r--r--ext/ffi_yajl/ext/parser/parser.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/ext/ffi_yajl/ext/parser/parser.c b/ext/ffi_yajl/ext/parser/parser.c
index de4f125..6833a88 100644
--- a/ext/ffi_yajl/ext/parser/parser.c
+++ b/ext/ffi_yajl/ext/parser/parser.c
@@ -10,6 +10,7 @@ static VALUE mFFI_Yajl, mExt, mParser, cParseError;
typedef struct {
VALUE self;
+ int symbolizeKeys;
} CTX;
void set_value(CTX *ctx, VALUE val) {
@@ -115,21 +116,13 @@ int start_map_callback(void *ctx) {
return 1;
}
-VALUE get_symbolize_keys(CTX *ctx) {
- VALUE opts = rb_iv_get(ctx->self, "@opts");
- if (TYPE(opts) != T_HASH) {
- rb_raise(rb_eTypeError, "opts is not a valid hash");
- }
- return rb_hash_aref(opts, ID2SYM(rb_intern("symbolize_keys")));
-}
-
int map_key_callback(void *ctx, const unsigned char *stringVal, size_t stringLen) {
VALUE key;
#ifdef HAVE_RUBY_ENCODING_H
rb_encoding *default_internal_enc;
#endif
- if ( get_symbolize_keys(ctx) == Qtrue ) {
+ if ( ((CTX *)ctx)->symbolizeKeys ) {
#ifdef HAVE_RUBY_ENCODING_H
ID id = rb_intern3((const char *)stringVal, stringLen, utf8Encoding);
key = ID2SYM(id);
@@ -180,6 +173,14 @@ static yajl_callbacks callbacks = {
end_array_callback,
};
+int get_symbolize_keys(VALUE self) {
+ VALUE opts = rb_iv_get(self, "@opts");
+ if (TYPE(opts) != T_HASH) {
+ rb_raise(rb_eTypeError, "opts is not a valid hash");
+ }
+ return rb_hash_aref(opts, ID2SYM(rb_intern("symbolize_keys"))) == Qtrue;
+}
+
static VALUE mParser_do_yajl_parse(VALUE self, VALUE str, VALUE opts) {
yajl_handle hand;
yajl_status stat;
@@ -190,6 +191,7 @@ static VALUE mParser_do_yajl_parse(VALUE self, VALUE str, VALUE opts) {
rb_ivar_set(self, rb_intern("key_stack"), rb_ary_new());
ctx.self = self;
+ ctx.symbolizeKeys = get_symbolize_keys(self);
hand = yajl_alloc(&callbacks, NULL, (void *)&ctx);
if ((stat = yajl_parse(hand, (unsigned char *)RSTRING_PTR(str), RSTRING_LEN(str))) != yajl_status_ok) {