Mercurial > wgsdk
view src/dirtools.c @ 10:42ac054c0231
*: huge refactoring
dirtools now uses wchar (wayyy overdue)
the timer doesn't have a stupid design anymore
we don't use windows.h at all now
...
author | Paper <paper@paper.us.eu.org> |
---|---|
date | Sun, 11 Feb 2024 19:43:31 -0500 |
parents | be4835547dd0 |
children | e6a594f16403 |
line wrap: on
line source
/** * dirtools.c: * * Useful tools for manipulating directory names, * or pretty much anything involving directories. **/ #include <stdio.h> #include <stdlib.h> #include <string.h> #ifndef WIN32_LEAN_AND_MEAN # define WIN32_LEAN_AND_MEAN #endif #include <windows.h> #include "dirtools.h" /* these are aids and should be converted to wchar */ static int dirtools_directory_exists(LPCWSTR restrict path) { DWORD attrib = GetFileAttributesW(path); return (attrib != INVALID_FILE_ATTRIBUTES && (attrib & FILE_ATTRIBUTE_DIRECTORY)); } int dirtools_create_directory(LPCWSTR restrict path) { size_t len = wcslen(path); WCHAR tmp[len + 1]; memset(tmp, '\0', (len + 1) * sizeof(WCHAR)); for (size_t i = 0; i < len; i++) { if (path[i] != L'\\') continue; wcsncpy(tmp, path, i); if (dirtools_directory_exists(tmp)) continue; if (!CreateDirectoryW(tmp, NULL)) if (GetLastError() == ERROR_PATH_NOT_FOUND) return 1; } if (!dirtools_directory_exists(path) && !CreateDirectoryW(path, NULL)) if (GetLastError() == ERROR_PATH_NOT_FOUND) return 1; return 0; } LPWSTR dirtools_concat_paths(LPCWSTR restrict a, LPCWSTR restrict b) { if (a[0] == L'\0' || b[0] == L'\0') return NULL; const size_t a_len = wcslen(a); const size_t b_len = wcslen(b); const int add_backslash = (a[a_len] != L'\\' && b[0] != L'\\'); LPWSTR out = calloc(a_len + b_len + 1 + add_backslash, sizeof(WCHAR)); if (out == NULL) return out; wcscpy(out, a); if (add_backslash) wcscat(out, L"\\"); wcscat(out, b); return out; }