mem.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. #include "__virtualmath.h"
  2. jmp_buf memVirtualMath_Env;
  3. bool memVirtualMathUseJmp;
  4. void *memCalloc(size_t num, size_t size){
  5. void *tmp = calloc(num, size);
  6. if (tmp == NULL) {
  7. if (memVirtualMathUseJmp)
  8. longjmp(memVirtualMath_Env, -1);
  9. else
  10. exit(2);
  11. }
  12. return tmp;
  13. }
  14. void *memRealloc(void *old, size_t size){
  15. void *tmp = realloc(old, size);
  16. if (tmp == NULL) {
  17. if (memVirtualMathUseJmp)
  18. longjmp(memVirtualMath_Env, -1);
  19. else
  20. exit(2);
  21. }
  22. return tmp;
  23. }
  24. char *memStrcpy(const char *str){
  25. char *tmp = memString(memStrlen(str));
  26. if (str != NULL)
  27. strcpy(tmp, str);
  28. return tmp;
  29. }
  30. wchar_t *memWidecpy(const wchar_t *str){
  31. wchar_t *tmp = memWide(memWidelen(str));
  32. if (str != NULL)
  33. wcscpy(tmp, str);
  34. return tmp;
  35. }
  36. wchar_t *memWideCharcpy(wchar_t *str, size_t nsize, bool free_old, bool write, ...) { // 复制str到新的空间,nszie是要扩展的大小。该函数支持让str=NULL,则变为单纯的memString
  37. size_t base_len = memWidelen(str);
  38. wchar_t *tmp = memWide(base_len + nsize);
  39. if (base_len != 0)
  40. wcscpy(tmp, str);
  41. if (write){
  42. va_list argp;
  43. va_start(argp, write);
  44. for (int i = 0; i < nsize; i++)
  45. tmp[base_len + i] = (wchar_t)va_arg(argp, int);
  46. va_end(argp);
  47. }
  48. if (free_old)
  49. memFree(str);
  50. return tmp;
  51. }
  52. char *memStrcatIter(char *base, bool free_base, ...) {
  53. va_list ap;
  54. va_start(ap, free_base);
  55. for (char *ch = va_arg(ap, char *); ch != NULL; ch = va_arg(ap, char *)) {
  56. base = memStrcat(base, ch, free_base, false);
  57. free_base = true;
  58. }
  59. va_end(ap);
  60. return base;
  61. }
  62. char *memStrcat(char *first, char *second, bool free_first, bool free_last) {
  63. if (first == NULL && second == NULL)
  64. return NULL;
  65. else if (first == NULL){
  66. first = second;
  67. second = NULL;
  68. free_first = free_last;
  69. free_last = false;
  70. }
  71. char *new = memString(memStrlen(first) + memStrlen(second));
  72. strcat(new, first);
  73. if (second != NULL)
  74. strcat(new, second);
  75. if (free_first)
  76. memFree(first);
  77. if (free_last)
  78. memFree(second);
  79. return new;
  80. }
  81. wchar_t *memWidecat(wchar_t *first, wchar_t *second, bool free_first, bool free_last) {
  82. if (first == NULL && second == NULL)
  83. return NULL;
  84. else if (first == NULL){
  85. first = second;
  86. second = NULL;
  87. free_first = free_last;
  88. free_last = false;
  89. }
  90. wchar_t *new = memWideCharcpy(first, memWidelen(second), false, false);
  91. if (second != NULL)
  92. wcscat(new, second);
  93. if (free_first)
  94. memFree(first);
  95. if (free_last)
  96. memFree(second);
  97. return new;
  98. }
  99. wchar_t *memWidecpySelf(wchar_t *str, long times){
  100. bool need_free = false;
  101. wchar_t *new_str = NULL;
  102. if (times < 0){
  103. str = memWiderev(str);
  104. times = -times;
  105. need_free = true;
  106. }
  107. for (long i=0; i < times; i++)
  108. new_str = memWidecat(new_str, str, true, false);
  109. if (need_free)
  110. memFree(str);
  111. return new_str;
  112. }
  113. wchar_t *memWiderev(wchar_t *str){
  114. size_t len_str = memWidelen(str);
  115. wchar_t *new_str = memWide(len_str);
  116. for (int i = 0;i < len_str;i++)
  117. new_str[i] = str[len_str - i - 1];
  118. return new_str;
  119. }
  120. wchar_t *memStrToWcs(char *str, bool free_old) {
  121. size_t len = memStrlen(str);
  122. wchar_t *tmp = memWide(len);
  123. mbstowcs(tmp, str, len);
  124. if (free_old)
  125. memFree(str);
  126. return tmp;
  127. }
  128. char *memWcsToStr(wchar_t *wcs, bool free_old) {
  129. size_t len = memWidelen(wcs);
  130. char *tmp = memString(len);
  131. wcstombs(tmp, wcs, len);
  132. if (free_old)
  133. memFree(wcs);
  134. return tmp;
  135. }