1
0

SII.inc 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. //======================================================
  2. // Slick's INI Include 2.0.6
  3. //
  4. // (c) Copyright 2008-2009, [DRuG]Slick
  5. // This file is provided as is (no warranties).
  6. //======================================================
  7. #pragma dynamic 25000 // Change accordingly!!
  8. #if defined MAX_STRING
  9. #define INI_MAX_VALUE MAX_STRING
  10. #else
  11. #define INI_MAX_VALUE 128
  12. #endif
  13. #define INI_MAX_KEY 24
  14. #define INI_MAX_LINE (INI_MAX_KEY + INI_MAX_VALUE + 3)
  15. #define INI_MAX_FILENAME 256
  16. #define INI_MAX_LINES 128
  17. enum E_CACHE
  18. {
  19. E_KEY[INI_MAX_KEY],
  20. E_VALUE[INI_MAX_VALUE]
  21. }
  22. enum E_FILE
  23. {
  24. E_FILENAME[INI_MAX_FILENAME],
  25. bool: E_OPEN
  26. }
  27. static gCache[INI_MAX_LINES][E_CACHE];
  28. static gEmptyCache[E_CACHE];
  29. static gFile[E_FILE];
  30. static gNoFile[E_FILE];
  31. #define INI_Exist fexist
  32. stock INI_Open(const filename[])
  33. {
  34. if (!filename[0]) return false;
  35. if (gFile[E_OPEN])
  36. {
  37. if (!strcmp(gFile[E_FILENAME], filename, true)) return true;
  38. return false;
  39. }
  40. new File: h;
  41. h = fopen(filename, io_readwrite);
  42. if (h)
  43. {
  44. INI_strcpy(gFile[E_FILENAME], filename, INI_MAX_FILENAME, INI_MAX_FILENAME);
  45. new line[INI_MAX_LINE];
  46. new ln = -1;
  47. new separator;
  48. while (((ln + 1) < INI_MAX_LINES) && (fread(h, line)))
  49. {
  50. ln ++;
  51. INI_StripLine(line);
  52. separator = strfind(line, "=", false);
  53. if ((line[0] == ';') || (line[0] == '=') || (separator == -1) || (separator > INI_MAX_KEY))
  54. {
  55. if (line[0] == ';')
  56. {
  57. INI_strcpy(gCache[ln][E_VALUE], line, INI_MAX_VALUE, INI_MAX_VALUE);
  58. }
  59. else
  60. {
  61. INI_strcpy(gCache[ln][E_VALUE][1], line, INI_MAX_VALUE, INI_MAX_VALUE);
  62. gCache[ln][E_VALUE][0] = ';';
  63. }
  64. continue;
  65. }
  66. INI_strcpy(gCache[ln][E_KEY], line, separator, INI_MAX_KEY);
  67. INI_strcpy(gCache[ln][E_VALUE], line[separator + 1], INI_MAX_VALUE, INI_MAX_VALUE);
  68. if (!gCache[ln][E_VALUE][0]) gCache[ln][E_VALUE][0] = ' ';
  69. }
  70. fclose(h);
  71. gFile[E_OPEN] = true;
  72. return 1;
  73. }
  74. return 0;
  75. }
  76. stock INI_Save()
  77. {
  78. if (!gFile[E_OPEN]) return false;
  79. new File: h;
  80. h = fopen(gFile[E_FILENAME], io_write);
  81. if (h)
  82. {
  83. new line[INI_MAX_LINE];
  84. new ln = -1;
  85. while (((ln + 1) < INI_MAX_LINES) && (gCache[ln + 1][E_VALUE][0]))
  86. {
  87. ln ++;
  88. if (gCache[ln][E_VALUE][0] == ';')
  89. {
  90. if (gCache[ln][E_VALUE][1])
  91. {
  92. format(line, sizeof(line), "%s\r\n", gCache[ln][E_VALUE]);
  93. fwrite(h, line);
  94. continue;
  95. }
  96. fwrite(h, "\r\n");
  97. continue;
  98. }
  99. format(line, sizeof(line), "%s=%s\r\n", gCache[ln][E_KEY], gCache[ln][E_VALUE]);
  100. fwrite(h, line);
  101. }
  102. fclose(h);
  103. return true;
  104. }
  105. return false;
  106. }
  107. stock INI_Close()
  108. {
  109. if (!gFile[E_OPEN]) return false;
  110. for (new ln; ln < INI_MAX_LINES; ln++) gCache[ln] = gEmptyCache;
  111. gFile = gNoFile;
  112. return true;
  113. }
  114. stock INI_Create(filename[]) {
  115. if (fexist(filename)) return false;
  116. new File:fhnd;
  117. fhnd=fopen(filename,io_write);
  118. if (fhnd) {
  119. fclose(fhnd);
  120. return true;
  121. }
  122. return false;
  123. }
  124. stock INI_ReadString(dest[], const key[], maxlength = sizeof(dest))
  125. {
  126. if ((!gFile[E_OPEN]) || (!key[0])) return false;
  127. new ln = -1;
  128. while (((ln + 1) < INI_MAX_LINES) && (gCache[ln + 1][E_VALUE][0]))
  129. {
  130. ln ++;
  131. if (gCache[ln][E_VALUE][0] == ';') continue;
  132. if (!strcmp(gCache[ln][E_KEY], key, false))
  133. {
  134. INI_strcpy(dest, gCache[ln][E_VALUE], INI_MAX_VALUE, maxlength);
  135. return true;
  136. }
  137. }
  138. return false;
  139. }
  140. stock INI_ReadInt(const key[])
  141. {
  142. new dest[11];
  143. if (INI_ReadString(dest, key)) return strval(dest);
  144. return false;
  145. }
  146. stock Float: INI_ReadFloat(const key[])
  147. {
  148. new dest[11];
  149. if (INI_ReadString(dest, key)) return floatstr(dest);
  150. return 0.0;
  151. }
  152. stock INI_WriteString(const key[], const value[])
  153. {
  154. if ((!gFile[E_OPEN]) || (!key[0]) || (key[0] == ';') || (strfind(key, "=", false) != -1)) return false;
  155. new ln = -1;
  156. while (((ln + 1) < INI_MAX_LINES) && (gCache[ln + 1][E_VALUE][0]))
  157. {
  158. ln ++;
  159. if (gCache[ln][E_VALUE][0] == ';') continue;
  160. if (!strcmp(gCache[ln][E_KEY], key, false))
  161. {
  162. INI_strcpy(gCache[ln][E_VALUE], value, INI_MAX_VALUE, INI_MAX_VALUE);
  163. return true;
  164. }
  165. }
  166. ln ++;
  167. if (ln < INI_MAX_LINES)
  168. {
  169. INI_strcpy(gCache[ln][E_KEY], key, INI_MAX_KEY, INI_MAX_KEY);
  170. INI_strcpy(gCache[ln][E_VALUE], value, INI_MAX_VALUE, INI_MAX_VALUE);
  171. return true;
  172. }
  173. return false;
  174. }
  175. stock INI_WriteInt(const key[], value)
  176. {
  177. new dest[11];
  178. format(dest, sizeof(dest), "%i", value);
  179. return INI_WriteString(key, dest);
  180. }
  181. stock INI_WriteFloat(const key[], Float: value)
  182. {
  183. new dest[11];
  184. format(dest, sizeof(dest), "%0.4f", value);
  185. return INI_WriteString(key, dest);
  186. }
  187. stock INI_RemoveEntry(const key[])
  188. {
  189. if ((!gFile[E_OPEN]) || (!key[0]) || (strfind(key, "=", false) != -1)) return false;
  190. new ln = -1;
  191. while (((ln + 1) < INI_MAX_LINES) && (gCache[ln + 1][E_VALUE][0]))
  192. {
  193. ln ++;
  194. if (gCache[ln][E_VALUE][0] == ';') continue;
  195. if (!strcmp(gCache[ln][E_KEY], key, false))
  196. {
  197. for (; ln < (INI_MAX_LINES - 1); ln ++)
  198. {
  199. INI_strcpy(gCache[ln][E_KEY], gCache[ln + 1][E_KEY], INI_MAX_KEY, INI_MAX_KEY);
  200. INI_strcpy(gCache[ln][E_VALUE], gCache[ln + 1][E_VALUE], INI_MAX_VALUE, INI_MAX_VALUE);
  201. }
  202. return true;
  203. }
  204. }
  205. return false;
  206. }
  207. stock INI_Remove(const filename[])
  208. {
  209. if (!filename[0]) return false;
  210. if ((gFile[E_OPEN]) && (!strcmp(gFile[E_FILENAME], filename, true))) gFile = gNoFile;
  211. return fremove(filename);
  212. }
  213. stock INI_strcpy(dest[], const source[], numcells = sizeof(source), maxlength = sizeof(dest))
  214. {
  215. new i;
  216. while ((source[i]) && (i < numcells) && (i < maxlength))
  217. {
  218. dest[i] = source[i];
  219. i ++;
  220. }
  221. dest[(i == maxlength) ? (i - 1) : (i)] = '\0';
  222. }
  223. stock INI_StripLine(string[])
  224. {
  225. new l;
  226. l = strlen(string);
  227. if (string[l - 2] == '\r') string[l - 2] = '\0';
  228. if (string[l - 1] == '\n') string[l - 1] = '\0';
  229. }