Platform.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535
  1. /* voc 2.1.0 [2019/11/01]. Bootstrapping compiler for address size 8, alignment 8. xrtspaSF */
  2. #define SHORTINT INT8
  3. #define INTEGER INT16
  4. #define LONGINT INT32
  5. #define SET UINT32
  6. #include "SYSTEM.h"
  7. typedef
  8. struct Platform_FileIdentity {
  9. INT32 volume, index, mtime;
  10. } Platform_FileIdentity;
  11. typedef
  12. void (*Platform_SignalHandler)(INT32);
  13. export BOOLEAN Platform_LittleEndian;
  14. export INT16 Platform_PID;
  15. export CHAR Platform_CWD[256];
  16. static INT32 Platform_TimeStart;
  17. export INT16 Platform_SeekSet, Platform_SeekCur, Platform_SeekEnd;
  18. export CHAR Platform_NL[3];
  19. export ADDRESS *Platform_FileIdentity__typ;
  20. export BOOLEAN Platform_Absent (INT16 e);
  21. export INT16 Platform_Chdir (CHAR *n, ADDRESS n__len);
  22. export INT16 Platform_Close (INT32 h);
  23. export BOOLEAN Platform_ConnectionFailed (INT16 e);
  24. export void Platform_Delay (INT32 ms);
  25. export BOOLEAN Platform_DifferentFilesystems (INT16 e);
  26. export INT16 Platform_Error (void);
  27. export void Platform_Exit (INT32 code);
  28. export void Platform_GetClock (INT32 *t, INT32 *d);
  29. export void Platform_GetEnv (CHAR *var, ADDRESS var__len, CHAR *val, ADDRESS val__len);
  30. export void Platform_GetTimeOfDay (INT32 *sec, INT32 *usec);
  31. export INT16 Platform_Identify (INT32 h, Platform_FileIdentity *identity, ADDRESS *identity__typ);
  32. export INT16 Platform_IdentifyByName (CHAR *n, ADDRESS n__len, Platform_FileIdentity *identity, ADDRESS *identity__typ);
  33. export BOOLEAN Platform_Inaccessible (INT16 e);
  34. export BOOLEAN Platform_Interrupted (INT16 e);
  35. export BOOLEAN Platform_IsConsole (INT32 h);
  36. export void Platform_MTimeAsClock (Platform_FileIdentity i, INT32 *t, INT32 *d);
  37. export INT16 Platform_MaxNameLength (void);
  38. export INT16 Platform_MaxPathLength (void);
  39. export INT16 Platform_New (CHAR *n, ADDRESS n__len, INT32 *h);
  40. export BOOLEAN Platform_NoSuchDirectory (INT16 e);
  41. export INT32 Platform_OSAllocate (INT32 size);
  42. export void Platform_OSFree (INT32 address);
  43. export INT16 Platform_OldRO (CHAR *n, ADDRESS n__len, INT32 *h);
  44. export INT16 Platform_OldRW (CHAR *n, ADDRESS n__len, INT32 *h);
  45. export INT16 Platform_Read (INT32 h, INT32 p, INT32 l, INT32 *n);
  46. export INT16 Platform_ReadBuf (INT32 h, SYSTEM_BYTE *b, ADDRESS b__len, INT32 *n);
  47. export INT16 Platform_Rename (CHAR *o, ADDRESS o__len, CHAR *n, ADDRESS n__len);
  48. export BOOLEAN Platform_SameFile (Platform_FileIdentity i1, Platform_FileIdentity i2);
  49. export BOOLEAN Platform_SameFileTime (Platform_FileIdentity i1, Platform_FileIdentity i2);
  50. export INT16 Platform_Seek (INT32 h, INT32 offset, INT16 whence);
  51. export void Platform_SetBadInstructionHandler (Platform_SignalHandler handler);
  52. export void Platform_SetInterruptHandler (Platform_SignalHandler handler);
  53. export void Platform_SetMTime (Platform_FileIdentity *target, ADDRESS *target__typ, Platform_FileIdentity source);
  54. export void Platform_SetQuitHandler (Platform_SignalHandler handler);
  55. export INT16 Platform_Size (INT32 h, INT32 *l);
  56. export INT16 Platform_Sync (INT32 h);
  57. export INT16 Platform_System (CHAR *cmd, ADDRESS cmd__len);
  58. static void Platform_TestLittleEndian (void);
  59. export INT32 Platform_Time (void);
  60. export BOOLEAN Platform_TimedOut (INT16 e);
  61. export BOOLEAN Platform_TooManyFiles (INT16 e);
  62. export INT16 Platform_Truncate (INT32 h, INT32 l);
  63. export INT16 Platform_Unlink (CHAR *n, ADDRESS n__len);
  64. export INT16 Platform_Write (INT32 h, INT32 p, INT32 l);
  65. static void Platform_YMDHMStoClock (INT32 ye, INT32 mo, INT32 da, INT32 ho, INT32 mi, INT32 se, INT32 *t, INT32 *d);
  66. export BOOLEAN Platform_getEnv (CHAR *var, ADDRESS var__len, CHAR *val, ADDRESS val__len);
  67. #include <errno.h>
  68. #include <errno.h>
  69. #include <fcntl.h>
  70. #include <sys/stat.h>
  71. #include <sys/time.h>
  72. #include <sys/types.h>
  73. #include <time.h>
  74. #include <unistd.h>
  75. #include <limits.h>
  76. #include <stdio.h>
  77. #include <stdlib.h>
  78. #define Platform_EACCES() EACCES
  79. #define Platform_EAGAIN() EAGAIN
  80. #define Platform_ECONNABORTED() ECONNABORTED
  81. #define Platform_ECONNREFUSED() ECONNREFUSED
  82. #define Platform_EHOSTUNREACH() EHOSTUNREACH
  83. #define Platform_EINTR() EINTR
  84. #define Platform_EMFILE() EMFILE
  85. #define Platform_ENETUNREACH() ENETUNREACH
  86. #define Platform_ENFILE() ENFILE
  87. #define Platform_ENOENT() ENOENT
  88. #define Platform_EROFS() EROFS
  89. #define Platform_ETIMEDOUT() ETIMEDOUT
  90. #define Platform_EXDEV() EXDEV
  91. #define Platform_NAMEMAX() NAME_MAX
  92. #define Platform_PATHMAX() PATH_MAX
  93. #define Platform_allocate(size) (ADDRESS)((void*)malloc((size_t)size))
  94. #define Platform_chdir(n, n__len) chdir((char*)n)
  95. #define Platform_closefile(fd) close(fd)
  96. #define Platform_err() errno
  97. #define Platform_exit(code) exit((int)code)
  98. #define Platform_free(address) free((void*)address)
  99. #define Platform_fstat(fd) fstat(fd, &s)
  100. #define Platform_fsync(fd) fsync(fd)
  101. #define Platform_ftruncate(fd, l) ftruncate(fd, l)
  102. #define Platform_getcwd(cwd, cwd__len) getcwd((char*)cwd, cwd__len)
  103. #define Platform_getenv(var, var__len) getenv((char*)var)
  104. #define Platform_getpid() (INTEGER)getpid()
  105. #define Platform_gettimeval() struct timeval tv; gettimeofday(&tv,0)
  106. #define Platform_isatty(fd) isatty(fd)
  107. #define Platform_lseek(fd, o, w) lseek(fd, o, w)
  108. #define Platform_nanosleep(s, ns) struct timespec req, rem; req.tv_sec = s; req.tv_nsec = ns; nanosleep(&req, &rem)
  109. #define Platform_opennew(n, n__len) open((char*)n, O_CREAT | O_TRUNC | O_RDWR, 0664)
  110. #define Platform_openro(n, n__len) open((char*)n, O_RDONLY)
  111. #define Platform_openrw(n, n__len) open((char*)n, O_RDWR)
  112. #define Platform_readfile(fd, p, l) (LONGINT)read(fd, (void*)(ADDRESS)(p), l)
  113. #define Platform_rename(o, o__len, n, n__len) rename((char*)o, (char*)n)
  114. #define Platform_sectotm(s) struct tm *time = localtime((time_t*)&s)
  115. #define Platform_seekcur() SEEK_CUR
  116. #define Platform_seekend() SEEK_END
  117. #define Platform_seekset() SEEK_SET
  118. #define Platform_sethandler(s, h) SystemSetHandler(s, (ADDRESS)h)
  119. #define Platform_stat(n, n__len) stat((char*)n, &s)
  120. #define Platform_statdev() (LONGINT)s.st_dev
  121. #define Platform_statino() (LONGINT)s.st_ino
  122. #define Platform_statmtime() (LONGINT)s.st_mtime
  123. #define Platform_statsize() (ADDRESS)s.st_size
  124. #define Platform_structstats() struct stat s
  125. #define Platform_system(str, str__len) system((char*)str)
  126. #define Platform_tmhour() (LONGINT)time->tm_hour
  127. #define Platform_tmmday() (LONGINT)time->tm_mday
  128. #define Platform_tmmin() (LONGINT)time->tm_min
  129. #define Platform_tmmon() (LONGINT)time->tm_mon
  130. #define Platform_tmsec() (LONGINT)time->tm_sec
  131. #define Platform_tmyear() (LONGINT)time->tm_year
  132. #define Platform_tvsec() tv.tv_sec
  133. #define Platform_tvusec() tv.tv_usec
  134. #define Platform_unlink(n, n__len) unlink((char*)n)
  135. #define Platform_writefile(fd, p, l) write(fd, (void*)(ADDRESS)(p), l)
  136. BOOLEAN Platform_TooManyFiles (INT16 e)
  137. {
  138. return e == Platform_EMFILE() || e == Platform_ENFILE();
  139. }
  140. BOOLEAN Platform_NoSuchDirectory (INT16 e)
  141. {
  142. return e == Platform_ENOENT();
  143. }
  144. BOOLEAN Platform_DifferentFilesystems (INT16 e)
  145. {
  146. return e == Platform_EXDEV();
  147. }
  148. BOOLEAN Platform_Inaccessible (INT16 e)
  149. {
  150. return (e == Platform_EACCES() || e == Platform_EROFS()) || e == Platform_EAGAIN();
  151. }
  152. BOOLEAN Platform_Absent (INT16 e)
  153. {
  154. return e == Platform_ENOENT();
  155. }
  156. BOOLEAN Platform_TimedOut (INT16 e)
  157. {
  158. return e == Platform_ETIMEDOUT();
  159. }
  160. BOOLEAN Platform_ConnectionFailed (INT16 e)
  161. {
  162. return ((e == Platform_ECONNREFUSED() || e == Platform_ECONNABORTED()) || e == Platform_ENETUNREACH()) || e == Platform_EHOSTUNREACH();
  163. }
  164. BOOLEAN Platform_Interrupted (INT16 e)
  165. {
  166. return e == Platform_EINTR();
  167. }
  168. INT16 Platform_MaxNameLength (void)
  169. {
  170. return Platform_NAMEMAX();
  171. }
  172. INT16 Platform_MaxPathLength (void)
  173. {
  174. return Platform_PATHMAX();
  175. }
  176. INT32 Platform_OSAllocate (INT32 size)
  177. {
  178. return Platform_allocate(size);
  179. }
  180. void Platform_OSFree (INT32 address)
  181. {
  182. Platform_free(address);
  183. }
  184. typedef
  185. CHAR (*EnvPtr__83)[1024];
  186. BOOLEAN Platform_getEnv (CHAR *var, ADDRESS var__len, CHAR *val, ADDRESS val__len)
  187. {
  188. EnvPtr__83 p = NIL;
  189. __DUP(var, var__len, CHAR);
  190. p = (EnvPtr__83)(ADDRESS)Platform_getenv(var, var__len);
  191. if (p != NIL) {
  192. __COPY(*p, val, val__len);
  193. }
  194. __DEL(var);
  195. return p != NIL;
  196. }
  197. void Platform_GetEnv (CHAR *var, ADDRESS var__len, CHAR *val, ADDRESS val__len)
  198. {
  199. __DUP(var, var__len, CHAR);
  200. if (!Platform_getEnv(var, var__len, (void*)val, val__len)) {
  201. val[0] = 0x00;
  202. }
  203. __DEL(var);
  204. }
  205. void Platform_SetInterruptHandler (Platform_SignalHandler handler)
  206. {
  207. Platform_sethandler(2, handler);
  208. }
  209. void Platform_SetQuitHandler (Platform_SignalHandler handler)
  210. {
  211. Platform_sethandler(3, handler);
  212. }
  213. void Platform_SetBadInstructionHandler (Platform_SignalHandler handler)
  214. {
  215. Platform_sethandler(4, handler);
  216. }
  217. static void Platform_YMDHMStoClock (INT32 ye, INT32 mo, INT32 da, INT32 ho, INT32 mi, INT32 se, INT32 *t, INT32 *d)
  218. {
  219. *d = (__ASHL((int)__MOD(ye, 100), 9) + __ASHL(mo + 1, 5)) + da;
  220. *t = (__ASHL(ho, 12) + __ASHL(mi, 6)) + se;
  221. }
  222. void Platform_GetClock (INT32 *t, INT32 *d)
  223. {
  224. Platform_gettimeval();
  225. Platform_sectotm(Platform_tvsec());
  226. Platform_YMDHMStoClock(Platform_tmyear(), Platform_tmmon(), Platform_tmmday(), Platform_tmhour(), Platform_tmmin(), Platform_tmsec(), &*t, &*d);
  227. }
  228. void Platform_GetTimeOfDay (INT32 *sec, INT32 *usec)
  229. {
  230. Platform_gettimeval();
  231. *sec = Platform_tvsec();
  232. *usec = Platform_tvusec();
  233. }
  234. INT32 Platform_Time (void)
  235. {
  236. INT32 ms;
  237. Platform_gettimeval();
  238. ms = (int)__DIVF(Platform_tvusec(), 1000) + Platform_tvsec() * 1000;
  239. return (int)__MOD(ms - Platform_TimeStart, 2147483647);
  240. }
  241. void Platform_Delay (INT32 ms)
  242. {
  243. INT32 s, ns;
  244. s = __DIV(ms, 1000);
  245. ns = (int)__MOD(ms, 1000) * 1000000;
  246. Platform_nanosleep(s, ns);
  247. }
  248. INT16 Platform_System (CHAR *cmd, ADDRESS cmd__len)
  249. {
  250. __DUP(cmd, cmd__len, CHAR);
  251. __DEL(cmd);
  252. return Platform_system(cmd, cmd__len);
  253. }
  254. INT16 Platform_Error (void)
  255. {
  256. return Platform_err();
  257. }
  258. INT16 Platform_OldRO (CHAR *n, ADDRESS n__len, INT32 *h)
  259. {
  260. INT16 fd;
  261. fd = Platform_openro(n, n__len);
  262. if (fd < 0) {
  263. return Platform_err();
  264. } else {
  265. *h = fd;
  266. return 0;
  267. }
  268. __RETCHK;
  269. }
  270. INT16 Platform_OldRW (CHAR *n, ADDRESS n__len, INT32 *h)
  271. {
  272. INT16 fd;
  273. fd = Platform_openrw(n, n__len);
  274. if (fd < 0) {
  275. return Platform_err();
  276. } else {
  277. *h = fd;
  278. return 0;
  279. }
  280. __RETCHK;
  281. }
  282. INT16 Platform_New (CHAR *n, ADDRESS n__len, INT32 *h)
  283. {
  284. INT16 fd;
  285. fd = Platform_opennew(n, n__len);
  286. if (fd < 0) {
  287. return Platform_err();
  288. } else {
  289. *h = fd;
  290. return 0;
  291. }
  292. __RETCHK;
  293. }
  294. INT16 Platform_Close (INT32 h)
  295. {
  296. if (Platform_closefile(h) < 0) {
  297. return Platform_err();
  298. } else {
  299. return 0;
  300. }
  301. __RETCHK;
  302. }
  303. BOOLEAN Platform_IsConsole (INT32 h)
  304. {
  305. return Platform_isatty(h) != 0;
  306. }
  307. INT16 Platform_Identify (INT32 h, Platform_FileIdentity *identity, ADDRESS *identity__typ)
  308. {
  309. Platform_structstats();
  310. if (Platform_fstat(h) < 0) {
  311. return Platform_err();
  312. }
  313. (*identity).volume = Platform_statdev();
  314. (*identity).index = Platform_statino();
  315. (*identity).mtime = Platform_statmtime();
  316. return 0;
  317. }
  318. INT16 Platform_IdentifyByName (CHAR *n, ADDRESS n__len, Platform_FileIdentity *identity, ADDRESS *identity__typ)
  319. {
  320. __DUP(n, n__len, CHAR);
  321. Platform_structstats();
  322. if (Platform_stat(n, n__len) < 0) {
  323. __DEL(n);
  324. return Platform_err();
  325. }
  326. (*identity).volume = Platform_statdev();
  327. (*identity).index = Platform_statino();
  328. (*identity).mtime = Platform_statmtime();
  329. __DEL(n);
  330. return 0;
  331. }
  332. BOOLEAN Platform_SameFile (Platform_FileIdentity i1, Platform_FileIdentity i2)
  333. {
  334. return (i1.index == i2.index && i1.volume == i2.volume);
  335. }
  336. BOOLEAN Platform_SameFileTime (Platform_FileIdentity i1, Platform_FileIdentity i2)
  337. {
  338. return i1.mtime == i2.mtime;
  339. }
  340. void Platform_SetMTime (Platform_FileIdentity *target, ADDRESS *target__typ, Platform_FileIdentity source)
  341. {
  342. (*target).mtime = source.mtime;
  343. }
  344. void Platform_MTimeAsClock (Platform_FileIdentity i, INT32 *t, INT32 *d)
  345. {
  346. Platform_sectotm(i.mtime);
  347. Platform_YMDHMStoClock(Platform_tmyear(), Platform_tmmon(), Platform_tmmday(), Platform_tmhour(), Platform_tmmin(), Platform_tmsec(), &*t, &*d);
  348. }
  349. INT16 Platform_Size (INT32 h, INT32 *l)
  350. {
  351. Platform_structstats();
  352. if (Platform_fstat(h) < 0) {
  353. return Platform_err();
  354. }
  355. *l = Platform_statsize();
  356. return 0;
  357. }
  358. INT16 Platform_Read (INT32 h, INT32 p, INT32 l, INT32 *n)
  359. {
  360. *n = Platform_readfile(h, p, l);
  361. if (*n < 0) {
  362. *n = 0;
  363. return Platform_err();
  364. } else {
  365. return 0;
  366. }
  367. __RETCHK;
  368. }
  369. INT16 Platform_ReadBuf (INT32 h, SYSTEM_BYTE *b, ADDRESS b__len, INT32 *n)
  370. {
  371. *n = Platform_readfile(h, (ADDRESS)b, b__len);
  372. if (*n < 0) {
  373. *n = 0;
  374. return Platform_err();
  375. } else {
  376. return 0;
  377. }
  378. __RETCHK;
  379. }
  380. INT16 Platform_Write (INT32 h, INT32 p, INT32 l)
  381. {
  382. INT32 written;
  383. written = Platform_writefile(h, p, l);
  384. if (written < 0) {
  385. return Platform_err();
  386. } else {
  387. return 0;
  388. }
  389. __RETCHK;
  390. }
  391. INT16 Platform_Sync (INT32 h)
  392. {
  393. if (Platform_fsync(h) < 0) {
  394. return Platform_err();
  395. } else {
  396. return 0;
  397. }
  398. __RETCHK;
  399. }
  400. INT16 Platform_Seek (INT32 h, INT32 offset, INT16 whence)
  401. {
  402. if (Platform_lseek(h, offset, whence) < 0) {
  403. return Platform_err();
  404. } else {
  405. return 0;
  406. }
  407. __RETCHK;
  408. }
  409. INT16 Platform_Truncate (INT32 h, INT32 l)
  410. {
  411. if (Platform_ftruncate(h, l) < 0) {
  412. return Platform_err();
  413. } else {
  414. return 0;
  415. }
  416. __RETCHK;
  417. }
  418. INT16 Platform_Unlink (CHAR *n, ADDRESS n__len)
  419. {
  420. if (Platform_unlink(n, n__len) < 0) {
  421. return Platform_err();
  422. } else {
  423. return 0;
  424. }
  425. __RETCHK;
  426. }
  427. INT16 Platform_Chdir (CHAR *n, ADDRESS n__len)
  428. {
  429. INT16 r;
  430. if ((Platform_chdir(n, n__len) >= 0 && Platform_getcwd((void*)Platform_CWD, 256) != NIL)) {
  431. return 0;
  432. } else {
  433. return Platform_err();
  434. }
  435. __RETCHK;
  436. }
  437. INT16 Platform_Rename (CHAR *o, ADDRESS o__len, CHAR *n, ADDRESS n__len)
  438. {
  439. if (Platform_rename(o, o__len, n, n__len) < 0) {
  440. return Platform_err();
  441. } else {
  442. return 0;
  443. }
  444. __RETCHK;
  445. }
  446. void Platform_Exit (INT32 code)
  447. {
  448. Platform_exit(code);
  449. }
  450. static void Platform_TestLittleEndian (void)
  451. {
  452. INT16 i;
  453. i = 1;
  454. __GET((ADDRESS)&i, Platform_LittleEndian, BOOLEAN);
  455. }
  456. __TDESC(Platform_FileIdentity, 1, 0) = {__TDFLDS("FileIdentity", 12), {-4}};
  457. export void *Platform__init(void)
  458. {
  459. __DEFMOD;
  460. __REGMOD("Platform", 0);
  461. __INITYP(Platform_FileIdentity, Platform_FileIdentity, 0);
  462. /* BEGIN */
  463. Platform_TestLittleEndian();
  464. Platform_TimeStart = 0;
  465. Platform_TimeStart = Platform_Time();
  466. Platform_PID = Platform_getpid();
  467. if (Platform_getcwd((void*)Platform_CWD, 256) == NIL) {
  468. Platform_CWD[0] = 0x00;
  469. }
  470. Platform_SeekSet = Platform_seekset();
  471. Platform_SeekCur = Platform_seekcur();
  472. Platform_SeekEnd = Platform_seekend();
  473. Platform_NL[0] = 0x0a;
  474. Platform_NL[1] = 0x00;
  475. __ENDMOD;
  476. }