mem.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #include "__virtualmath.h"
  2. jmp_buf memVirtualMath_Env;
  3. bool memVirtualMathUseJmp;
  4. void *memCalloc(size_t num, size_t size){
  5. void *tmp = NULL;
  6. if (num == 0 || size == 0)
  7. return NULL;
  8. tmp = calloc(num, size);
  9. if (tmp == NULL) {
  10. if (memVirtualMathUseJmp)
  11. longjmp(memVirtualMath_Env, -1);
  12. else
  13. exit(2);
  14. }
  15. return tmp;
  16. }
  17. void *memRealloc(void *old, size_t size){
  18. void *tmp = NULL;
  19. if (size <= 0)
  20. return NULL;
  21. else if (old == NULL)
  22. tmp = memCalloc(1,size);
  23. else
  24. tmp = realloc(old, size);
  25. if (tmp == NULL) {
  26. if (memVirtualMathUseJmp)
  27. longjmp(memVirtualMath_Env, -1);
  28. else
  29. exit(2);
  30. }
  31. return tmp;
  32. }
  33. char *memStrcpy(const char *const str){
  34. char *tmp = memString(memStrlen(str));
  35. if (str != NULL)
  36. strcpy(tmp, str);
  37. return tmp;
  38. }
  39. char *memStrCharcpy(char *str, size_t nsize, bool free_old, bool write, ...) { // 复制str到新的空间,nszie是要扩展的大小。该函数支持让str=NULL,则变为单纯的memString
  40. char *tmp = memString(memStrlen(str) + nsize);
  41. size_t base_len = memStrlen(str);
  42. if (base_len != 0)
  43. strcpy(tmp, str);
  44. if (write){
  45. va_list argp;
  46. va_start(argp, write);
  47. for (int i = 0; i < nsize; i++)
  48. tmp[base_len + i] = (char)va_arg(argp, int);
  49. va_end(argp);
  50. }
  51. if (free_old)
  52. memFree(str);
  53. return tmp;
  54. }
  55. char *memStrcat(char *first, char *second, bool free_first, bool free_last) {
  56. if (first == NULL && second == NULL)
  57. return NULL;
  58. else if (first == NULL){
  59. first = second;
  60. second = NULL;
  61. free_first = free_last;
  62. free_last = false;
  63. }
  64. char *new = memStrCharcpy(first, memStrlen(second), false, false);
  65. if (second != NULL)
  66. strcat(new, second);
  67. if (free_first)
  68. memFree(first);
  69. if (free_last)
  70. memFree(second);
  71. return new;
  72. }
  73. char *memStrcpySelf(char *str, long times){
  74. bool need_free = false;
  75. char *new_str = NULL;
  76. if (times < 0){
  77. str = memStrrev(str);
  78. times = -times;
  79. need_free = true;
  80. }
  81. for (long i=0; i < times; i++)
  82. new_str = memStrcat(new_str, str, true, false);
  83. if (need_free)
  84. memFree(str);
  85. return new_str;
  86. }
  87. char *memStrrev(const char *const str){
  88. size_t len_str = memStrlen(str);
  89. char *new_str = memString(len_str);
  90. for (int i = 0;i < len_str;i++)
  91. new_str[i] = str[len_str - i - 1];
  92. return new_str;
  93. }