mem.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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 *const str){
  25. char *tmp = memString(memStrlen(str));
  26. if (str != NULL)
  27. strcpy(tmp, str);
  28. return tmp;
  29. }
  30. char *memStrCharcpy(char *str, size_t nsize, bool free_old, bool write, ...) { // 复制str到新的空间,nszie是要扩展的大小。该函数支持让str=NULL,则变为单纯的memString
  31. char *tmp = memString(memStrlen(str) + nsize);
  32. size_t base_len = memStrlen(str);
  33. if (base_len != 0)
  34. strcpy(tmp, str);
  35. if (write){
  36. va_list argp;
  37. va_start(argp, write);
  38. for (int i = 0; i < nsize; i++)
  39. tmp[base_len + i] = (char)va_arg(argp, int);
  40. va_end(argp);
  41. }
  42. if (free_old)
  43. memFree(str);
  44. return tmp;
  45. }
  46. char *memStrcatIter(char *base, bool free_base, ...) {
  47. va_list ap;
  48. va_start(ap, free_base);
  49. for (char *ch = va_arg(ap, char *); ch != NULL; ch = va_arg(ap, char *)) {
  50. base = memStrcat(base, ch, free_base, false);
  51. free_base = true;
  52. }
  53. va_end(ap);
  54. return base;
  55. }
  56. char *memStrcat(char *first, char *second, bool free_first, bool free_last) {
  57. if (first == NULL && second == NULL)
  58. return NULL;
  59. else if (first == NULL){
  60. first = second;
  61. second = NULL;
  62. free_first = free_last;
  63. free_last = false;
  64. }
  65. char *new = memStrCharcpy(first, memStrlen(second), false, false);
  66. if (second != NULL)
  67. strcat(new, second);
  68. if (free_first)
  69. memFree(first);
  70. if (free_last)
  71. memFree(second);
  72. return new;
  73. }
  74. char *memStrcpySelf(char *str, long times){
  75. bool need_free = false;
  76. char *new_str = NULL;
  77. if (times < 0){
  78. str = memStrrev(str);
  79. times = -times;
  80. need_free = true;
  81. }
  82. for (long i=0; i < times; i++)
  83. new_str = memStrcat(new_str, str, true, false);
  84. if (need_free)
  85. memFree(str);
  86. return new_str;
  87. }
  88. char *memStrrev(const char *const str){
  89. size_t len_str = memStrlen(str);
  90. char *new_str = memString(len_str);
  91. for (int i = 0;i < len_str;i++)
  92. new_str[i] = str[len_str - i - 1];
  93. return new_str;
  94. }