sp_dir.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  1. #include "precompile.h"
  2. #include <time.h>
  3. #include "sp_dir.h"
  4. #include "sp_def.h"
  5. #include "shm_mem.h"
  6. #include "fileutil.h"
  7. int sp_dir_create(sp_dir_t **p_dir)
  8. {
  9. sp_dir_t *dir;
  10. int rc = Error_Unexpect;
  11. char tmp[MAX_PATH];
  12. char ver[SP_MAX_VER_LEN];
  13. dir = shm_malloc(sizeof(sp_dir_t));
  14. memset(dir, 0, sizeof(sp_dir_t));
  15. //TODO(Gifur): duplicate path value set, which would makd memory leak
  16. GetModuleFileNameA(NULL, tmp, MAX_PATH);
  17. *strrchr(tmp, SPLIT_SLASH) = 0;
  18. //C:/Run/version/1.2.3.4/bin
  19. dir->bin_path = shm_strdup(tmp);
  20. *strrchr(tmp, SPLIT_SLASH) = 0;
  21. //C:/Run/version/1.2.3.4
  22. dir->base_path = shm_strdup(tmp);
  23. *strrchr(tmp, SPLIT_SLASH) = 0;
  24. //C:/Run/version
  25. dir->root_ver_path = shm_strdup(tmp);
  26. *strrchr(tmp, SPLIT_SLASH) = 0;
  27. //C:/Run
  28. dir->root_path = shm_strdup(tmp);
  29. *strrchr(tmp, SPLIT_SLASH) = 0;
  30. //C:
  31. dir->rvc_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "rvc", tmp);
  32. //TODO: duplicate
  33. dir->root_ver_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "version", dir->root_path);
  34. dir->root_hardwarecfg_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "hardwarecfg", dir->root_path);
  35. dir->root_runinfo_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "runinfo", dir->root_path);
  36. dir->dep_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "dep", dir->base_path);
  37. dir->cfg_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "cfg", dir->base_path);
  38. dir->mod_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "mod", dir->base_path);
  39. dir->obj_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "obj", dir->base_path);
  40. dir->dbg_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "dbg", dir->rvc_path);
  41. dir->slv_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "slv", dir->rvc_path);
  42. dir->dmp_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "dmp", dir->rvc_path);
  43. dir->ad0_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "ad0", dir->rvc_path);
  44. if(!ExistsDirA(dir->root_hardwarecfg_path))
  45. CreateDirRecursiveA(dir->root_hardwarecfg_path);
  46. if (!ExistsDirA(dir->rvc_path)) {
  47. CreateDirRecursiveA(dir->rvc_path);
  48. }
  49. if (!ExistsDirA(dir->dmp_path)) {
  50. CreateDirRecursiveA(dir->dmp_path);
  51. }
  52. if (!ExistsDirA(dir->dbg_path)) {
  53. CreateDirRecursiveA(dir->dbg_path);
  54. }
  55. if (!ExistsDirA(dir->slv_path)) {
  56. CreateDirRecursiveA(dir->slv_path);
  57. }
  58. memset(tmp, 0, sizeof(tmp));
  59. sprintf(tmp, "%s" SPLIT_SLASH_STR "runcfg", dir->root_runinfo_path);
  60. if (!ExistsDirA(tmp))
  61. CreateDirRecursiveA(tmp);
  62. dir->dep_base_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "dep", dir->root_path);
  63. if (!ExistsDirA(dir->dep_base_path)) {
  64. CreateDirRecursiveA(dir->dep_base_path);
  65. }
  66. memset(tmp, 0, sizeof(tmp));
  67. sprintf(tmp, "%s" SPLIT_SLASH_STR ADAPTER_VERSION_FILE_NAME, dir->dep_base_path);
  68. memset(ver, 0, sizeof(ver));
  69. if (sp_dir_inner_get_content(tmp, ver) == 0) {
  70. dir->dep_ver_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "%s", dir->dep_base_path, ver);
  71. }
  72. else {
  73. //TODO: [Gifur@20241014]
  74. dir->dep_ver_path = NULL;
  75. }
  76. *p_dir = dir;
  77. rc = 0;
  78. return rc;
  79. }
  80. void sp_dir_destroy(sp_dir_t* dir)
  81. {
  82. if (dir) {
  83. if (dir->base_path)
  84. shm_free(dir->base_path);
  85. if (dir->rvc_path)
  86. shm_free(dir->rvc_path);
  87. if (dir->bin_path)
  88. shm_free(dir->bin_path);
  89. if (dir->dep_path)
  90. shm_free(dir->dep_path);
  91. if (dir->cfg_path)
  92. shm_free(dir->cfg_path);
  93. if (dir->mod_path)
  94. shm_free(dir->mod_path);
  95. if (dir->obj_path)
  96. shm_free(dir->obj_path);
  97. if (dir->dbg_path)
  98. shm_free(dir->dbg_path);
  99. if (dir->slv_path)
  100. shm_free(dir->slv_path);
  101. if (dir->dmp_path)
  102. shm_free(dir->dmp_path);
  103. if (dir->root_path)
  104. shm_free(dir->root_path);
  105. if (dir->root_hardwarecfg_path)
  106. shm_free(dir->root_hardwarecfg_path);
  107. if (dir->root_runinfo_path)
  108. shm_free(dir->root_runinfo_path);
  109. if (dir->root_ver_path)
  110. shm_free(dir->root_ver_path);
  111. if (dir->dep_base_path)
  112. shm_free(dir->dep_base_path);
  113. if (dir->dep_ver_path)
  114. shm_free(dir->dep_ver_path);
  115. shm_free(dir);
  116. }
  117. }
  118. static int __dir_get_path(char *base_dir, int flag, const char *cat_name, char *buf, int len, const char *site, int mode)
  119. {
  120. int rc = 0;
  121. int needed = strlen(base_dir);
  122. if (flag == SP_DIR_ENTITY_INI) {
  123. needed += strlen(cat_name) + 6;
  124. } else if (flag == SP_DIR_SHELL_INI) {
  125. needed += 11;
  126. } else if (flag == SP_DIR_SHELLVAR_INI) {
  127. needed += 22;
  128. } else if (flag == SP_DIR_MODULE_BIN) {
  129. needed += strlen(cat_name) + 6;
  130. } else if (flag == SP_DIR_ROOT_INI) {
  131. needed += strlen("root.ini") + 10;
  132. } else if (flag == SP_DIR_DEVICE_ENTITY_INI) {
  133. needed += strlen(cat_name) + 6;
  134. } else if (flag == SP_DIR_RUNINFO_INI) {
  135. needed += strlen(cat_name) + 6 + 7;
  136. } else if (flag == SP_DIR_RUNINFO_GLOBAL_INI) {
  137. needed += strlen("Global.ini") + 2;
  138. } else if (flag == SP_DIR_RUNINFO_BOOT_LOG) {
  139. needed += strlen(cat_name) + 6 + 8;
  140. } else if (flag == SP_DIR_INSTALL_INI) {
  141. needed += 13;
  142. } else if (flag == SP_DIR_EXPLORER_INI) {
  143. needed += 16;
  144. } else if (flag == SP_DIR_CENTER_SETTING_INI){
  145. needed += 18;
  146. } else if (flag == SP_DIR_ENTITY_DBG_LOG) {
  147. needed += strlen(cat_name) + 2 + 4 + 8;
  148. }
  149. else if (flag == SP_DIR_ENV_INI) {
  150. needed += strlen("env.ini") + 10;
  151. }
  152. else if (flag == SP_DIR_DEPVER_TXT) {
  153. needed += 12;
  154. }
  155. else {
  156. rc = Error_Param;
  157. }
  158. if (buf) {
  159. if (len && len < needed)
  160. return Error_TooSmallBuffer;
  161. } else {
  162. return needed;
  163. }
  164. if (flag == SP_DIR_ENTITY_INI || flag == SP_DIR_DEVICE_ENTITY_INI)
  165. {
  166. strcpy(buf, base_dir);
  167. strcat(buf, SPLIT_SLASH_STR);
  168. strcat(buf, cat_name);
  169. strcat(buf, ".ini");
  170. }
  171. else if (flag == SP_DIR_RUNINFO_INI)
  172. {
  173. strcpy(buf, base_dir);
  174. strcat(buf, SPLIT_SLASH_STR "runcfg" SPLIT_SLASH_STR);
  175. strcat(buf, cat_name);
  176. strcat(buf, ".ini");
  177. }
  178. else if (flag == SP_DIR_RUNINFO_GLOBAL_INI) {
  179. strcpy(buf, base_dir);
  180. strcat(buf, SPLIT_SLASH_STR "Global.ini");
  181. }
  182. else if (flag == SP_DIR_RUNINFO_BOOT_LOG) {
  183. strcpy(buf, base_dir);
  184. strcat(buf, SPLIT_SLASH_STR "bootrec" SPLIT_SLASH_STR);
  185. strcat(buf, cat_name);
  186. strcat(buf, ".log");
  187. } else if (flag == SP_DIR_ENTITY_DBG_LOG ) {
  188. time_t timep;
  189. struct tm *p;
  190. char td[128] = { 0 };
  191. time(&timep);
  192. p = gmtime(&timep);
  193. sprintf(td, "%04d%02d%02d.log", 1900+p->tm_year, p->tm_mon+1, p->tm_mday);
  194. strcpy(buf, base_dir);
  195. strcat(buf, SPLIT_SLASH_STR);
  196. strcat(buf, cat_name);
  197. strcat(buf, SPLIT_SLASH_STR);
  198. strcat(buf, td);
  199. }
  200. else if (flag == SP_DIR_SHELLVAR_INI){
  201. strcpy(buf, base_dir);
  202. strcat(buf, SPLIT_SLASH_STR "runcfg" SPLIT_SLASH_STR "shellVar.ini");
  203. }else if (flag == SP_DIR_SHELL_INI) {
  204. strcpy(buf, base_dir);
  205. strcat(buf, SPLIT_SLASH_STR "shell.ini");
  206. }
  207. else if (flag == SP_DIR_ENV_INI) {
  208. strcpy(buf, base_dir);
  209. strcat(buf, SPLIT_SLASH_STR "env.ini");
  210. }
  211. else if (flag == SP_DIR_MODULE_BIN) {
  212. strcpy(buf, base_dir);
  213. strcat(buf, SPLIT_SLASH_STR);
  214. #if defined(RVC_OS_WIN)
  215. strcat(buf, cat_name);
  216. strcat(buf, ".dll");
  217. #else
  218. strcat(buf, "lib");
  219. strcat(buf, cat_name);
  220. strcat(buf, ".so");
  221. #endif //RVC_OS_WIN
  222. } else if (flag == SP_DIR_ROOT_INI) {
  223. strcpy(buf, base_dir);
  224. if(mode == 1) strcat(buf, SPLIT_SLASH_STR "root-ST.ini");
  225. else if(mode == 2) strcat(buf, SPLIT_SLASH_STR "root-UAT.ini");
  226. else strcat(buf, SPLIT_SLASH_STR "root.ini");
  227. } else if (flag == SP_DIR_INSTALL_INI) {
  228. strcpy(buf, base_dir);
  229. strcat(buf, SPLIT_SLASH_STR "install.ini");
  230. }
  231. else if (flag == SP_DIR_CENTER_SETTING_INI)
  232. {
  233. strcpy(buf, base_dir);
  234. strcat(buf, SPLIT_SLASH_STR "CenterSetting.ini");
  235. }
  236. else if (flag == SP_DIR_DEPVER_TXT) {
  237. strcpy(buf, base_dir);
  238. strcat(buf, SPLIT_SLASH_STR ADAPTER_VERSION_FILE_NAME);
  239. }
  240. else {
  241. rc = (int)Error_Param;
  242. }
  243. return rc;
  244. }
  245. int sp_dir_get_path(sp_dir_t* dir, int flag, const char *cat_name, char *buf, int len)
  246. {
  247. return sp_dir_get_path_new(dir, flag, cat_name, buf, len, 0);
  248. }
  249. int sp_dir_get_path_new(sp_dir_t* dir, int flag, const char *cat_name, char *buf, int len, int mode)
  250. {
  251. char* base_path = NULL;
  252. switch (flag)
  253. {
  254. case SP_DIR_ROOT_INI:
  255. case SP_DIR_DEVICE_ENTITY_INI:
  256. base_path = dir->root_hardwarecfg_path;
  257. break;
  258. case SP_DIR_SHELL_INI:
  259. case SP_DIR_ENTITY_INI:
  260. case SP_DIR_CENTER_SETTING_INI:
  261. case SP_DIR_ENV_INI:
  262. base_path = dir->cfg_path;
  263. break;
  264. case SP_DIR_MODULE_BIN:
  265. base_path = dir->mod_path;
  266. break;
  267. case SP_DIR_RUNINFO_INI:
  268. case SP_DIR_SHELLVAR_INI:
  269. case SP_DIR_RUNINFO_GLOBAL_INI:
  270. case SP_DIR_RUNINFO_BOOT_LOG:
  271. base_path = dir->root_runinfo_path;
  272. break;
  273. case SP_DIR_INSTALL_INI:
  274. base_path = dir->base_path;
  275. break;
  276. case SP_DIR_EXPLORER_INI:
  277. base_path = dir->root_path;
  278. break;
  279. case SP_DIR_ENTITY_DBG_LOG:
  280. base_path = dir->dbg_path;
  281. break;
  282. case SP_DIR_DEPVER_TXT:
  283. base_path = dir->dep_base_path;
  284. break;
  285. default:
  286. return Error_Param;
  287. }
  288. return __dir_get_path(base_path, flag, cat_name, buf, len, NULL, mode);
  289. }
  290. int sp_dir_get_path_version(sp_dir_t* dir, int major, int minor, int revision, int build, int flag, const char *cat_name, char *buf, int len, int mode)
  291. {
  292. char tmp[MAX_PATH];
  293. char *base_path = NULL;
  294. if (flag == SP_DIR_ROOT_INI || flag == SP_DIR_DEVICE_ENTITY_INI) {
  295. base_path = dir->root_hardwarecfg_path;
  296. } else if (flag == SP_DIR_RUNINFO_INI || flag == SP_DIR_RUNINFO_BOOT_LOG) {
  297. base_path = dir->root_runinfo_path;
  298. } else if (flag == SP_DIR_SHELL_INI || flag == SP_DIR_ENTITY_INI) {
  299. sprintf(tmp, "%s" SPLIT_SLASH_STR "%d.%d.%d.%d" SPLIT_SLASH_STR "cfg", dir->root_ver_path, major, minor, revision, build);
  300. base_path = tmp;
  301. } else if (flag == SP_DIR_MODULE_BIN) {
  302. sprintf(tmp, "%s" SPLIT_SLASH_STR "%d.%d.%d.%d" SPLIT_SLASH_STR "mod", dir->root_ver_path, major, minor, revision, build);
  303. base_path = tmp;
  304. } else if (flag == SP_DIR_INSTALL_INI) {
  305. sprintf(tmp, "%s" SPLIT_SLASH_STR "%d.%d.%d.%d", dir->root_ver_path, major, minor, revision, build);
  306. base_path = tmp;
  307. } else {
  308. return Error_Param;
  309. }
  310. return __dir_get_path(base_path, flag, cat_name, buf, len, NULL, mode);
  311. }
  312. void sp_dir_get_cur_drive(char* path)
  313. {
  314. char drive[_MAX_DRIVE] = {'\0'};
  315. char dir[_MAX_DIR] = { '\0' };
  316. char fname[_MAX_FNAME] = { '\0' };
  317. char ext[_MAX_EXT] = { '\0' };
  318. char chpath[MAX_PATH] = { '\0' };
  319. GetModuleFileNameA(NULL, (LPSTR)chpath, sizeof(chpath));
  320. _splitpath(chpath, drive, dir, fname, ext);
  321. memcpy(path, drive, sizeof(drive));
  322. }
  323. int sp_dir_inner_get_content(const char* file, char* ver)
  324. {
  325. FILE* pFile = NULL;
  326. if (!ExistsFileA(file)) {
  327. return Error_NotExist;
  328. }
  329. pFile = fopen(file, "rb+");
  330. if (pFile != NULL)
  331. {
  332. char szTemp[256];
  333. int i, n;
  334. memset(szTemp, 0, sizeof(szTemp));
  335. n = fread(szTemp, 1, 256, pFile);
  336. fclose(pFile);
  337. memset(ver, 0, SP_MAX_VER_LEN);
  338. strncpy(ver, szTemp, SP_MAX_VER_LEN);
  339. if (strlen(ver) == 0) {
  340. return Error_Null;
  341. }
  342. }
  343. else
  344. {
  345. return Error_IO;
  346. }
  347. return 0;
  348. }
  349. SPBASE_API int sp_dir_refresh_dep_path(sp_dir_t* dir)
  350. {
  351. char tmp[MAX_PATH];
  352. char ver[SP_MAX_VER_LEN];
  353. int result = 0;
  354. if (dir && dir->dep_base_path != NULL && strlen(dir->dep_base_path) > 0) {
  355. memset(tmp, 0, sizeof(tmp));
  356. sprintf(tmp, "%s" SPLIT_SLASH_STR ADAPTER_VERSION_FILE_NAME, dir->dep_base_path);
  357. result = sp_dir_inner_get_content(tmp, ver);
  358. if (result == 0) {
  359. if (dir->dep_ver_path != NULL) {
  360. shm_free(dir->dep_ver_path);
  361. }
  362. dir->dep_ver_path = shm_strdup_printf("%s" SPLIT_SLASH_STR "%s", dir->dep_base_path, ver);
  363. }
  364. return result;
  365. }
  366. return Error_InvalidState;
  367. }