A static site generator, written in C
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

cms_util.c 2.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. #include <fcntl.h>
  2. #include <unistd.h>
  3. #include <stdio.h>
  4. #include <stddef.h>
  5. #include <string.h>
  6. #include <stdlib.h>
  7. #include <dirent.h>
  8. #include <sys/stat.h>
  9. #include <sys/types.h>
  10. #include <errno.h>
  11. #include "cms_util.h"
  12. int cms_util_file_exists(char* fname)
  13. {
  14. int f = open(fname, O_RDONLY);
  15. close(f);
  16. if (errno == ENOENT)
  17. return 0;
  18. else
  19. return 1;
  20. }
  21. cms_err cms_util_file_create(char* fname)
  22. {
  23. int f = open(fname, O_CREAT);
  24. close(f);
  25. if (f == -1)
  26. return cms_err_from_std_err(errno);
  27. else
  28. return CMS_ERR_NONE;
  29. }
  30. cms_err cms_util_file_copy(char* fname1, char* fname2)
  31. {
  32. int f1 = open(fname1, O_RDONLY);
  33. int f2 = open(fname2, O_WRONLY);
  34. struct stat* s = malloc(sizeof(struct stat));
  35. if (s == NULL)
  36. return CMS_ERR_ALLOC;
  37. fstat(f1, s);
  38. void* buf = malloc(s->st_size);
  39. if (buf == NULL)
  40. return CMS_ERR_ALLOC;
  41. read(f1, buf, s->st_size);
  42. write(f2, buf, s->st_size);
  43. close(f1);
  44. close(f2);
  45. free(s);
  46. free(buf);
  47. return CMS_ERR_NONE;
  48. }
  49. cms_err cms_util_dir_copy_recursive(char* dir1, char* dir2)
  50. {
  51. if (mkdir(dir2, 0777) == -1)
  52. return cms_err_from_std_err(errno);
  53. DIR* dp = opendir(dir1);
  54. if (dp == NULL)
  55. return cms_err_from_std_err(errno);
  56. struct dirent* ep;
  57. struct stat* st = malloc(sizeof(struct stat));
  58. if (st == NULL)
  59. return CMS_ERR_ALLOC;
  60. while (ep = readdir(dp))
  61. {
  62. char* path1 = cms_util_path_join(dir1, ep->d_name);
  63. char* path2 = cms_util_path_join(dir2, ep->d_name);
  64. stat(path1, st);
  65. if (S_ISDIR(st->st_mode))
  66. {
  67. cms_err err = cms_util_dir_copy_recursive(path1, path2);
  68. if (err != CMS_ERR_NONE)
  69. return err;
  70. }
  71. else
  72. {
  73. cms_err err = cms_util_file_copy(path1, path2);
  74. if (err != CMS_ERR_NONE)
  75. return err;
  76. }
  77. }
  78. free(st);
  79. return 0;
  80. }
  81. char* cms_util_path_join(char* str1, char* str2)
  82. {
  83. size_t len1 = strlen(str1);
  84. size_t len2 = strlen(str2);
  85. if (str1[len1 - 1] == '/')
  86. {
  87. len1 -= 1;
  88. }
  89. char* path = malloc((len1 + len2 + 1) * sizeof(char));
  90. if (path == NULL)
  91. cms_err_panic(CMS_ERR_ALLOC, "");
  92. if (path == NULL)
  93. return NULL;
  94. memcpy(path, str1, len1); //First part
  95. path[len1] = '/'; //Separator
  96. memcpy(path + len1 + 1, str2, len2); //Second part
  97. path[len1 + len2 + 1] = '\0'; //Null terminator
  98. return path;
  99. }