string_split.h 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. Bullet Continuous Collision Detection and Physics Library
  3. Copyright (c) 2003-2012 Erwin Coumans http://bulletphysics.org
  4. This software is provided 'as-is', without any express or implied warranty.
  5. In no event will the authors be held liable for any damages arising from the use of this software.
  6. Permission is granted to anyone to use this software for any purpose,
  7. including commercial applications, and to alter it and redistribute it freely,
  8. subject to the following restrictions:
  9. 1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
  10. 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
  11. 3. This notice may not be removed or altered from any source distribution.
  12. */
  13. ///The string split C code is by Lars Wirzenius
  14. ///See http://stackoverflow.com/questions/2531605/how-to-split-a-string-with-a-delimiter-larger-than-one-single-char
  15. #ifndef STRING_SPLIT_H
  16. #define STRING_SPLIT_H
  17. #include <cstring>
  18. #include "LinearMath/btAlignedObjectArray.h"
  19. #include <string>
  20. namespace bullet_utils
  21. {
  22. void split( btAlignedObjectArray<std::string>&pieces, const std::string& vector_str, const std::string& separator);
  23. };
  24. ///The string split C code is by Lars Wirzenius
  25. ///See http://stackoverflow.com/questions/2531605/how-to-split-a-string-with-a-delimiter-larger-than-one-single-char
  26. /* Split a string into substrings. Return dynamic array of dynamically
  27. allocated substrings, or NULL if there was an error. Caller is
  28. expected to free the memory, for example with str_array_free. */
  29. char** str_split(const char* input, const char* sep);
  30. /* Free a dynamic array of dynamic strings. */
  31. void str_array_free(char** array);
  32. /* Return length of a NULL-delimited array of strings. */
  33. size_t str_array_len(char** array);
  34. #endif //STRING_SPLIT_H