/* * Copyright (c) Huawei Technologies Co., Ltd. 2014-2020. All rights reserved. * Licensed under Mulan PSL v2. * You can use this software according to the terms and conditions of the Mulan PSL v2. * You may obtain a copy of Mulan PSL v2 at: * http://license.coscl.org.cn/MulanPSL2 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE. * See the Mulan PSL v2 for more details. * Description: vsscanf_s function * Author: lishunda * Create: 2014-02-25 */ #include "secinput.h" #if defined(SECUREC_VXWORKS_PLATFORM) && !SECUREC_IN_KERNEL && \ (!defined(SECUREC_SYSAPI4VXWORKS) && !defined(SECUREC_CTYPE_MACRO_ADAPT)) #include #endif /* * * vsscanf_s * * * * The vsscanf_s function is equivalent to sscanf_s, with the variable argument list replaced by argList * The vsscanf_s function reads data from buffer into the location given by * each argument. Every argument must be a pointer to a variable with a type * that corresponds to a type specifier in format. The format argument controls * the interpretation of the input fields and has the same form and function * as the format argument for the scanf function. * If copying takes place between strings that overlap, the behavior is undefined. * * * buffer Stored data * format Format control string, see Format Specifications. * argList pointer to list of arguments * * * argList the converted value stored in user assigned address * * * Each of these functions returns the number of fields successfully converted * and assigned; the return value does not include fields that were read but * not assigned. A return value of 0 indicates that no fields were assigned. * return -1 if an error occurs. */ int vsscanf_s(const char *buffer, const char *format, va_list argList) { size_t count; /* If initialization causes e838 */ int retVal; SecFileStream fStr; /* Validation section */ if (buffer == NULL || format == NULL) { SECUREC_ERROR_INVALID_PARAMTER("vsscanf_s"); return SECUREC_SCANF_EINVAL; } count = strlen(buffer); if (count == 0 || count > SECUREC_STRING_MAX_LEN) { SecClearDestBuf(buffer, format, argList); SECUREC_ERROR_INVALID_PARAMTER("vsscanf_s"); return SECUREC_SCANF_EINVAL; } #if defined(SECUREC_VXWORKS_PLATFORM) && !SECUREC_IN_KERNEL /* * On vxworks platform when buffer is white string, will set first %s argument tu zero.like following useage: * " \v\f\t\r\n", "%s", str, strSize * Do not check all character, just first and last character then consider it is white string */ if (isspace((int)(unsigned char)buffer[0]) != 0 && isspace((int)(unsigned char)buffer[count - 1]) != 0) { SecClearDestBuf(buffer, format, argList); } #endif SECUREC_FILE_STREAM_FROM_STRING(&fStr, buffer, count); retVal = SecInputS(&fStr, format, argList); if (retVal < 0) { SECUREC_ERROR_INVALID_PARAMTER("vsscanf_s"); return SECUREC_SCANF_EINVAL; } return retVal; } #if SECUREC_IN_KERNEL EXPORT_SYMBOL(vsscanf_s); #endif