mirror of
				https://github.com/libsdl-org/SDL.git
				synced 2025-11-04 01:34:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			154 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
  Copyright (C) 1997-2024 Sam Lantinga <slouken@libsdl.org>
 | 
						|
 | 
						|
  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, 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_SetLogPriority(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) {
 | 
						|
        char **globlist;
 | 
						|
 | 
						|
        if (SDL_EnumerateDirectory(base_path, enum_callback, NULL) < 0) {
 | 
						|
            SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Base path enumeration failed!");
 | 
						|
        }
 | 
						|
 | 
						|
        globlist = SDL_GlobDirectory(base_path, "*/test*/T?st*", SDL_GLOB_CASEINSENSITIVE, NULL);
 | 
						|
        if (!globlist) {
 | 
						|
            SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Base path globbing failed!");
 | 
						|
        } else {
 | 
						|
            int i;
 | 
						|
            for (i = 0; globlist[i]; i++) {
 | 
						|
                SDL_Log("GLOB[%d]: '%s'", i, globlist[i]);
 | 
						|
            }
 | 
						|
            SDL_free(globlist);
 | 
						|
        }
 | 
						|
 | 
						|
        /* !!! 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;
 | 
						|
}
 |