GCC Code Coverage Report
Directory: ./ Exec Total Coverage
File: gx_utility_string_length_check.c Lines: 9 9 100.0 %
Date: 2024-12-05 08:52:37 Branches: 8 8 100.0 %

Line Branch Exec Source
1
/***************************************************************************
2
 * Copyright (c) 2024 Microsoft Corporation
3
 *
4
 * This program and the accompanying materials are made available under the
5
 * terms of the MIT License which is available at
6
 * https://opensource.org/licenses/MIT.
7
 *
8
 * SPDX-License-Identifier: MIT
9
 **************************************************************************/
10
11
12
/**************************************************************************/
13
/**************************************************************************/
14
/**                                                                       */
15
/** GUIX Component                                                        */
16
/**                                                                       */
17
/**   Utility (Utility)                                                   */
18
/**                                                                       */
19
/**************************************************************************/
20
21
#define GX_SOURCE_CODE
22
23
24
/* Include necessary system files.  */
25
26
#include "gx_api.h"
27
#include "gx_utility.h"
28
29
/**************************************************************************/
30
/*                                                                        */
31
/*  FUNCTION                                               RELEASE        */
32
/*                                                                        */
33
/*    _gx_utility_string_length_check                     PORTABLE C      */
34
/*                                                           6.1          */
35
/*  AUTHOR                                                                */
36
/*                                                                        */
37
/*    Kenneth Maxwell, Microsoft Corporation                              */
38
/*                                                                        */
39
/*  DESCRIPTION                                                           */
40
/*                                                                        */
41
/*    This function traverses the string and returns the string length,   */
42
/*    if the string is invalid or the string length is bigger than max    */
43
/*    string length, returns error.                                       */
44
/*                                                                        */
45
/*  INPUT                                                                 */
46
/*                                                                        */
47
/*    input_string                          Pointer to input string       */
48
/*    string_length                         Pointer to string length      */
49
/*    max_string_length                     Max string length             */
50
/*                                                                        */
51
/*  OUTPUT                                                                */
52
/*                                                                        */
53
/*    None                                                                */
54
/*                                                                        */
55
/*  CALLS                                                                 */
56
/*                                                                        */
57
/*    None                                                                */
58
/*                                                                        */
59
/*  CALLED BY                                                             */
60
/*                                                                        */
61
/*    GUIX Internal Code                                                  */
62
/*                                                                        */
63
/*  RELEASE HISTORY                                                       */
64
/*                                                                        */
65
/*    DATE              NAME                      DESCRIPTION             */
66
/*                                                                        */
67
/*  05-19-2020     Kenneth Maxwell          Initial Version 6.0           */
68
/*  09-30-2020     Kenneth Maxwell          Modified comment(s),          */
69
/*                                            resulting in version 6.1    */
70
/*                                                                        */
71
/**************************************************************************/
72
117688
UINT  _gx_utility_string_length_check(GX_CONST GX_CHAR *input_string, UINT *string_length, UINT max_string_length)
73
{
74
UINT i;
75
76
    /* Check for invalid input pointers.  */
77
117688
    if (input_string == GX_NULL)
78
    {
79
27
        return(GX_PTR_ERROR);
80
    }
81
82
    /* Traverse the string.  */
83
4179524
    for (i = 0; input_string[i]; i++)
84
    {
85
86
        /* Check if the string length is bigger than the max string length.  */
87
4061902
        if (i >= max_string_length)
88
        {
89
39
            return(GX_INVALID_STRING_LENGTH);
90
        }
91
    }
92
93
    /* Return the string length if string_length is not NULL.
94
       String_length being NULL indicates the caller needs to check for string
95
       length within the max_string_length. */
96
117622
    if (string_length)
97
    {
98
117621
        *string_length = i;
99
    }
100
101
117622
    return(GX_SUCCESS);
102
}
103