NeoMutt  2023-05-17-33-gce4425
Teaching an old dog new tricks
DOXYGEN
string2.h
Go to the documentation of this file.
1
24/* @note This file is called string2.h so that other files can safely
25 * #include <string.h>
26 */
27
28#ifndef MUTT_MUTT_STRING2_H
29#define MUTT_MUTT_STRING2_H
30
31#include <ctype.h>
32#include <stdbool.h>
33#include <stdio.h>
34
35#define STR_COMMAND 8192
36
37#define NONULL(x) ((x) ? (x) : "")
38
39/* Exit values */
40#define S_ERR 127
41#define S_BKG 126
42
43/* this macro must check for (*ch == 0) since isspace(0) has unreliable behavior
44 * on some systems */
45#define SKIPWS(ch) \
46 while (*(ch) && isspace((unsigned char) *(ch))) \
47 ch++;
48
49#define terminate_string(str, strlen, buflen) \
50 (str)[MIN((strlen), (buflen))] = '\0'
51
52#define terminate_buffer(str, strlen) \
53 terminate_string(str, strlen, sizeof(str) - 1)
54
55void mutt_str_adjust(char **ptr);
56void mutt_str_append_item(char **str, const char *item, char sep);
57int mutt_str_asprintf(char **strp, const char *fmt, ...);
58int mutt_str_coll(const char *a, const char *b);
59void mutt_str_dequote_comment(char *str);
60const char *mutt_str_find_word(const char *src);
61const char *mutt_str_getenv(const char *name);
62bool mutt_str_inline_replace(char *buf, size_t buflen, size_t xlen, const char *rstr);
63bool mutt_str_is_ascii(const char *str, size_t len);
64size_t mutt_str_len(const char *a);
65char * mutt_str_lower(char *str);
66size_t mutt_str_lws_len(const char *s, size_t n);
67size_t mutt_str_lws_rlen(const char *s, size_t n);
68const char *mutt_str_next_word(const char *s);
69void mutt_str_remove_trailing_ws(char *s);
70char * mutt_str_replace(char **p, const char *s);
71char * mutt_str_sep(char **stringp, const char *delim);
72char * mutt_str_skip_email_wsp(const char *s);
73char * mutt_str_skip_whitespace(const char *p);
74const char *mutt_str_sysexit(int e);
75char * mutt_str_upper(char *str);
76
77/* case-sensitive flavours */
78char * mutt_str_cat(char *buf, size_t buflen, const char *s);
79int mutt_str_cmp(const char *a, const char *b);
80size_t mutt_str_copy(char *dest, const char *src, size_t dsize);
81char * mutt_str_dup(const char *str);
82bool mutt_str_equal(const char *a, const char *b);
83size_t mutt_str_startswith(const char *str, const char *prefix);
84
85/* case-sensitive, length-bound flavours */
86char * mutt_strn_cat(char *dest, size_t l, const char *s, size_t sl);
87char * mutt_strn_copy(char *dest, const char *src, size_t len, size_t dsize);
88char * mutt_strn_dup(const char *begin, size_t l);
89bool mutt_strn_equal(const char *a, const char *b, size_t num);
90const char *mutt_strn_rfind(const char *haystack, size_t haystack_length, const char *needle);
91
92/* case-insensitive flavours */
93int mutt_istr_cmp(const char *a, const char *b);
94bool mutt_istr_equal(const char *a, const char *b);
95const char *mutt_istr_find(const char *haystack, const char *needle);
96int mutt_istr_remall(char *str, const char *target);
97size_t mutt_istr_startswith(const char *str, const char *prefix);
98
99/* case-insensitive, length-bound flavours */
100int mutt_istrn_cmp(const char *a, const char *b, size_t num);
101bool mutt_istrn_equal(const char *a, const char *b, size_t num);
102const char *mutt_istrn_rfind(const char *haystack, size_t haystack_length, const char *needle);
103
109static inline bool mutt_str_is_email_wsp(char c)
110{
111 return (c == ' ') || (c == '\t') || (c == '\r') || (c == '\n');
112}
113
114#endif /* MUTT_MUTT_STRING2_H */
bool mutt_str_inline_replace(char *buf, size_t buflen, size_t xlen, const char *rstr)
Replace the beginning of a string.
Definition: string.c:940
const char * mutt_str_sysexit(int e)
Return a string matching an error code.
Definition: string.c:167
int mutt_str_cmp(const char *a, const char *b)
Compare two strings, safely.
Definition: string.c:471
int mutt_istrn_cmp(const char *a, const char *b, size_t num)
Compare two strings ignoring case (to a maximum), safely.
Definition: string.c:511
void mutt_str_remove_trailing_ws(char *s)
Trim trailing whitespace from a string.
Definition: string.c:637
bool mutt_istr_equal(const char *a, const char *b)
Compare two strings, ignoring case.
Definition: string.c:810
void mutt_str_dequote_comment(char *str)
Un-escape characters in an email address comment.
Definition: string.c:766
char * mutt_str_dup(const char *str)
Copy a string, safely.
Definition: string.c:251
int mutt_str_asprintf(char **strp, const char *fmt,...)
Definition: string.c:1022
char * mutt_str_upper(char *str)
Convert all characters in the string to uppercase.
Definition: string.c:408
char * mutt_str_lower(char *str)
Convert all characters in the string to lowercase.
Definition: string.c:385
char * mutt_str_skip_email_wsp(const char *s)
Skip over whitespace as defined by RFC5322.
Definition: string.c:680
const char * mutt_istrn_rfind(const char *haystack, size_t haystack_length, const char *needle)
Find last instance of a substring, ignoring case.
Definition: string.c:541
size_t mutt_str_lws_len(const char *s, size_t n)
Measure the linear-white-space at the beginning of a string.
Definition: string.c:700
bool mutt_str_is_ascii(const char *str, size_t len)
Is a string ASCII (7-bit)?
Definition: string.c:875
void mutt_str_append_item(char **str, const char *item, char sep)
Add string to another separated by sep.
Definition: string.c:347
int mutt_istr_cmp(const char *a, const char *b)
Compare two strings ignoring case, safely.
Definition: string.c:484
bool mutt_str_equal(const char *a, const char *b)
Compare two strings.
Definition: string.c:798
bool mutt_strn_equal(const char *a, const char *b, size_t num)
Check for equality of two strings (to a maximum), safely.
Definition: string.c:497
char * mutt_strn_dup(const char *begin, size_t l)
Duplicate a sub-string.
Definition: string.c:452
char * mutt_strn_cat(char *dest, size_t l, const char *s, size_t sl)
Concatenate two strings.
Definition: string.c:295
const char * mutt_str_find_word(const char *src)
Find the end of a word (non-space)
Definition: string.c:898
char * mutt_strn_copy(char *dest, const char *src, size_t len, size_t dsize)
Copy a sub-string into a buffer.
Definition: string.c:432
int mutt_istr_remall(char *str, const char *target)
Remove all occurrences of substring, ignoring case.
Definition: string.c:964
const char * mutt_str_getenv(const char *name)
Get an environment variable.
Definition: string.c:918
const char * mutt_istr_find(const char *haystack, const char *needle)
Find first occurrence of string (ignoring case)
Definition: string.c:593
size_t mutt_str_startswith(const char *str, const char *prefix)
Check whether a string starts with a prefix.
Definition: string.c:228
char * mutt_str_skip_whitespace(const char *p)
Find the first non-whitespace character in a string.
Definition: string.c:623
void mutt_str_adjust(char **ptr)
Shrink-to-fit a string.
Definition: string.c:371
size_t mutt_str_len(const char *a)
Calculate the length of a string, safely.
Definition: string.c:568
size_t mutt_str_copy(char *dest, const char *src, size_t dsize)
Copy a string into a buffer (guaranteeing NUL-termination)
Definition: string.c:653
static bool mutt_str_is_email_wsp(char c)
Is this a whitespace character (for an email header)
Definition: string2.h:109
const char * mutt_str_next_word(const char *s)
Find the next word in a string.
Definition: string.c:825
size_t mutt_istr_startswith(const char *str, const char *prefix)
Check whether a string starts with a prefix, ignoring case.
Definition: string.c:240
bool mutt_istrn_equal(const char *a, const char *b, size_t num)
Check for equality of two strings ignoring case (to a maximum), safely.
Definition: string.c:525
char * mutt_str_replace(char **p, const char *s)
Replace one string with another.
Definition: string.c:327
size_t mutt_str_lws_rlen(const char *s, size_t n)
Measure the linear-white-space at the end of a string.
Definition: string.c:734
const char * mutt_strn_rfind(const char *haystack, size_t haystack_length, const char *needle)
Find last instance of a substring.
Definition: string.c:847
int mutt_str_coll(const char *a, const char *b)
Collate two strings (compare using locale), safely.
Definition: string.c:581
char * mutt_str_sep(char **stringp, const char *delim)
Find first occurrence of any of delim characters in *stringp.
Definition: string.c:184
char * mutt_str_cat(char *buf, size_t buflen, const char *s)
Concatenate two strings.
Definition: string.c:266