util_string.cpp 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /* ----------------------------------------------------------------- */
  2. /* The HMM-Based Singing Voice Synthesis System "Sinsy" */
  3. /* developed by Sinsy Working Group */
  4. /* http://sinsy.sourceforge.net/ */
  5. /* ----------------------------------------------------------------- */
  6. /* */
  7. /* Copyright (c) 2009-2015 Nagoya Institute of Technology */
  8. /* Department of Computer Science */
  9. /* */
  10. /* All rights reserved. */
  11. /* */
  12. /* Redistribution and use in source and binary forms, with or */
  13. /* without modification, are permitted provided that the following */
  14. /* conditions are met: */
  15. /* */
  16. /* - Redistributions of source code must retain the above copyright */
  17. /* notice, this list of conditions and the following disclaimer. */
  18. /* - Redistributions in binary form must reproduce the above */
  19. /* copyright notice, this list of conditions and the following */
  20. /* disclaimer in the documentation and/or other materials provided */
  21. /* with the distribution. */
  22. /* - Neither the name of the Sinsy working group nor the names of */
  23. /* its contributors may be used to endorse or promote products */
  24. /* derived from this software without specific prior written */
  25. /* permission. */
  26. /* */
  27. /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND */
  28. /* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, */
  29. /* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
  30. /* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE */
  31. /* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS */
  32. /* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, */
  33. /* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
  34. /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, */
  35. /* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON */
  36. /* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, */
  37. /* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY */
  38. /* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE */
  39. /* POSSIBILITY OF SUCH DAMAGE. */
  40. /* ----------------------------------------------------------------- */
  41. #include <algorithm>
  42. #include "util_string.h"
  43. namespace sinsy
  44. {
  45. /*!
  46. c is blank character or not
  47. */
  48. bool isBlank(char c)
  49. {
  50. size_t idx(BLANK_STR.find(c));
  51. if (std::string::npos == idx) {
  52. return false;
  53. }
  54. return true;
  55. }
  56. /*!
  57. cut left and right blanks
  58. */
  59. std::string& cutBlanks(std::string& str)
  60. {
  61. size_t start(str.find_first_not_of(BLANK_STR));
  62. if (std::string::npos == start) {
  63. str.clear();
  64. return str;
  65. }
  66. size_t end(str.find_last_not_of(BLANK_STR));
  67. size_t sz(end - start + 1);
  68. if ((0 == start) && (str.size() == sz)) {
  69. return str;
  70. }
  71. str = str.substr(start, sz);
  72. return str;
  73. }
  74. /*!
  75. find first blank character
  76. */
  77. size_t findFirstOfBlank(const std::string& str)
  78. {
  79. return str.find_first_of(BLANK_STR);
  80. }
  81. /*!
  82. find first not blank character
  83. */
  84. size_t findFirstNotOfBlank(const std::string& str, size_t index)
  85. {
  86. return str.find_first_not_of(BLANK_STR, index);
  87. }
  88. /*!
  89. convert str to lower-case
  90. */
  91. void toLower(std::string& str)
  92. {
  93. std::transform(str.begin(), str.end(), str.begin(), tolower);
  94. }
  95. /*!
  96. convert str to lower-case
  97. */
  98. void toUpper(std::string& str)
  99. {
  100. std::transform(str.begin(), str.end(), str.begin(), toupper);
  101. }
  102. }; // namespace sinsy