2020-08-22 20:05:24 +03:00
|
|
|
/**
|
|
|
|
* xrdp: A Remote Desktop Protocol server.
|
|
|
|
*
|
|
|
|
* Copyright (C) Jay Sorg 2004-2020
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* generic string handling calls
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if !defined(STRING_CALLS_H)
|
|
|
|
#define STRING_CALLS_H
|
|
|
|
|
2020-12-21 15:36:00 +03:00
|
|
|
#include "arch.h"
|
|
|
|
|
2020-08-22 20:05:24 +03:00
|
|
|
/**
|
|
|
|
* Map a character to a string value
|
|
|
|
*
|
|
|
|
* This structure is used by g_format_info_string() to specify the
|
2022-09-03 02:48:01 +03:00
|
|
|
* string which could be output for %'ch', where ch is a character
|
2020-08-22 20:05:24 +03:00
|
|
|
*/
|
|
|
|
struct info_string_tag
|
|
|
|
{
|
|
|
|
char ch;
|
|
|
|
const char *val;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define INFO_STRING_END_OF_LIST { '\0', NULL }
|
|
|
|
|
2021-08-26 17:31:38 +03:00
|
|
|
/**
|
|
|
|
* Map a bitmask to a string value
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* This structure is used by g_bitmask_to_str() to specify the
|
|
|
|
* string for each bit in the bitmask
|
|
|
|
*/
|
|
|
|
struct bitmask_string
|
|
|
|
{
|
|
|
|
int mask;
|
|
|
|
const char *str;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define BITMASK_STRING_END_OF_LIST { 0, NULL }
|
|
|
|
|
2022-05-03 11:53:24 +03:00
|
|
|
/**
|
|
|
|
* Map a bitmask to a char value
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* This structure is used by g_bitmask_to_charstr() to specify the
|
|
|
|
* char for each bit in the bitmask
|
|
|
|
*/
|
|
|
|
struct bitmask_char
|
|
|
|
{
|
|
|
|
int mask;
|
|
|
|
char c;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define BITMASK_CHAR_END_OF_LIST { 0, '\0' }
|
|
|
|
|
2020-08-22 20:05:24 +03:00
|
|
|
/**
|
|
|
|
* Processes a format string for general info
|
|
|
|
*
|
|
|
|
* @param[out] dest Destination buffer
|
|
|
|
* @param[in] len Length of buffer, including space for a terminator
|
|
|
|
* @param[in] format Format string to process
|
|
|
|
* @param[in] map Array of struct info_string_tag.
|
|
|
|
*
|
|
|
|
* Where a '%<ch>' is encountered in the format string, the map is scanned
|
|
|
|
* and the corresponding string is copied instead of '%<ch>'.
|
|
|
|
*
|
|
|
|
* '%%' is always replaced with a single '%' in the output. %<ch> strings
|
|
|
|
* not present in the map are ignored.
|
|
|
|
*
|
|
|
|
* The map is terminated with INFO_STRING_END_OF_LIST
|
|
|
|
*
|
|
|
|
* Caller can check for buffer truncation by comparing the result with
|
|
|
|
* the buffer length (as in snprintf())
|
|
|
|
*/
|
|
|
|
unsigned int
|
2020-12-21 15:36:00 +03:00
|
|
|
g_format_info_string(char *dest, unsigned int len,
|
|
|
|
const char *format,
|
|
|
|
const struct info_string_tag map[]);
|
2020-08-22 20:05:24 +03:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a boolean to a string for output
|
|
|
|
*
|
|
|
|
* @param[in] value Value to convert
|
|
|
|
* @return String representation
|
|
|
|
*/
|
|
|
|
const char *
|
|
|
|
g_bool2text(int value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a string to a boolean value
|
|
|
|
*
|
|
|
|
* @param[in] s String to convert
|
|
|
|
* @return machine representation
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
g_text2bool(const char *s);
|
|
|
|
|
2021-03-29 00:55:19 +03:00
|
|
|
/**
|
|
|
|
* Joins an array of strings into a single string.
|
|
|
|
*
|
|
|
|
* Note: The joiner is placed between each source string. The joiner is not
|
|
|
|
* placed after the last source string. If there is only one source string,
|
|
|
|
* then the result string will be equal to the source string.
|
|
|
|
*
|
|
|
|
* Note: any content that is present in dest will be overwritten with the new
|
|
|
|
* joined string.
|
|
|
|
*
|
|
|
|
* Note: If the destination array is not large enough to hold the entire
|
|
|
|
* contents of the joined string, then the joined string will be truncated
|
|
|
|
* to fit in the destination array.
|
|
|
|
*
|
|
|
|
* @param[out] dest The destination array to write the joined string into.
|
|
|
|
* @param[in] dest_len The max number of characters to write to the destination
|
|
|
|
* array including the terminating null. Must be > 0
|
|
|
|
* @param[in] joiner The string to concatenate between each source string.
|
|
|
|
* The joiner string may be NULL which is processed as a zero length string.
|
|
|
|
* @param[in] src An array of strings to join. The array must be non-null.
|
|
|
|
* Array items may be NULL and are processed as zero length strings.
|
|
|
|
* @param[in] src_len The number of strings to join in the src array. Must be > 0
|
2022-09-03 02:48:01 +03:00
|
|
|
* @return A pointer to the beginning of the joined string (ie. returns dest).
|
2021-03-29 00:55:19 +03:00
|
|
|
*/
|
|
|
|
char *
|
|
|
|
g_strnjoin(char *dest, int dest_len, const char *joiner, const char *src[], int src_len);
|
|
|
|
|
2021-02-28 22:50:16 +03:00
|
|
|
/**
|
|
|
|
* Converts a binary array into a hux dump suitable for displaying to a user.
|
|
|
|
*
|
|
|
|
* The format of the hex dump is:
|
|
|
|
* 0000 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 ................
|
|
|
|
* /\ /\ /\
|
|
|
|
* | | |
|
|
|
|
* | | ascii representation of bytes
|
|
|
|
* | hex representation of bytes
|
2021-04-08 18:10:12 +03:00
|
|
|
* offset from beginning of the byte array in hex
|
2021-02-28 22:50:16 +03:00
|
|
|
*
|
|
|
|
* Note: the ascii representation uses '.' for all non-printable
|
|
|
|
* characters (eg. below 32 or above 127).
|
|
|
|
*
|
|
|
|
* Note: the string contains embedded new lines, but is not new line terminated.
|
|
|
|
*
|
|
|
|
* @param[in] src Value to convert
|
|
|
|
* @param[in] len The number of bytes in src to convert
|
|
|
|
* @return string containing the hex dump that must be free'd by the caller
|
|
|
|
*/
|
|
|
|
char *
|
|
|
|
g_bytes_to_hexdump(const char *src, int len);
|
|
|
|
|
2021-04-13 14:11:19 +03:00
|
|
|
/**
|
|
|
|
* Extracts the display number from an X11 display string
|
|
|
|
*
|
|
|
|
* @param Display string (i.e. g_getenv("DISPLAY"))
|
|
|
|
*
|
|
|
|
* @result <0 if the string could not be parsed, or >=0 for a display number
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
g_get_display_num_from_display(const char *display_text);
|
|
|
|
|
2021-08-26 17:31:38 +03:00
|
|
|
/**
|
|
|
|
* Converts a bitmask into a string for output purposes
|
|
|
|
*
|
2022-05-03 11:53:24 +03:00
|
|
|
* Similar to g_bitmask_to_charstr(), but tokens are strings, separated
|
|
|
|
* by delimiters.
|
|
|
|
*
|
2021-08-26 17:31:38 +03:00
|
|
|
* @param bitmask Bitmask to convert
|
|
|
|
* @param bitdefs Definitions for strings for bits
|
|
|
|
* @param delim Delimiter to use between strings
|
|
|
|
* @param buff Output buff
|
|
|
|
* @param bufflen Length of buff, including terminator '`\0'
|
|
|
|
*
|
|
|
|
* @return Total length excluding terminator which would be written, as
|
|
|
|
* in snprintf(). Can be used to check for overflow
|
|
|
|
*
|
|
|
|
* @note Any undefined bits in the bitmask are appended to the output as
|
|
|
|
* a hexadecimal constant.
|
|
|
|
*/
|
|
|
|
int
|
2022-05-03 11:52:37 +03:00
|
|
|
g_bitmask_to_str(int bitmask, const struct bitmask_string bitdefs[],
|
2021-08-26 17:31:38 +03:00
|
|
|
char delim, char *buff, int bufflen);
|
|
|
|
|
2021-12-14 08:04:09 +03:00
|
|
|
/***
|
|
|
|
* Converts a string containing a series of tokens to a bitmask.
|
2022-05-03 11:53:24 +03:00
|
|
|
*
|
|
|
|
* Similar to g_charstr_to_bitmask(), but tokens are strings, separated
|
|
|
|
* by delimiters.
|
|
|
|
*
|
2021-12-14 08:04:09 +03:00
|
|
|
* @param str Input string
|
2022-05-03 11:53:24 +03:00
|
|
|
* @param bitdefs Array mapping tokens to bitmask values
|
2021-12-14 08:04:09 +03:00
|
|
|
* @param delim Delimiter for tokens in str
|
|
|
|
* @param[out] unrecognised Buffer for any unrecognised tokens
|
|
|
|
* @param unrecognised_len Length of unrecognised including '\0';
|
|
|
|
* @return bitmask value for recognised tokens
|
|
|
|
*/
|
|
|
|
int
|
2022-05-03 11:52:37 +03:00
|
|
|
g_str_to_bitmask(const char *str, const struct bitmask_string bitdefs[],
|
2021-12-14 08:04:09 +03:00
|
|
|
const char *delim, char *unrecognised,
|
|
|
|
int unrecognised_len);
|
|
|
|
|
2022-05-03 11:53:24 +03:00
|
|
|
/**
|
|
|
|
* Converts a bitmask into a string for output purposes
|
|
|
|
*
|
|
|
|
* Similar to g_bitmask_to_str(), but tokens are individual characters, and
|
|
|
|
* there are no delimiters.
|
|
|
|
*
|
|
|
|
* @param bitmask Bitmask to convert
|
|
|
|
* @param bitdefs Definitions for strings for bits
|
|
|
|
* @param buff Output buff
|
|
|
|
* @param bufflen Length of buff, including terminator '`\0'
|
|
|
|
* @param[out] rest Any unused bits which weren't covered by bitdefs.
|
|
|
|
* May be NULL.
|
|
|
|
*
|
|
|
|
* @return Total length excluding terminator which would be written, as
|
|
|
|
* in snprintf(). Can be used to check for overflow
|
|
|
|
*
|
|
|
|
* @note Any undefined bits in the bitmask are appended to the output as
|
|
|
|
* a hexadecimal constant.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
g_bitmask_to_charstr(int bitmask, const struct bitmask_char bitdefs[],
|
|
|
|
char *buff, int bufflen, int *rest);
|
|
|
|
|
|
|
|
/***
|
|
|
|
* Converts a string containing a series of characters to a bitmask.
|
|
|
|
*
|
|
|
|
* Similar to g_str_to_bitmask(), but tokens are individual characters, and
|
|
|
|
* there are no delimiters.
|
|
|
|
*
|
|
|
|
* @param str Input string
|
|
|
|
* @param bitdefs Array mapping tokens to bitmask values
|
|
|
|
* @param delim Delimiter for tokens in str
|
|
|
|
* @param[out] unrecognised Buffer for any unrecognised tokens
|
|
|
|
* @param unrecognised_len Length of unrecognised including '\0';
|
|
|
|
* @return bitmask value for recognised tokens
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
g_charstr_to_bitmask(const char *str, const struct bitmask_char bitdefs[],
|
|
|
|
char *unrecognised, int unrecognised_len);
|
|
|
|
|
2020-12-21 15:36:00 +03:00
|
|
|
int g_strlen(const char *text);
|
2021-10-25 18:13:09 +03:00
|
|
|
char *g_strchr(const char *text, int c);
|
|
|
|
char *g_strrchr(const char *text, int c);
|
|
|
|
char *g_strnchr(const char *text, int c, int len);
|
2020-12-21 15:36:00 +03:00
|
|
|
char *g_strcpy(char *dest, const char *src);
|
|
|
|
char *g_strncpy(char *dest, const char *src, int len);
|
|
|
|
char *g_strcat(char *dest, const char *src);
|
|
|
|
char *g_strncat(char *dest, const char *src, int len);
|
|
|
|
char *g_strdup(const char *in);
|
|
|
|
char *g_strndup(const char *in, const unsigned int maxlen);
|
|
|
|
int g_strcmp(const char *c1, const char *c2);
|
|
|
|
int g_strncmp(const char *c1, const char *c2, int len);
|
|
|
|
int g_strncmp_d(const char *c1, const char *c2, const char delim, int len);
|
|
|
|
int g_strcasecmp(const char *c1, const char *c2);
|
|
|
|
int g_strncasecmp(const char *c1, const char *c2, int len);
|
|
|
|
int g_atoi(const char *str);
|
2021-07-19 19:08:45 +03:00
|
|
|
/**
|
|
|
|
* Extends g_atoi(), Converts decimal and hexadecimal number String to integer
|
|
|
|
*
|
|
|
|
* Prefix hexadecimal numbers with '0x'
|
|
|
|
*
|
|
|
|
* @param str String to convert to an integer
|
|
|
|
* @return int Integer expression of a string
|
|
|
|
*/
|
|
|
|
int g_atoix(const char *str);
|
2020-12-21 15:36:00 +03:00
|
|
|
int g_htoi(char *str);
|
|
|
|
int g_bytes_to_hexstr(const void *bytes, int num_bytes, char *out_str,
|
|
|
|
int bytes_out_str);
|
|
|
|
int g_pos(const char *str, const char *to_find);
|
2021-10-25 18:13:09 +03:00
|
|
|
char *g_strstr(const char *haystack, const char *needle);
|
2020-12-21 15:36:00 +03:00
|
|
|
int g_mbstowcs(twchar *dest, const char *src, int n);
|
|
|
|
int g_wcstombs(char *dest, const twchar *src, int n);
|
|
|
|
int g_strtrim(char *str, int trim_flags);
|
2020-08-22 20:05:24 +03:00
|
|
|
#endif
|