pack.c: reduce dispatch in `pack_unpack()`.

parent bfe2bd49
...@@ -1501,26 +1501,24 @@ pack_unpack(mrb_state *mrb, mrb_value str, int single) ...@@ -1501,26 +1501,24 @@ pack_unpack(mrb_state *mrb, mrb_value str, int single)
continue; continue;
} }
if (flags & PACK_FLAG_COUNT2) {
sptr = (const unsigned char *)RSTRING_PTR(str) + srcidx; sptr = (const unsigned char *)RSTRING_PTR(str) + srcidx;
switch (dir) { switch (dir) {
case PACK_DIR_HEX: case PACK_DIR_HEX:
srcidx += unpack_h(mrb, sptr, srclen - srcidx, result, count, flags); srcidx += unpack_h(mrb, sptr, srclen - srcidx, result, count, flags);
break; continue;
case PACK_DIR_STR: case PACK_DIR_STR:
srcidx += unpack_a(mrb, sptr, srclen - srcidx, result, count, flags); srcidx += unpack_a(mrb, sptr, srclen - srcidx, result, count, flags);
break; continue;
case PACK_DIR_BASE64: case PACK_DIR_BASE64:
srcidx += unpack_m(mrb, sptr, srclen - srcidx, result); srcidx += unpack_m(mrb, sptr, srclen - srcidx, result);
continue;
break; break;
case PACK_DIR_QENC: case PACK_DIR_QENC:
srcidx += unpack_M(mrb, sptr, srclen - srcidx, result); srcidx += unpack_M(mrb, sptr, srclen - srcidx, result);
break; continue;
default: default:
break; break;
} }
continue;
}
while (count != 0) { while (count != 0) {
if (srclen - srcidx < size) { if (srclen - srcidx < size) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment