Browse Source

api doc and test for duk_require_context, update duk_get_context doc and test

pull/1/head
Sami Vaarala 11 years ago
parent
commit
f0b171fc4c
  1. 40
      api-testcases/test-get-context.c
  2. 89
      api-testcases/test-require-context.c
  3. 22
      website/api/duk_require_context.txt

40
api-testcases/test-get-context.c

@ -1,11 +1,17 @@
/*===
concat: foobarquux
still here
rc=0 -> undefined
new_ctx is NULL: 1
new_ctx is NULL: 1
new_ctx is NULL: 1
rc=0 -> undefined
===*/
void test(duk_context *ctx) {
int test_1(duk_context *ctx) {
duk_context *new_ctx;
duk_set_top(ctx, 0);
(void) duk_push_new_thread(ctx);
new_ctx = duk_get_context(ctx, -1);
@ -22,5 +28,37 @@ void test(duk_context *ctx) {
duk_pop(ctx);
printf("still here\n");
return 0;
}
int test_2(duk_context *ctx) {
duk_context *new_ctx;
/* non-thread value */
duk_set_top(ctx, 0);
duk_push_int(ctx, 123);
new_ctx = duk_get_context(ctx, -1);
printf("new_ctx is NULL: %d\n", (new_ctx == NULL ? 1 : 0));
/* invalid index */
new_ctx = duk_get_context(ctx, 123);
printf("new_ctx is NULL: %d\n", (new_ctx == NULL ? 1 : 0));
/* invalid index */
new_ctx = duk_get_context(ctx, DUK_INVALID_INDEX);
printf("new_ctx is NULL: %d\n", (new_ctx == NULL ? 1 : 0));
return 0;
}
void test(duk_context *ctx) {
int rc;
rc = duk_safe_call(ctx, test_1, 0, 1, DUK_INVALID_INDEX);
printf("rc=%d -> %s\n", rc, duk_to_string(ctx, -1));
duk_pop(ctx);
rc = duk_safe_call(ctx, test_2, 0, 1, DUK_INVALID_INDEX);
printf("rc=%d -> %s\n", rc, duk_to_string(ctx, -1));
duk_pop(ctx);
}

89
api-testcases/test-require-context.c

@ -0,0 +1,89 @@
/*===
concat: foobarquux
still here
rc=0 -> undefined
rc=1 -> TypeError: incorrect type, expected tag 6
rc=1 -> TypeError: incorrect type, expected tag 6
rc=1 -> TypeError: incorrect type, expected tag 6
===*/
int test_1(duk_context *ctx) {
duk_context *new_ctx;
duk_set_top(ctx, 0);
(void) duk_push_new_thread(ctx);
new_ctx = duk_require_context(ctx, -1);
duk_push_string(new_ctx, "foo");
duk_push_string(new_ctx, "bar");
duk_push_string(new_ctx, "quux");
duk_concat(new_ctx, 3);
printf("concat: %s\n", duk_get_string(new_ctx, -1));
/* This duk_pop() makes the new thread unreachable (assuming there
* is no other reference to it), so new_ctx is no longer valid
* afterwards.
*/
duk_pop(ctx);
printf("still here\n");
return 0;
}
int test_2(duk_context *ctx) {
duk_context *new_ctx;
/* non-thread value */
duk_set_top(ctx, 0);
duk_push_int(ctx, 123);
new_ctx = duk_require_context(ctx, -1);
printf("new_ctx is NULL: %d\n", (new_ctx == NULL ? 1 : 0));
return 0;
}
int test_3(duk_context *ctx) {
duk_context *new_ctx;
/* invalid index */
duk_set_top(ctx, 0);
duk_push_int(ctx, 123);
new_ctx = duk_require_context(ctx, 123);
printf("new_ctx is NULL: %d\n", (new_ctx == NULL ? 1 : 0));
return 0;
}
int test_4(duk_context *ctx) {
duk_context *new_ctx;
/* invalid index */
duk_set_top(ctx, 0);
duk_push_int(ctx, 123);
new_ctx = duk_require_context(ctx, DUK_INVALID_INDEX);
printf("new_ctx is NULL: %d\n", (new_ctx == NULL ? 1 : 0));
return 0;
}
void test(duk_context *ctx) {
int rc;
rc = duk_safe_call(ctx, test_1, 0, 1, DUK_INVALID_INDEX);
printf("rc=%d -> %s\n", rc, duk_to_string(ctx, -1));
duk_pop(ctx);
/* FIXME: printing the specific error is currently fragile
* because it includes a tag number.
*/
rc = duk_safe_call(ctx, test_2, 0, 1, DUK_INVALID_INDEX);
printf("rc=%d -> %s\n", rc, duk_to_string(ctx, -1));
duk_pop(ctx);
rc = duk_safe_call(ctx, test_3, 0, 1, DUK_INVALID_INDEX);
printf("rc=%d -> %s\n", rc, duk_to_string(ctx, -1));
duk_pop(ctx);
rc = duk_safe_call(ctx, test_4, 0, 1, DUK_INVALID_INDEX);
printf("rc=%d -> %s\n", rc, duk_to_string(ctx, -1));
duk_pop(ctx);
}

22
website/api/duk_require_context.txt

@ -0,0 +1,22 @@
=proto
duk_context *duk_require_context(duk_context *ctx, int index);
=stack
[ ... val! ... ]
=summary
<p>Get a context pointer for a Duktape thread at <tt>index</tt>. If the
value at <tt>index</tt> is not a Duktape thread or the index is invalid,
throws an error.</p>
<p>The returned context pointer is only valid while the Duktape thread
is reachable from a garbage collection point of view.</p>
<p>If you prefer a <tt>NULL</tt> to be returned for an invalid value or index,
use <tt><a href="#duk_get_context">duk_get_context()</a></tt>.</p>
=example
duk_context *new_ctx;
(void) duk_push_new_thread(ctx);
new_ctx = duk_require_context(ctx, -1);
Loading…
Cancel
Save