123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- /*
- Copyright (C) 1997-2024 Sam Lantinga <[email protected]>
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely.
- */
- /* Simple test of filesystem functions. */
- #include <SDL3/SDL.h>
- #include <SDL3/SDL_main.h>
- #include <SDL3/SDL_test.h>
- static int SDLCALL enum_callback(void *userdata, void *reserved, const char *origdir, const char *fname)
- {
- SDL_PathInfo info;
- char *fullpath = NULL;
- /* you can use '/' for a path separator on Windows, but to make the log output look correct, we'll #ifdef this... */
- #ifdef SDL_PLATFORM_WINDOWS
- const char *pathsep = "\\";
- #else
- const char *pathsep = "/";
- #endif
- if (SDL_asprintf(&fullpath, "%s%s%s", origdir, *origdir ? pathsep : "", fname) < 0) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Out of memory!");
- return -1;
- }
- if (SDL_GetPathInfo(fullpath, &info) < 0) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't stat '%s': %s", fullpath, SDL_GetError());
- } else {
- const char *type;
- if (info.type == SDL_PATHTYPE_FILE) {
- type = "FILE";
- } else if (info.type == SDL_PATHTYPE_DIRECTORY) {
- type = "DIRECTORY";
- } else {
- type = "OTHER";
- }
- SDL_Log("%s (type=%s, size=%" SDL_PRIu64 ", create=%" SDL_PRIu64 ", mod=%" SDL_PRIu64 ", access=%" SDL_PRIu64 ")",
- fullpath, type, info.size, info.modify_time, info.create_time, info.access_time);
- if (info.type == SDL_PATHTYPE_DIRECTORY) {
- if (SDL_EnumerateDirectory(fullpath, enum_callback, userdata) < 0) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Enumeration failed!");
- }
- }
- }
- SDL_free(fullpath);
- return 1; /* keep going */
- }
- int main(int argc, char *argv[])
- {
- SDLTest_CommonState *state;
- char *pref_path;
- char *base_path;
- /* Initialize test framework */
- state = SDLTest_CommonCreateState(argv, 0);
- if (!state) {
- return 1;
- }
- /* Enable standard application logging */
- SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
- /* Parse commandline */
- if (!SDLTest_CommonDefaultArgs(state, argc, argv)) {
- return 1;
- }
- if (SDL_Init(0) == -1) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_Init() failed: %s\n", SDL_GetError());
- return 1;
- }
- base_path = SDL_GetBasePath();
- if (!base_path) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't find base path: %s\n",
- SDL_GetError());
- } else {
- SDL_Log("base path: '%s'\n", base_path);
- }
- pref_path = SDL_GetPrefPath("libsdl", "test_filesystem");
- if (!pref_path) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't find pref path: %s\n",
- SDL_GetError());
- } else {
- SDL_Log("pref path: '%s'\n", pref_path);
- SDL_free(pref_path);
- }
- pref_path = SDL_GetPrefPath(NULL, "test_filesystem");
- if (!pref_path) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't find pref path without organization: %s\n",
- SDL_GetError());
- } else {
- SDL_Log("pref path: '%s'\n", pref_path);
- SDL_free(pref_path);
- }
- if (base_path) {
- if (SDL_EnumerateDirectory(base_path, enum_callback, NULL) < 0) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Base path enumeration failed!");
- }
- /* !!! FIXME: put this in a subroutine and make it test more thoroughly (and put it in testautomation). */
- if (SDL_CreateDirectory("testfilesystem-test") == -1) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_CreateDirectory('testfilesystem-test') failed: %s", SDL_GetError());
- } else if (SDL_CreateDirectory("testfilesystem-test/1") == -1) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_CreateDirectory('testfilesystem-test/1') failed: %s", SDL_GetError());
- } else if (SDL_CreateDirectory("testfilesystem-test/1") == -1) { /* THIS SHOULD NOT FAIL! Making a directory that already exists should succeed here. */
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_CreateDirectory('testfilesystem-test/1') failed: %s", SDL_GetError());
- } else if (SDL_RenamePath("testfilesystem-test/1", "testfilesystem-test/2") == -1) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_RenamePath('testfilesystem-test/1', 'testfilesystem-test/2') failed: %s", SDL_GetError());
- } else if (SDL_RemovePath("testfilesystem-test/2") == -1) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_RemovePath('testfilesystem-test/2') failed: %s", SDL_GetError());
- } else if (SDL_RemovePath("testfilesystem-test") == -1) {
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_RemovePath('testfilesystem-test') failed: %s", SDL_GetError());
- } else if (SDL_RemovePath("testfilesystem-test") == -1) { /* THIS SHOULD NOT FAIL! Removing a directory that is already gone should succeed here. */
- SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_RemovePath('testfilesystem-test') failed: %s", SDL_GetError());
- }
- }
- SDL_free(base_path);
- SDL_Quit();
- SDLTest_CommonDestroyState(state);
- return 0;
- }
|