mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
Related Issue: #2060 JerryScript-DCO-1.0-Signed-off-by: Zidong Jiang zidong.jiang@intel.com
111 lines
3.9 KiB
C
111 lines
3.9 KiB
C
/* 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 ECMA_PROMISE_OBJECT_H
|
|
#define ECMA_PROMISE_OBJECT_H
|
|
|
|
#ifndef CONFIG_DISABLE_ES2015_PROMISE_BUILTIN
|
|
#include "ecma-globals.h"
|
|
|
|
/** \addtogroup ecma ECMA
|
|
* @{
|
|
*
|
|
* \addtogroup ecmaarraybufferobject ECMA ArrayBuffer object related routines
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* The PromiseState of promise object.
|
|
*/
|
|
typedef enum
|
|
{
|
|
ECMA_PROMISE_STATE_PENDING, /**< pending state */
|
|
ECMA_PROMISE_STATE_FULFILLED, /**< fulfilled state */
|
|
ECMA_PROMISE_STATE_REJECTED, /** rejected state */
|
|
ECMA_PROMISE_STATE__COUNT /**< number of states */
|
|
} ecma_promise_state_t;
|
|
|
|
/**
|
|
* Indicates the type of the executor in promise construct.
|
|
*/
|
|
typedef enum
|
|
{
|
|
ECMA_PROMISE_EXECUTOR_FUNCTION, /**< the executor is a function, it is for the usual constructor */
|
|
ECMA_PROMISE_EXECUTOR_OBJECT, /**< the executor is an object, it is for the `then` routine */
|
|
ECMA_PROMISE_EXECUTOR_EMPTY /**< the executor is empty, it is for external C API */
|
|
} ecma_promise_executor_type_t;
|
|
|
|
/**
|
|
* Description of the promise resolving functions.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ecma_value_t resolve; /**< the resolve function */
|
|
ecma_value_t reject; /**< the reject function */
|
|
} ecma_promise_resolving_functions_t;
|
|
|
|
/**
|
|
* Description of the promise object.
|
|
* It need more space than normal object to store builtin properties.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ecma_extended_object_t ecma_extended_object_t; /**< extended object part */
|
|
uint8_t state; /**< promise state, see ecma_promise_state_t */
|
|
ecma_collection_header_t *fulfill_reactions; /**< list of PromiseFullfillReactions */
|
|
ecma_collection_header_t *reject_reactions; /**< list of PromiseRejectReactions */
|
|
} ecma_promise_object_t;
|
|
|
|
/**
|
|
* Use symbolic constant to represent the internal property name of
|
|
* promise related structures.
|
|
*/
|
|
typedef enum
|
|
{
|
|
ECMA_PROMISE_PROPERTY_PROMISE, /**< [[Promise]] property */
|
|
ECMA_PROMISE_PROPERTY_RESOLVE, /**< [[Resolve]] property */
|
|
ECMA_PROMISE_PROPERTY_REJECT, /**< [[Reject]] property */
|
|
ECMA_PROMISE_PROPERTY_CAPABILITY, /**< [[Capability]] property */
|
|
ECMA_PROMISE_PROPERTY_HANDLER, /**< [[Handler]] property */
|
|
ECMA_PROMISE_PROPERTY_ALREADY_CALLED, /**< [[AlreadyCalled]] property */
|
|
ECMA_PROMISE_PROPERTY_INDEX, /**< [[Index]] property */
|
|
ECMA_PROMISE_PROPERTY_VALUE, /**< [[Values]] property */
|
|
ECMA_PROMISE_PROPERTY_REMAINING_ELEMENT /**< [[RemainingElement]] property */
|
|
} ecma_promise_property_symbolic_constant_t;
|
|
|
|
bool ecma_is_promise (ecma_object_t *obj_p);
|
|
ecma_value_t ecma_promise_get_result (ecma_object_t *obj_p);
|
|
void ecma_promise_set_result (ecma_object_t *obj_p, ecma_value_t result);
|
|
uint8_t ecma_promise_get_state (ecma_object_t *obj_p);
|
|
void ecma_promise_set_state (ecma_object_t *obj_p, uint8_t state);
|
|
ecma_value_t
|
|
ecma_op_create_promise_object (ecma_value_t executor, ecma_promise_executor_type_t type);
|
|
ecma_value_t ecma_promise_new_capability (void);
|
|
ecma_value_t
|
|
ecma_promise_then (ecma_value_t promise,
|
|
ecma_value_t on_fulfilled,
|
|
ecma_value_t on_rejected);
|
|
ecma_promise_resolving_functions_t *
|
|
ecma_promise_create_resolving_functions (ecma_object_t *object_p);
|
|
void ecma_promise_free_resolving_functions (ecma_promise_resolving_functions_t *funcs);
|
|
|
|
/**
|
|
* @}
|
|
* @}
|
|
*/
|
|
|
|
#endif /* !CONFIG_DISABLE_ES2015_PROMISE_BUILTIN */
|
|
#endif /* !ECMA_PROMISE_OBJECT_H */
|