Fix problems arising from incorrect use of various size types
E.g., * `ssize_t` was used where `lit_utf8_size_t` or `jerry_api_size_t` would have been correct, * `lit_utf8_size_t` was used where `ecma_length_t` would have been correct. Note, the patch also includes internal and public API changes: * `ecma_string_to_utf8_string` does not return negative value if output buffer is not large enough to contain the string; the buffer is expected to be large enough. (`ecma_string_get_size` can be used to retrieve the required size.) * `jerry_api_string_to_char_buffer` adapts the same logic (and `jerry_api_get_string_size` can be used to determine the required size of the buffer). Related issue: #942 JerryScript-DCO-1.0-Signed-off-by: Akos Kiss akiss@inf.u-szeged.hu
This commit is contained in:
+5
-6
@@ -548,19 +548,18 @@ jerry_api_convert_eval_completion_to_retval (jerry_api_value_t *retval_p, /**< [
|
||||
*/
|
||||
|
||||
/**
|
||||
* Copy string characters to specified buffer.
|
||||
* Copy string characters to specified buffer. It is the caller's responsibility
|
||||
* to make sure that the string fits in the buffer.
|
||||
*
|
||||
* Note:
|
||||
* '\0' could occur in characters.
|
||||
*
|
||||
* @return number of bytes, actually copied to the buffer - if string's content was copied successfully;
|
||||
* otherwise (in case size of buffer is insufficient) - negative number, which is calculated
|
||||
* as negation of buffer size, that is required to hold the string's content.
|
||||
* @return number of bytes, actually copied to the buffer.
|
||||
*/
|
||||
ssize_t
|
||||
jerry_api_size_t
|
||||
jerry_api_string_to_char_buffer (const jerry_api_string_t *string_p, /**< string descriptor */
|
||||
jerry_api_char_t *buffer_p, /**< [out] output characters buffer */
|
||||
ssize_t buffer_size) /**< size of output buffer */
|
||||
jerry_api_size_t buffer_size) /**< size of output buffer */
|
||||
{
|
||||
jerry_assert_api_available ();
|
||||
|
||||
|
||||
Reference in New Issue
Block a user