📄 wmemmove_s.c
字号:
/***
*wmemmove_s.c - contains wmemmove_s routine
*
* Copyright (c) Microsoft Corporation. All rights reserved.
*
*Purpose:
* wmemmove_s() copies a source memory buffer to a destination buffer.
* Overlapping buffers are treated specially, to avoid propagation.
*
*******************************************************************************/
#include <cruntime.h>
#include <wchar.h>
#include <internal.h>
/***
*wmemmove - Copy source buffer to destination buffer in units of wchar_t
*
*Purpose:
* wmemmove() copies a source memory buffer to a destination memory buffer.
* This routine recognize overlapping buffers to avoid propagation.
*
* For cases where propagation is not a problem, wmemcpy_s() can be used.
*
*Entry:
* wchar_t *dst = pointer to destination buffer
* size_t sizeInWchar_ts = size in wchar_ts of the destination buffer
* const wchar_t *src = pointer to source buffer
* size_t count = number of wchar_ts to copy
*
*Exit:
* Returns 0 if everything is ok, else return the error code.
*
*Exceptions:
* Input parameters are validated. Refer to the validation section of the function.
* On error, the error code is returned. Nothing is written to the destination buffer.
*
*******************************************************************************/
errno_t __cdecl wmemmove_s(
wchar_t * dst,
size_t sizeInWchar_ts,
const wchar_t * src,
size_t count
)
{
if (count == 0)
{
/* nothing to do */
return 0;
}
/* validation section */
_VALIDATE_RETURN_ERRCODE(dst != NULL, EINVAL);
_VALIDATE_RETURN_ERRCODE(src != NULL, EINVAL);
_VALIDATE_RETURN_ERRCODE(sizeInWchar_ts >= count, ERANGE);
wmemmove(dst, src, count);
return 0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -