Standard setup for writing C inspired by Casey Muratori, Ryan Fleury, Mr. 4th Programmer, and others in the handmade community.
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 
 
 

93 wiersze
3.1 KiB

  1. #ifndef OS_IMPL_WIN32_CPP
  2. #define OS_IMPL_WIN32_CPP
  3. #include "Windows.h"
  4. #include "os.h"
  5. void *os_alloc(size_t commitSize) {
  6. return VirtualAlloc(NULL, commitSize, MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE);
  7. }
  8. void os_reserve(void *ptr) {
  9. }
  10. void os_decommit(void *ptr) {
  11. }
  12. void os_free(void *ptr, size_t size) {
  13. VirtualFree(ptr, NULL, MEM_RELEASE);
  14. }
  15. string os_readEntireFile(Arena *arena, string filename) {
  16. string result = {0};
  17. HANDLE fileHandle = CreateFileA(cstring(arena, filename), GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, NULL, NULL);
  18. if (fileHandle != INVALID_HANDLE_VALUE) {
  19. LARGE_INTEGER fileSize;
  20. if (GetFileSizeEx(fileHandle, &fileSize)) {
  21. string readfile = PushString(arena, (size_t)fileSize.QuadPart);
  22. if (readfile.str) {
  23. DWORD bytesRead;
  24. if (ReadFile(fileHandle, readfile.str, (DWORD)fileSize.QuadPart, &bytesRead, NULL) && (fileSize.QuadPart == bytesRead)) {
  25. result = readfile;
  26. }
  27. }
  28. }
  29. CloseHandle(fileHandle);
  30. }
  31. return result;
  32. }
  33. bool os_writeEntireFile(Arena *arena, string filename, const byte *contents, size_t contentsLength) {
  34. bool result = false;
  35. HANDLE fileHandle = CreateFileA(cstring(arena, filename), GENERIC_WRITE, FILE_SHARE_READ, NULL, CREATE_ALWAYS, NULL, NULL);
  36. if (fileHandle != INVALID_HANDLE_VALUE) {
  37. DWORD bytesWritten;
  38. if (WriteFile(fileHandle, contents, (DWORD)contentsLength, &bytesWritten, NULL)) {
  39. // file written successfully
  40. result = bytesWritten == contentsLength;
  41. }
  42. CloseHandle(fileHandle);
  43. }
  44. return result;
  45. }
  46. bool os_fileAppend(Arena *arena, string filename, const byte *contents, size_t contentsLength) {
  47. bool result = false;
  48. HANDLE fileHandle = CreateFileA(cstring(arena, filename), FILE_APPEND_DATA | FILE_GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
  49. if (fileHandle != INVALID_HANDLE_VALUE) {
  50. DWORD bytesWritten;
  51. DWORD position = SetFilePointer(fileHandle, 0, NULL, FILE_END);
  52. if (WriteFile(fileHandle, contents, (DWORD)contentsLength, &bytesWritten, NULL)) {
  53. // file written successfully
  54. result = bytesWritten == contentsLength;
  55. }
  56. CloseHandle(fileHandle);
  57. }
  58. return result;
  59. }
  60. function void os_log(LogTarget target, const char *fmt, va_list argList) {
  61. Scratch scratch = scratchStart(0, 0);
  62. string result = strPrintfv(scratch.arena, fmt, argList);
  63. DWORD done;
  64. HANDLE stdHandle;
  65. switch (target) {
  66. case LogTarget_stdin:
  67. stdHandle = GetStdHandle(STD_INPUT_HANDLE);
  68. break;
  69. case LogTarget_stdout:
  70. stdHandle = GetStdHandle(STD_ERROR_HANDLE);
  71. break;
  72. case LogTarget_stderr:
  73. stdHandle = GetStdHandle(STD_OUTPUT_HANDLE);
  74. break;
  75. default:
  76. stdHandle = GetStdHandle(STD_OUTPUT_HANDLE);
  77. break;
  78. }
  79. WriteFile(stdHandle, result.str, (DWORD)result.length, &done, 0);
  80. scratchEnd(scratch);
  81. }
  82. #endif