1
0

mem.c 3.9 KB

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