Add jerryscript-ext/autorelease.h with JERRYX_AR_VALUE_T (#1874)

JerryScript-DCO-1.0-Signed-off-by: Martijn The martijn.the@intel.com
This commit is contained in:
Martijn Thé 2017-06-16 07:09:19 +02:00 committed by Zidong Jiang
parent 940f1f89c9
commit b947f56fd0
5 changed files with 207 additions and 0 deletions

View File

@ -0,0 +1,47 @@
# Autorelease values
## JERRYX_AR_VALUE_T
**Summary**
Macro for `const jerry_value_t` for which jerry_release_value() is
automatically called when the variable goes out of scope.
*Note*: The macro depends on compiler support. For GCC and LLVM/clang, the macro is implemented
using the `__cleanup__` variable attribute. For other compilers, no support has been added yet.
**Example**
```c
#include "jerryscript.h"
#include "jerryscript-ext/autorelease.h"
static void foo (bool enable)
{
JERRYX_AR_VALUE_T bar = jerry_create_string (...);
if (enable)
{
JERRYX_AR_VALUE_T baz = jerry_get_global_object ();
...
/*
* jerry_release_value (baz) and jerry_release_value (bar) is called automatically before
* returning, because `baz` and `bar` go out of scope.
*/
return;
}
/*
* jerry_release_value (bar) is called automatically when the function returns,
* because `bar` goes out of scope.
*/
}
```
**See also**
- [jerry_value_t](../docs/02.API-REFERENCE.md#jerry_value_t)
- [jerry_acquire_value](../docs/02.API-REFERENCE.md#jerry_acquire_value)
- [jerry_release_value](../docs/02.API-REFERENCE.md#jerry_release_value)

View File

@ -0,0 +1,54 @@
/* Copyright JS Foundation and other contributors, http://js.foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef JERRYX_AUTORELEASE_H
#define JERRYX_AUTORELEASE_H
#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */
#include "autorelease.impl.h"
/*
* Macro for `const jerry_value_t` for which jerry_release_value () is
* automatically called when the variable goes out of scope.
*
* Example usage:
* static void foo (bool enable)
* {
* JERRYX_AR_VALUE_T bar = jerry_create_string (...);
*
* if (enable) {
* JERRYX_AR_VALUE_T baz = jerry_get_global_object ();
*
* // ...
*
* // jerry_release_value (baz) and jerry_release_value (bar) is called automatically before
* // returning, because `baz` and `bar` go out of scope.
* return;
* }
*
* // jerry_release_value (bar) is called automatically when the function returns,
* // because `bar` goes out of scope.
* }
*/
#define JERRYX_AR_VALUE_T __JERRYX_AR_VALUE_T_IMPL
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* !JERRYX_AUTORELEASE_H */

View File

@ -0,0 +1,40 @@
/* Copyright JS Foundation and other contributors, http://js.foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef JERRYX_AUTORELEASE_IMPL_H
#define JERRYX_AUTORELEASE_IMPL_H
#include "jerryscript.h"
#ifdef __GNUC__
/*
* Calls jerry_release_value (*value).
* The GCC __cleanup__ function must take a pointer to the variable to clean up.
*
* @return void
*/
static inline void
jerryx_autorelease_cleanup (const jerry_value_t *value) /**< jerry value */
{
jerry_release_value (*value);
} /* jerryx_autorelease_cleanup */
#define __JERRYX_AR_VALUE_T_IMPL const jerry_value_t __attribute__ ((__cleanup__(jerryx_autorelease_cleanup)))
#else /* !__GNUC__ */
/* TODO: for other compilers */
#error "No autorelease implementation for your compiler!"
#endif /* __GNUC__ */
#endif /* !JERRYX_AUTORELEASE_IMPL_H */

View File

@ -0,0 +1,64 @@
/* Copyright JS Foundation and other contributors, http://js.foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* Unit test for jerry-ext/autorelease.
*/
#include "jerryscript.h"
#include "jerryscript-ext/autorelease.h"
#include "test-common.h"
static int native_free_cb_call_count;
static void
native_free_cb (void *native_p)
{
++native_free_cb_call_count;
(void) native_p;
} /* native_free_cb */
static const jerry_object_native_info_t native_info =
{
.free_cb = native_free_cb,
};
static jerry_value_t
create_object (void)
{
jerry_value_t obj = jerry_create_object ();
jerry_set_object_native_pointer (obj, NULL, &native_info);
return obj;
} /* create_object */
static void
test_autorelease_val (void)
{
JERRYX_AR_VALUE_T obj = create_object ();
(void) obj;
} /* test_autorelease_val */
int
main (void)
{
jerry_init (JERRY_INIT_EMPTY);
native_free_cb_call_count = 0;
test_autorelease_val ();
jerry_gc ();
TEST_ASSERT (native_free_cb_call_count == 1);
jerry_cleanup ();
} /* main */

View File

@ -32,6 +32,7 @@ DEBUGGER_MD="07.DEBUGGER.md"
CODING_STANDARDS_MD="08.CODING-STANDARDS.md"
EXT_REFERENCE_ARG_MD="09.EXT-REFERENCE-ARG.md"
EXT_REFERENCE_HANDLER_MD="10.EXT-REFERENCE-HANDLER.md"
EXT_REFERENCE_AUTORELEASE_MD="11.EXT-REFERENCE-AUTORELEASE.md"
declare -A titles
@ -45,6 +46,7 @@ titles[$DEBUGGER_MD]="Debugger"
titles[$CODING_STANDARDS_MD]="Coding Standards"
titles[$EXT_REFERENCE_ARG_MD]="'Extension API: Argument Validation'"
titles[$EXT_REFERENCE_HANDLER_MD]="'Extension API: External Function Handlers'"
titles[$EXT_REFERENCE_AUTORELEASE_MD]="'Extension API: Autorelease Values'"
for docfile in $docs_dir/*.md; do
docfile_base=`basename $docfile`