]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/wxcrt.h
do not use preprocessor macros in interface headers; doxygen doesn't know about prepr...
[wxWidgets.git] / interface / wx / wxcrt.h
CommitLineData
23324ae1 1/////////////////////////////////////////////////////////////////////////////
7c913512 2// Name: wxcrt.h
8f182e0a 3// Purpose: interface of global CRT wrapper functions
7c913512
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
b21126db 9/** @addtogroup group_funcmacro_string */
3950d49c
BP
10//@{
11
7c913512 12/**
8f182e0a
FM
13 Returns @true if the pointer @a p is either @NULL or points to an empty string,
14 @false otherwise.
23324ae1 15
3950d49c
BP
16 @header{wx/wxcrt.h}
17*/
18bool wxIsEmpty(const char* p);
23324ae1 19
7c913512 20/**
3950d49c
BP
21 This is a safe version of standard function @e strlen(): it does exactly
22 the same thing (i.e. returns the length of the string) except that it
23 returns 0 if @a p is the @NULL pointer.
4cc4bfaf 24
3950d49c 25 @header{wx/wxcrt.h}
23324ae1 26*/
3950d49c 27size_t wxStrlen(const char* p);
23324ae1 28
8f182e0a
FM
29/**
30 This is a safe version of standard function @e strlen(): it returns the length
31 of the string s in bytes if this length is smaller than @a maxlen bytes.
32 Otherwise it returns @a maxlen.
33
34 The @a maxlen parameter makes it easier to avoid array indexing errors
35 since you are sure that wxStrnlen() won't read any memory exceeding the
36 @c "*(p+maxlen)" location.
37
38 @since 2.9.0
39
40 @header{wx/wxcrt.h}
41*/
42size_t wxStrnlen(const char* p, size_t maxlen);
43
23324ae1 44/**
3950d49c
BP
45 This function complements the standard C function @e stricmp() which
46 performs case-insensitive comparison.
47
d29a9a8a 48 @return A negative value, 0, or positive value if @a p1 is less than,
8f182e0a 49 equal to or greater than @a p2. The comparison is case-sensitive.
3950d49c
BP
50
51 @header{wx/wxcrt.h}
23324ae1 52*/
3950d49c 53int wxStrcmp(const char* p1, const char* p2);
23324ae1
FM
54
55/**
3950d49c
BP
56 This function complements the standard C function @e strcmp() which performs
57 case-sensitive comparison.
58
d29a9a8a 59 @return A negative value, 0, or positive value if @a p1 is less than,
8f182e0a 60 equal to or greater than @e p2. The comparison is case-insensitive.
7c913512 61
3950d49c 62 @header{wx/wxcrt.h}
23324ae1 63*/
3950d49c 64int wxStricmp(const char* p1, const char* p2);
23324ae1
FM
65
66/**
8f182e0a 67 @deprecated Use wxString::operator== instead.
3950d49c
BP
68
69 This macro is defined as:
70
71 @code
72 #define wxStringEq(s1, s2) (s1 && s2 && (strcmp(s1, s2) == 0))
73 @endcode
74
75 @header{wx/wxcrt.h}
23324ae1 76*/
3950d49c 77bool wxStringEq(const wxString& s1, const wxString& s2);
23324ae1
FM
78
79/**
3950d49c
BP
80 @deprecated Use wxString::Find() instead.
81
82 Returns @true if the substring @a s1 is found within @a s2, ignoring case
83 if @a exact is @false. If @a subString is @false, no substring matching is
84 done.
85
86 @header{wx/wxcrt.h}
23324ae1 87*/
3950d49c
BP
88bool wxStringMatch(const wxString& s1, const wxString& s2,
89 bool subString = true, bool exact = false);
23324ae1
FM
90
91/**
3950d49c
BP
92 This is a convenience function wrapping wxStringTokenizer which simply
93 returns all tokens found in the given @a string in an array.
94
95 Please see wxStringTokenizer::wxStringTokenizer() for a description of the
96 other parameters.
97
98 @header{wx/wxcrt.h}
23324ae1 99*/
3950d49c
BP
100wxArrayString wxStringTokenize(const wxString& string,
101 const wxString& delims = wxDEFAULT_DELIMITERS,
102 wxStringTokenizerMode mode = wxTOKEN_DEFAULT);
23324ae1 103
e408bf52
VZ
104/**
105 Safe and more convenient replacement for strncpy().
106
107 This function copies the source string @a src to the destination buffer @a
108 dst of size @a n without overflowing the buffer and ensuring that it is
8d740f72 109 always @NUL-terminated.
e408bf52
VZ
110
111 Example of use:
112 @code
113 char buf[256];
114 if ( wxStrlcpy(buf, GetSomeString(), WXSIZEOF(buf)) > WXSIZEOF(buf) )
115 ... handle truncation ...
116 @endcode
117 Notice that using wxStrncpy() in similar way is wrong, the above is broadly
118 equivalent to
119 @code
120 char buf[256];
121 buf[WXSIZEOF(buf) - 1] = '\0';
122 wxStrncpy(buf, GetSomeString(), WXSIZEOF(buf) - 1);
123 if ( buf[WXSIZEOF(buf) - 1] != '\0' )
124 {
125 ... truncation occurred ...
126 // need to NUL-terminate string manually
127 buf[WXSIZEOF(buf) - 1] = '\0';
128 }
129 @endcode
130 which should explain the advantage of using wxStrlcpy().
131
132 Notice that this function is similar to the OpenBSD strlcpy() function.
133
e408bf52
VZ
134 @param dst
135 Destination buffer of size (greater or) equal to @a n.
136 @param src
8d740f72 137 @NUL-terminated source string.
e408bf52
VZ
138 @param n
139 The size of the destination buffer.
140 @return
141 The length of @a src, if the returned value is greater or equal to @a n
142 then there was not enough space in the destination buffer and the
143 string was truncated.
144
8f182e0a 145 @since 2.9.0
e408bf52
VZ
146
147 @header{wx/wxcrt.h}
148 */
8f182e0a 149size_t wxStrlcpy(char *dst, const char *src, size_t n);
e408bf52 150
23324ae1 151/**
3950d49c
BP
152 This function replaces the dangerous standard function @e sprintf() and is
153 like @e snprintf() available on some platforms. The only difference with
154 @e sprintf() is that an additional argument - buffer size - is taken and
155 the buffer is never overflowed.
156
157 Returns the number of characters copied to the buffer or -1 if there is not
158 enough space.
159
160 @see wxVsnprintf(), wxString::Printf()
161
162 @header{wx/wxcrt.h}
23324ae1 163*/
8f182e0a 164int wxSnprintf(char* buf, size_t len, const char* format, ...);
23324ae1
FM
165
166/**
3950d49c
BP
167 The same as wxSnprintf() but takes a @c va_list argument instead of an
168 arbitrary number of parameters.
169
170 @note If @c wxUSE_PRINTF_POS_PARAMS is set to 1, then this function
171 supports positional arguments (see wxString::Printf() for more
172 information). However other functions of the same family (wxPrintf(),
173 wxSprintf(), wxFprintf(), wxVfprintf(), wxVfprintf(), wxVprintf(),
174 wxVsprintf()) currently do not to support positional parameters even
175 when @c wxUSE_PRINTF_POS_PARAMS is 1.
176
177 @see wxSnprintf(), wxString::PrintfV()
178
179 @header{wx/wxcrt.h}
23324ae1 180*/
8f182e0a 181int wxVsnprintf(char* buf, size_t len, const char* format, va_list argPtr);
3950d49c
BP
182
183//@}
23324ae1 184