|
- /**
- * Copyright 2020 Huawei Technologies Co., Ltd
- *
- * 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.
- */
-
- #include "secinput.h"
-
- /*
- * <FUNCTION DESCRIPTION>
- * The vfscanf_s function is equivalent to fscanf_s, with the variable argument list replaced by argList
- * The vfscanf_s function reads data from the current position of stream into
- * the locations given by argument (if any). Each argument must be a pointer
- * to a variable of a type that corresponds to a type specifier in format.
- * format controls the interpretation of the input fields and has the same
- * form and function as the format argument for scanf.
- *
- * <INPUT PARAMETERS>
- * stream Pointer to FILE structure.
- * format Format control string, see Format Specifications.
- * argList pointer to list of arguments
- *
- * <OUTPUT PARAMETERS>
- * argList the converted value stored in user assigned address
- *
- * <RETURN VALUE>
- * 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 vfscanf_s(FILE *stream, const char *format, va_list argList)
- {
- int retVal; /* If initialization causes e838 */
- SecFileStream fStr;
-
- if ((stream == NULL) || (format == NULL)) {
- SECUREC_ERROR_INVALID_PARAMTER("vfscanf_s");
- return SECUREC_SCANF_EINVAL;
- }
- if (stream == stdin) {
- return vscanf_s(format, argList);
- }
-
- SECUREC_LOCK_FILE(stream);
- SECUREC_INIT_SEC_FILE_STREAM(fStr, SECUREC_FILE_STREAM_FLAG, stream, SECUREC_UNINITIALIZED_FILE_POS, NULL, 0);
- retVal = SecInputS(&fStr, format, argList);
- SECUREC_UNLOCK_FILE(stream);
- if (retVal < 0) {
- SECUREC_ERROR_INVALID_PARAMTER("vfscanf_s");
- return SECUREC_SCANF_EINVAL;
- }
-
- return retVal;
- }
-
|