It allows to iterate over a string, returning an new element each time, using a char as separator. See BLI_String.h's comments for more info and an example. Needed by the UI template list patch following!
168 lines
5.0 KiB
C++
168 lines
5.0 KiB
C++
/*
|
||
* ***** BEGIN GPL LICENSE BLOCK *****
|
||
*
|
||
* This program is free software; you can redistribute it and/or
|
||
* modify it under the terms of the GNU General Public License
|
||
* as published by the Free Software Foundation; either version 2
|
||
* of the License, or (at your option) any later version.
|
||
*
|
||
* This program is distributed in the hope that it will be useful,
|
||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
* GNU General Public License for more details.
|
||
*
|
||
* You should have received a copy of the GNU General Public License
|
||
* along with this program; if not, write to the Free Software Foundation,
|
||
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
*
|
||
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
||
* All rights reserved.
|
||
*
|
||
* The Original Code is: all of this file.
|
||
*
|
||
* Contributor(s): none yet.
|
||
*
|
||
* ***** END GPL LICENSE BLOCK *****
|
||
*/
|
||
|
||
#ifndef BLI_STRING_H
|
||
#define BLI_STRING_H
|
||
|
||
/** \file BLI_string.h
|
||
* \ingroup bli
|
||
*/
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
/**
|
||
* Duplicates the cstring @a str into a newly mallocN'd
|
||
* string and returns it.
|
||
*
|
||
* @param str The string to be duplicated
|
||
* @retval Returns the duplicated string
|
||
*/
|
||
char *BLI_strdup(const char *str);
|
||
|
||
/**
|
||
* Duplicates the first @a len bytes of cstring @a str
|
||
* into a newly mallocN'd string and returns it. @a str
|
||
* is assumed to be at least len bytes long.
|
||
*
|
||
* @param str The string to be duplicated
|
||
* @param len The number of bytes to duplicate
|
||
* @retval Returns the duplicated string
|
||
*/
|
||
char *BLI_strdupn(const char *str, const size_t len);
|
||
|
||
/**
|
||
* Appends the two strings, and returns new mallocN'ed string
|
||
* @param str1 first string for copy
|
||
* @param str2 second string for append
|
||
* @retval Returns dst
|
||
*/
|
||
char *BLI_strdupcat(const char *str1, const char *str2);
|
||
|
||
/**
|
||
* Like strncpy but ensures dst is always
|
||
* '\0' terminated.
|
||
*
|
||
* @param dst Destination for copy
|
||
* @param src Source string to copy
|
||
* @param maxncpy Maximum number of characters to copy (generally
|
||
* the size of dst)
|
||
* @retval Returns dst
|
||
*/
|
||
char *BLI_strncpy(char *dst, const char *src, const size_t maxncpy);
|
||
|
||
/* Makes a copy of the text within the "" that appear after some text 'blahblah'
|
||
* i.e. for string 'pose["apples"]' with prefix 'pose[', it should grab "apples"
|
||
*
|
||
* - str: is the entire string to chop
|
||
* - prefix: is the part of the string to leave out
|
||
*
|
||
* Assume that the strings returned must be freed afterwards, and that the inputs will contain
|
||
* data we want...
|
||
*/
|
||
char *BLI_getQuotedStr(const char *str, const char *prefix);
|
||
|
||
/**
|
||
* Returns a copy of the cstring @a str into a newly mallocN'd
|
||
* string with all instances of oldText replaced with newText,
|
||
* and returns it.
|
||
*
|
||
* @param str The string to replace occurances of oldText in
|
||
* @param oldText The text in the string to find and replace
|
||
* @param newText The text in the string to find and replace
|
||
* @retval Returns the duplicated string
|
||
*/
|
||
char *BLI_replacestr(char *str, const char *oldText, const char *newText);
|
||
|
||
/*
|
||
* Replacement for snprintf
|
||
*/
|
||
size_t BLI_snprintf(char *buffer, size_t len, const char *format, ...)
|
||
#ifdef __GNUC__
|
||
__attribute__ ((format (printf, 3, 4)))
|
||
#endif
|
||
;
|
||
|
||
/*
|
||
* Print formatted string into a newly mallocN'd string
|
||
* and return it.
|
||
*/
|
||
char *BLI_sprintfN(const char *format, ...)
|
||
#ifdef __GNUC__
|
||
__attribute__ ((format (printf, 1, 2)))
|
||
#endif
|
||
;
|
||
|
||
size_t BLI_strescape(char *dst, const char *src, const size_t maxlen);
|
||
|
||
/**
|
||
* Compare two strings without regard to case.
|
||
*
|
||
* @retval True if the strings are equal, false otherwise.
|
||
*/
|
||
int BLI_strcaseeq(const char *a, const char *b);
|
||
|
||
char *BLI_strcasestr(const char *s, const char *find);
|
||
int BLI_strcasecmp(const char *s1, const char *s2);
|
||
int BLI_strncasecmp(const char *s1, const char *s2, size_t len);
|
||
int BLI_natstrcmp(const char *s1, const char *s2);
|
||
size_t BLI_strnlen(const char *str, size_t maxlen);
|
||
|
||
/**
|
||
* Split str on the first occurence of delimiter, returns the first
|
||
* part as a mallocN'd string, and stores the second part into
|
||
* ctx (also mallocN'd).
|
||
* If str is NULL, split on ctx instead.
|
||
* This allows to iterate over this "generator" function:
|
||
*
|
||
* char *ctx = NULL;
|
||
* char *res = NULL;
|
||
* for(res = BLI_strtok_r("a;dummy;csv;line", ";", &ctx); res; res = BLI_strtok_r(NULL, ";", &ctx)) {
|
||
* printf(res);
|
||
* MEM_freeN(res);
|
||
* }
|
||
*
|
||
* @param str The string to be split.
|
||
* @param delimiter The char used to split str apart.
|
||
* @param ctx The "context" string. It’s a pointer inside the org passed @str,
|
||
* so it has no specific mem management.
|
||
* @retval Returns the mallocN'd first element from split str (or ctx).
|
||
*/
|
||
char *BLI_strtok_r(char *str, const char *delimiter, char **ctx);
|
||
|
||
void BLI_timestr(double _time, char *str); /* time var is global */
|
||
|
||
void BLI_ascii_strtolower(char *str, int len);
|
||
void BLI_ascii_strtoupper(char *str, int len);
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|
||
|
||
#endif
|