]> git.kaiwu.me - njs.git/commitdiff
Fixed njs_string_slice().
authorDmitry Volyntsev <xeioex@nginx.com>
Fri, 14 Sep 2018 11:19:03 +0000 (14:19 +0300)
committerDmitry Volyntsev <xeioex@nginx.com>
Fri, 14 Sep 2018 11:19:03 +0000 (14:19 +0300)
dst retval argument was ignored.

njs/njs_string.c
njs/njs_string.h

index 1e8c21d221453b91355dbc2ff59b65a7e7f26125..acb4d2fcb5f61dcf07ae46834b235d325d90b7a8 100644 (file)
@@ -1288,7 +1288,7 @@ njs_string_slice_args(njs_slice_prop_t *slice, njs_value_t *args,
 
 nxt_noinline njs_ret_t
 njs_string_slice(njs_vm_t *vm, njs_value_t *dst,
-    const njs_string_prop_t *string, njs_slice_prop_t *slice)
+    const njs_string_prop_t *string, const njs_slice_prop_t *slice)
 {
     size_t        size, n, length;
     const u_char  *p, *start, *end;
@@ -1325,10 +1325,10 @@ njs_string_slice(njs_vm_t *vm, njs_value_t *dst,
     }
 
     if (nxt_fast_path(size != 0)) {
-        return njs_string_new(vm, &vm->retval, start, size, length);
+        return njs_string_new(vm, dst, start, size, length);
     }
 
-    vm->retval = njs_string_empty;
+    *dst = njs_string_empty;
 
     return NXT_OK;
 }
index 0dd36dff010b15dd47598201ab222ac06067eaca..e2042d041e8d5714fbc37870a7a55d0c4b0948ad 100644 (file)
@@ -146,7 +146,7 @@ njs_ret_t njs_string_constructor(njs_vm_t *vm, njs_value_t *args,
 nxt_bool_t njs_string_eq(const njs_value_t *val1, const njs_value_t *val2);
 nxt_int_t njs_string_cmp(const njs_value_t *val1, const njs_value_t *val2);
 njs_ret_t njs_string_slice(njs_vm_t *vm, njs_value_t *dst,
-    const njs_string_prop_t *string, njs_slice_prop_t *slice);
+    const njs_string_prop_t *string, const njs_slice_prop_t *slice);
 const u_char *njs_string_offset(const u_char *start, const u_char *end,
     size_t index);
 nxt_noinline uint32_t njs_string_index(njs_string_prop_t *string,