From 52f622b5c3165ab06da8266d586b131518d43afe Mon Sep 17 00:00:00 2001 From: Dominic Masters Date: Fri, 1 Oct 2021 00:27:36 -0700 Subject: [PATCH] Added Unit Tests --- .github/workflows/test.yml | 27 ++ CMakeLists.txt | 10 +- include/rg351/SDL2/_real_SDL_config.h | 451 -------------------------- lib/CMakeLists.txt | 1 - src/poker/card.c | 6 + src/poker/card.h | 10 +- src/poker2/poker.c | 115 +++++++ src/poker2/poker.h | 72 ++++ test/CMakeLists.txt | 6 + test/poker2/card.c | 27 ++ 10 files changed, 271 insertions(+), 454 deletions(-) create mode 100644 .github/workflows/test.yml delete mode 100644 include/rg351/SDL2/_real_SDL_config.h create mode 100644 src/poker2/poker.c create mode 100644 src/poker2/poker.h create mode 100644 test/CMakeLists.txt create mode 100644 test/poker2/card.c diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 00000000..7f28e6c9 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,27 @@ +name: test +on: + pull_request: + branches: [ master ] +jobs: + build: + runs-on: ubuntu-latest + steps: + - name: Checkout 🛎️ + uses: actions/checkout@v2.3.1 + + - name: Setup cmake + uses: jwlawson/actions-setup-cmake@v1.9 + with: + cmake-version: '3.13.x' + + - name: Get Libraries + run: git submodule update --init --recursive + + - name: Build + run: | + cmake -B build -DTARGET_GROUP=test + cmake --build ./build + + - name: Test + run: | + ./build/bin/tests \ No newline at end of file diff --git a/CMakeLists.txt b/CMakeLists.txt index 618a8d16..4af86055 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -11,11 +11,19 @@ project(Dawn VERSION 1.0) set(GAME_NAME DawnGame) set(GAME_VERSION 1.0) +set(TARGET_GROUP test) ##################################### LIBS ##################################### add_subdirectory(lib) add_subdirectory(src) -add_subdirectory(client) + +if(TARGET_GROUP STREQUAL production) + add_subdirectory(client) +elseif(TARGET_GROUP STREQUAL test) + add_subdirectory(test) +else() + message(FATAL_ERROR "Invalid Target Type") +endif() #################################### ASSETS #################################### file(COPY ${CMAKE_CURRENT_LIST_DIR}/assets DESTINATION ${CMAKE_CURRENT_BINARY_DIR}) \ No newline at end of file diff --git a/include/rg351/SDL2/_real_SDL_config.h b/include/rg351/SDL2/_real_SDL_config.h deleted file mode 100644 index a4369890..00000000 --- a/include/rg351/SDL2/_real_SDL_config.h +++ /dev/null @@ -1,451 +0,0 @@ -/* include/SDL_config.h. Generated from SDL_config.h.in by configure. */ -/* - Simple DirectMedia Layer - Copyright (C) 1997-2020 Sam Lantinga - 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, subject to the following restrictions: - 1. The origin of this software must not be misrepresented; you must not - claim that you wrote the original software. If you use this software - in a product, an acknowledgment in the product documentation would be - appreciated but is not required. - 2. Altered source versions must be plainly marked as such, and must not be - misrepresented as being the original software. - 3. This notice may not be removed or altered from any source distribution. -*/ - -#ifndef SDL_config_h_ -#define SDL_config_h_ - -/** - * \file SDL_config.h.in - * - * This is a set of defines to configure the SDL features - */ - -/* General platform specific identifiers */ -#include "SDL_platform.h" - -/* Make sure that this isn't included by Visual C++ */ -#ifdef _MSC_VER -#error You should run hg revert SDL_config.h -#endif - -/* C language features */ -/* #undef const */ -/* #undef inline */ -/* #undef volatile */ - -/* C datatypes */ -#ifdef __LP64__ -#define SIZEOF_VOIDP 8 -#else -#define SIZEOF_VOIDP 4 -#endif -#define HAVE_GCC_ATOMICS 1 -/* #undef HAVE_GCC_SYNC_LOCK_TEST_AND_SET */ - -/* Comment this if you want to build without any C library requirements */ -#define HAVE_LIBC 1 -#if HAVE_LIBC - -/* Useful headers */ -#define STDC_HEADERS 1 -#define HAVE_ALLOCA_H 1 -#define HAVE_CTYPE_H 1 -#define HAVE_FLOAT_H 1 -#define HAVE_ICONV_H 1 -#define HAVE_INTTYPES_H 1 -#define HAVE_LIMITS_H 1 -#define HAVE_MALLOC_H 1 -#define HAVE_MATH_H 1 -#define HAVE_MEMORY_H 1 -#define HAVE_SIGNAL_H 1 -#define HAVE_STDARG_H 1 -#define HAVE_STDINT_H 1 -#define HAVE_STDIO_H 1 -#define HAVE_STDLIB_H 1 -#define HAVE_STRINGS_H 1 -#define HAVE_STRING_H 1 -#define HAVE_SYS_TYPES_H 1 -#define HAVE_WCHAR_H 1 -/* #undef HAVE_PTHREAD_NP_H */ -/* #undef HAVE_LIBUNWIND_H */ - -/* C library functions */ -#define HAVE_MALLOC 1 -#define HAVE_CALLOC 1 -#define HAVE_REALLOC 1 -#define HAVE_FREE 1 -#define HAVE_ALLOCA 1 -#ifndef __WIN32__ /* Don't use C runtime versions of these on Windows */ -#define HAVE_GETENV 1 -#define HAVE_SETENV 1 -#define HAVE_PUTENV 1 -#define HAVE_UNSETENV 1 -#endif -#define HAVE_QSORT 1 -#define HAVE_ABS 1 -#define HAVE_BCOPY 1 -#define HAVE_MEMSET 1 -#define HAVE_MEMCPY 1 -#define HAVE_MEMMOVE 1 -#define HAVE_MEMCMP 1 -#define HAVE_WCSLEN 1 -/* #undef HAVE_WCSLCPY */ -/* #undef HAVE_WCSLCAT */ -#define HAVE_WCSDUP 1 -#define HAVE_WCSSTR 1 -#define HAVE_WCSCMP 1 -#define HAVE_WCSNCMP 1 -#define HAVE_WCSCASECMP 1 -/* #undef HAVE__WCSICMP */ -#define HAVE_WCSNCASECMP 1 -/* #undef HAVE__WCSNICMP */ -#define HAVE_STRLEN 1 -/* #undef HAVE_STRLCPY */ -/* #undef HAVE_STRLCAT */ -/* #undef HAVE__STRREV */ -/* #undef HAVE__STRUPR */ -/* #undef HAVE__STRLWR */ -/* #undef HAVE_INDEX */ -/* #undef HAVE_RINDEX */ -#define HAVE_STRCHR 1 -#define HAVE_STRRCHR 1 -#define HAVE_STRSTR 1 -#define HAVE_STRTOK_R 1 -/* #undef HAVE_STRTOK_S */ -/* #undef HAVE_ITOA */ -/* #undef HAVE__LTOA */ -/* #undef HAVE__UITOA */ -/* #undef HAVE__ULTOA */ -#define HAVE_STRTOL 1 -#define HAVE_STRTOUL 1 -/* #undef HAVE__I64TOA */ -/* #undef HAVE__UI64TOA */ -#define HAVE_STRTOLL 1 -#define HAVE_STRTOULL 1 -#define HAVE_STRTOD 1 -#define HAVE_ATOI 1 -#define HAVE_ATOF 1 -#define HAVE_STRCMP 1 -#define HAVE_STRNCMP 1 -/* #undef HAVE__STRICMP */ -#define HAVE_STRCASECMP 1 -/* #undef HAVE__STRNICMP */ -#define HAVE_STRNCASECMP 1 -/* #undef HAVE_SSCANF */ -#define HAVE_VSSCANF 1 -/* #undef HAVE_SNPRINTF */ -#define HAVE_VSNPRINTF 1 -#define HAVE_M_PI /**/ -#define HAVE_ACOS 1 -#define HAVE_ACOSF 1 -#define HAVE_ASIN 1 -#define HAVE_ASINF 1 -#define HAVE_ATAN 1 -#define HAVE_ATANF 1 -#define HAVE_ATAN2 1 -#define HAVE_ATAN2F 1 -#define HAVE_CEIL 1 -#define HAVE_CEILF 1 -#define HAVE_COPYSIGN 1 -#define HAVE_COPYSIGNF 1 -#define HAVE_COS 1 -#define HAVE_COSF 1 -#define HAVE_EXP 1 -#define HAVE_EXPF 1 -#define HAVE_FABS 1 -#define HAVE_FABSF 1 -#define HAVE_FLOOR 1 -#define HAVE_FLOORF 1 -#define HAVE_FMOD 1 -#define HAVE_FMODF 1 -#define HAVE_LOG 1 -#define HAVE_LOGF 1 -#define HAVE_LOG10 1 -#define HAVE_LOG10F 1 -#define HAVE_LROUND 1 -#define HAVE_LROUNDF 1 -#define HAVE_POW 1 -#define HAVE_POWF 1 -#define HAVE_ROUND 1 -#define HAVE_ROUNDF 1 -#define HAVE_SCALBN 1 -#define HAVE_SCALBNF 1 -#define HAVE_SIN 1 -#define HAVE_SINF 1 -#define HAVE_SQRT 1 -#define HAVE_SQRTF 1 -#define HAVE_TAN 1 -#define HAVE_TANF 1 -#define HAVE_TRUNC 1 -#define HAVE_TRUNCF 1 -#define HAVE_FOPEN64 1 -#define HAVE_FSEEKO 1 -#define HAVE_FSEEKO64 1 -#define HAVE_SIGACTION 1 -#define HAVE_SA_SIGACTION 1 -#define HAVE_SETJMP 1 -#define HAVE_NANOSLEEP 1 -#define HAVE_SYSCONF 1 -/* #undef HAVE_SYSCTLBYNAME */ -#define HAVE_CLOCK_GETTIME 1 -/* #undef HAVE_GETPAGESIZE */ -#define HAVE_MPROTECT 1 -#define HAVE_ICONV 1 -#define HAVE_PTHREAD_SETNAME_NP 1 -/* #undef HAVE_PTHREAD_SET_NAME_NP */ -#define HAVE_SEM_TIMEDWAIT 1 -#define HAVE_GETAUXVAL 1 -/* #undef HAVE_ELF_AUX_INFO */ -#define HAVE_POLL 1 -#define HAVE__EXIT 1 - -#else -#define HAVE_STDARG_H 1 -#define HAVE_STDDEF_H 1 -#define HAVE_STDINT_H 1 -#endif /* HAVE_LIBC */ - -/* #undef HAVE_ALTIVEC_H */ -#define HAVE_DBUS_DBUS_H 1 -#define HAVE_FCITX 1 -#define HAVE_SYS_INOTIFY_H 1 -#define HAVE_INOTIFY_INIT 1 -#define HAVE_INOTIFY_INIT1 1 -#define HAVE_INOTIFY 1 -/* #undef HAVE_IBUS_IBUS_H */ -/* #undef HAVE_IMMINTRIN_H */ -#define HAVE_LIBUDEV_H 1 -/* #undef HAVE_LIBSAMPLERATE_H */ - -/* #undef HAVE_DDRAW_H */ -/* #undef HAVE_DINPUT_H */ -/* #undef HAVE_DSOUND_H */ -/* #undef HAVE_DXGI_H */ -/* #undef HAVE_XINPUT_H */ - -/* #undef HAVE_MMDEVICEAPI_H */ -/* #undef HAVE_AUDIOCLIENT_H */ -/* #undef HAVE_SENSORSAPI_H */ - -/* #undef HAVE_XINPUT_GAMEPAD_EX */ -/* #undef HAVE_XINPUT_STATE_EX */ - -/* SDL internal assertion support */ -/* #undef SDL_DEFAULT_ASSERT_LEVEL */ - -/* Allow disabling of core subsystems */ -/* #undef SDL_ATOMIC_DISABLED */ -/* #undef SDL_AUDIO_DISABLED */ -/* #undef SDL_CPUINFO_DISABLED */ -/* #undef SDL_EVENTS_DISABLED */ -/* #undef SDL_FILE_DISABLED */ -/* #undef SDL_JOYSTICK_DISABLED */ -/* #undef SDL_HAPTIC_DISABLED */ -/* #undef SDL_SENSOR_DISABLED */ -/* #undef SDL_LOADSO_DISABLED */ -/* #undef SDL_RENDER_DISABLED */ -/* #undef SDL_THREADS_DISABLED */ -/* #undef SDL_TIMERS_DISABLED */ -/* #undef SDL_VIDEO_DISABLED */ -/* #undef SDL_POWER_DISABLED */ -/* #undef SDL_FILESYSTEM_DISABLED */ - -/* Enable various audio drivers */ -#define SDL_AUDIO_DRIVER_ALSA 1 -#define SDL_AUDIO_DRIVER_ALSA_DYNAMIC "libasound.so.2" -/* #undef SDL_AUDIO_DRIVER_ANDROID */ -/* #undef SDL_AUDIO_DRIVER_ARTS */ -/* #undef SDL_AUDIO_DRIVER_ARTS_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_COREAUDIO */ -#define SDL_AUDIO_DRIVER_DISK 1 -/* #undef SDL_AUDIO_DRIVER_DSOUND */ -#define SDL_AUDIO_DRIVER_DUMMY 1 -/* #undef SDL_AUDIO_DRIVER_EMSCRIPTEN */ -/* #undef SDL_AUDIO_DRIVER_ESD */ -/* #undef SDL_AUDIO_DRIVER_ESD_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_FUSIONSOUND */ -/* #undef SDL_AUDIO_DRIVER_FUSIONSOUND_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_HAIKU */ -/* #undef SDL_AUDIO_DRIVER_JACK */ -/* #undef SDL_AUDIO_DRIVER_JACK_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_NACL */ -/* #undef SDL_AUDIO_DRIVER_NAS */ -/* #undef SDL_AUDIO_DRIVER_NAS_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_NETBSD */ -#define SDL_AUDIO_DRIVER_OSS 1 -/* #undef SDL_AUDIO_DRIVER_OSS_SOUNDCARD_H */ -/* #undef SDL_AUDIO_DRIVER_PAUDIO */ -/* #undef SDL_AUDIO_DRIVER_PULSEAUDIO */ -/* #undef SDL_AUDIO_DRIVER_PULSEAUDIO_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_QSA */ -/* #undef SDL_AUDIO_DRIVER_SNDIO */ -/* #undef SDL_AUDIO_DRIVER_SNDIO_DYNAMIC */ -/* #undef SDL_AUDIO_DRIVER_SUNAUDIO */ -/* #undef SDL_AUDIO_DRIVER_WASAPI */ -/* #undef SDL_AUDIO_DRIVER_WINMM */ - -/* Enable various input drivers */ -#define SDL_INPUT_LINUXEV 1 -/* #undef SDL_INPUT_FBSDKBIO */ -#define SDL_INPUT_LINUXKD 1 -/* #undef SDL_JOYSTICK_HAIKU */ -/* #undef SDL_JOYSTICK_DINPUT */ -/* #undef SDL_JOYSTICK_XINPUT */ -/* #undef SDL_JOYSTICK_DUMMY */ -/* #undef SDL_JOYSTICK_IOKIT */ -/* #undef SDL_JOYSTICK_MFI */ -#define SDL_JOYSTICK_LINUX 1 -/* #undef SDL_JOYSTICK_ANDROID */ -/* #undef SDL_JOYSTICK_WINMM */ -/* #undef SDL_JOYSTICK_USBHID */ -/* #undef SDL_JOYSTICK_USBHID_MACHINE_JOYSTICK_H */ -#define SDL_JOYSTICK_HIDAPI 1 -/* #undef SDL_JOYSTICK_RAWINPUT */ -/* #undef SDL_JOYSTICK_EMSCRIPTEN */ -#define SDL_JOYSTICK_VIRTUAL 1 -/* #undef SDL_HAPTIC_DUMMY */ -/* #undef SDL_HAPTIC_ANDROID */ -#define SDL_HAPTIC_LINUX 1 -/* #undef SDL_HAPTIC_IOKIT */ -/* #undef SDL_HAPTIC_DINPUT */ -/* #undef SDL_HAPTIC_XINPUT */ - -/* Enable various sensor drivers */ -/* #undef SDL_SENSOR_ANDROID */ -/* #undef SDL_SENSOR_COREMOTION */ -/* #undef SDL_SENSOR_WINDOWS */ -#define SDL_SENSOR_DUMMY 1 - -/* Enable various shared object loading systems */ -#define SDL_LOADSO_DLOPEN 1 -/* #undef SDL_LOADSO_DUMMY */ -/* #undef SDL_LOADSO_LDG */ -/* #undef SDL_LOADSO_WINDOWS */ - -/* Enable various threading systems */ -#define SDL_THREAD_PTHREAD 1 -#define SDL_THREAD_PTHREAD_RECURSIVE_MUTEX 1 -/* #undef SDL_THREAD_PTHREAD_RECURSIVE_MUTEX_NP */ -/* #undef SDL_THREAD_WINDOWS */ - -/* Enable various timer systems */ -/* #undef SDL_TIMER_HAIKU */ -/* #undef SDL_TIMER_DUMMY */ -#define SDL_TIMER_UNIX 1 -/* #undef SDL_TIMER_WINDOWS */ - -/* Enable various video drivers */ -/* #undef SDL_VIDEO_DRIVER_HAIKU */ -/* #undef SDL_VIDEO_DRIVER_COCOA */ -/* #undef SDL_VIDEO_DRIVER_DIRECTFB */ -/* #undef SDL_VIDEO_DRIVER_DIRECTFB_DYNAMIC */ -#define SDL_VIDEO_DRIVER_DUMMY 1 -/* #undef SDL_VIDEO_DRIVER_WINDOWS */ -#define SDL_VIDEO_DRIVER_WAYLAND 1 -#define SDL_VIDEO_DRIVER_WAYLAND_QT_TOUCH 1 -#define SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC "libwayland-client.so.0" -#define SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_EGL "libwayland-egl.so.1" -#define SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_CURSOR "libwayland-cursor.so.0" -#define SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC_XKBCOMMON "libxkbcommon.so.0" -/* #undef SDL_VIDEO_DRIVER_X11 */ -/* #undef SDL_VIDEO_DRIVER_RPI */ -#define SDL_VIDEO_DRIVER_KMSDRM 1 -/* #undef SDL_VIDEO_DRIVER_KMSDRM_DYNAMIC */ -/* #undef SDL_VIDEO_DRIVER_KMSDRM_DYNAMIC_GBM */ -/* #undef SDL_VIDEO_DRIVER_ANDROID */ -/* #undef SDL_VIDEO_DRIVER_EMSCRIPTEN */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XEXT */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XCURSOR */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XINERAMA */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XINPUT2 */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XRANDR */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XSS */ -/* #undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XVIDMODE */ -/* #undef SDL_VIDEO_DRIVER_X11_XCURSOR */ -/* #undef SDL_VIDEO_DRIVER_X11_XDBE */ -/* #undef SDL_VIDEO_DRIVER_X11_XINERAMA */ -/* #undef SDL_VIDEO_DRIVER_X11_XINPUT2 */ -/* #undef SDL_VIDEO_DRIVER_X11_XINPUT2_SUPPORTS_MULTITOUCH */ -/* #undef SDL_VIDEO_DRIVER_X11_XRANDR */ -/* #undef SDL_VIDEO_DRIVER_X11_XSCRNSAVER */ -/* #undef SDL_VIDEO_DRIVER_X11_XSHAPE */ -/* #undef SDL_VIDEO_DRIVER_X11_XVIDMODE */ -/* #undef SDL_VIDEO_DRIVER_X11_SUPPORTS_GENERIC_EVENTS */ -/* #undef SDL_VIDEO_DRIVER_X11_CONST_PARAM_XEXTADDDISPLAY */ -/* #undef SDL_VIDEO_DRIVER_X11_HAS_XKBKEYCODETOKEYSYM */ -/* #undef SDL_VIDEO_DRIVER_NACL */ -/* #undef SDL_VIDEO_DRIVER_VIVANTE */ -/* #undef SDL_VIDEO_DRIVER_VIVANTE_VDK */ -/* #undef SDL_VIDEO_DRIVER_QNX */ - -/* #undef SDL_VIDEO_RENDER_D3D */ -/* #undef SDL_VIDEO_RENDER_D3D11 */ -/* #undef SDL_VIDEO_RENDER_OGL */ -#define SDL_VIDEO_RENDER_OGL_ES 1 -#define SDL_VIDEO_RENDER_OGL_ES2 1 -/* #undef SDL_VIDEO_RENDER_DIRECTFB */ -/* #undef SDL_VIDEO_RENDER_METAL */ - -/* Enable OpenGL support */ -/* #undef SDL_VIDEO_OPENGL */ -#define SDL_VIDEO_OPENGL_ES 1 -#define SDL_VIDEO_OPENGL_ES2 1 -/* #undef SDL_VIDEO_OPENGL_BGL */ -/* #undef SDL_VIDEO_OPENGL_CGL */ -#define SDL_VIDEO_OPENGL_EGL 1 -/* #undef SDL_VIDEO_OPENGL_GLX */ -/* #undef SDL_VIDEO_OPENGL_WGL */ -/* #undef SDL_VIDEO_OPENGL_OSMESA */ -/* #undef SDL_VIDEO_OPENGL_OSMESA_DYNAMIC */ - -/* Enable Vulkan support */ -/* #undef SDL_VIDEO_VULKAN */ - -/* Enable Metal support */ -/* #undef SDL_VIDEO_METAL */ - -/* Enable system power support */ -#define SDL_POWER_LINUX 1 -/* #undef SDL_POWER_WINDOWS */ -/* #undef SDL_POWER_MACOSX */ -/* #undef SDL_POWER_HAIKU */ -/* #undef SDL_POWER_ANDROID */ -/* #undef SDL_POWER_EMSCRIPTEN */ -/* #undef SDL_POWER_HARDWIRED */ - -/* Enable system filesystem support */ -/* #undef SDL_FILESYSTEM_HAIKU */ -/* #undef SDL_FILESYSTEM_COCOA */ -/* #undef SDL_FILESYSTEM_DUMMY */ -#define SDL_FILESYSTEM_UNIX 1 -/* #undef SDL_FILESYSTEM_WINDOWS */ -/* #undef SDL_FILESYSTEM_NACL */ -/* #undef SDL_FILESYSTEM_ANDROID */ -/* #undef SDL_FILESYSTEM_EMSCRIPTEN */ - -/* Enable assembly routines */ -#define SDL_ASSEMBLY_ROUTINES 1 -/* #undef SDL_ALTIVEC_BLITTERS */ -/* #undef SDL_ARM_SIMD_BLITTERS */ -/* #undef SDL_ARM_NEON_BLITTERS */ - -/* Enable ime support */ -#define SDL_USE_IME 1 - -/* Enable dynamic udev support */ -#define SDL_UDEV_DYNAMIC "libudev.so.1" - -/* Enable dynamic libusb support */ -/* #undef SDL_LIBUSB_DYNAMIC */ - -/* Enable dynamic libsamplerate support */ -/* #undef SDL_LIBSAMPLERATE_DYNAMIC */ - -#endif /* SDL_config_h_ */ \ No newline at end of file diff --git a/lib/CMakeLists.txt b/lib/CMakeLists.txt index 081035e3..14746ae4 100644 --- a/lib/CMakeLists.txt +++ b/lib/CMakeLists.txt @@ -9,7 +9,6 @@ add_subdirectory(glfw) add_subdirectory(duktape) add_subdirectory(glad) - # STB file(GLOB_RECURSE STB_SOURCES stb/*.h) add_library(stb INTERFACE) diff --git a/src/poker/card.c b/src/poker/card.c index 021b56fc..adf1b415 100644 --- a/src/poker/card.c +++ b/src/poker/card.c @@ -72,4 +72,10 @@ uint8_t cardCountPairs(card_t *in, uint8_t inCount, uint8_t number, void cardShuffle(card_t *hand, uint8_t length) { arrayShuffle(sizeof(card_t), hand, length); +} + +uint8_t cardWriteDeck(card_t *hand) { + uint8_t i; + for(i = 0; i < CARD_DECK_SIZE; i++) hand[i] = i; + return CARD_DECK_SIZE; } \ No newline at end of file diff --git a/src/poker/card.h b/src/poker/card.h index 1854356f..a9af4808 100644 --- a/src/poker/card.h +++ b/src/poker/card.h @@ -194,4 +194,12 @@ uint8_t cardCountPairs( * @param hand Hand to shuffle. * @param length Length of the hand to shuffle. */ -void cardShuffle(card_t *hand, uint8_t length); \ No newline at end of file +void cardShuffle(card_t *hand, uint8_t length); + +/** + * Write an entire deck of cards (in order) to a given hand. + * + * @param hand Hand to write the deck to. + * @return The count of cards in the deck. + */ +uint8_t cardWriteDeck(card_t *hand); \ No newline at end of file diff --git a/src/poker2/poker.c b/src/poker2/poker.c new file mode 100644 index 00000000..279d48a9 --- /dev/null +++ b/src/poker2/poker.c @@ -0,0 +1,115 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#include "poker.h" + +void pokerInit(poker2_t *poker) { + pokerResetRound(poker); + poker->playerCount = 0; +} + +void pokerResetRound(poker2_t *poker) { + poker->deckSize = cardWriteDeck(poker->deck); + poker->graveSize = 0; + poker->communitySize = 0; + poker->potCount = 0; + pokerPotAdd(poker); +} + +// Pot functions +uint8_t pokerPotAdd(poker2_t *poker) { + poker2pot_t *pot; + uint8_t i = poker->potCount++; + pot = poker->pots + i; + pot->chips = 0; + pot->playerCount = 0; + return i; +} + +void pokerPotAddPlayer(poker2pot_t *pot, uint8_t playerIndex) { + if(!arrayContains( + sizeof(uint8_t), pot->players, pot->playerCount, &playerIndex + )) return; + pot->players[pot->playerCount++] = playerIndex; +} + +// Dealer Functions +void pokerTurn(poker2_t *poker, uint8_t count) { + uint8_t i; + for(i = 0; i < count; i++) { + cardDeal( + poker->deck, &poker->deckSize, poker->community, &poker->communitySize + ); + } +} + +void pokerBurn(poker2_t *poker, uint8_t count) { + uint8_t i; + for(i = 0; i < count; i++) { + cardDeal(poker->deck, &poker->deckSize, poker->grave, &poker->graveSize); + } +} + + +// Player Functions +uint8_t pokerPlayerAdd(poker2_t *poker) { + poker2player_t *player; + uint8_t i = poker->playerCount++; + player = poker->players + i; + player->cardCount = 0; + player->chips = 0; + player->state = 0x00; + return i; +} + +void pokerPlayerDeal(poker2_t *poker, poker2player_t *player, uint8_t count) { + uint8_t i; + for(i = 0; i < count; i++) { + cardDeal(poker->deck, &poker->deckSize, player->cards, &player->cardCount); + } +} + +void pokerPlayerChipsAdd(poker2player_t *player, int32_t chips) { + player->chips += chips; + if(player->chips > 0) { + flagOff(player->state, POKER_PLAYER_STATE_OUT); + } else { + player->state |= POKER_PLAYER_STATE_OUT; + } +} + +void pokerPlayerDealAll(poker2_t *poker, uint8_t count) { + uint8_t i; + poker2player_t *player; + for(i = 0; i < poker->playerCount; i++) { + player = poker->players + i; + + // Can't deal to a player who is folded or out + if(player->state & (POKER_PLAYER_STATE_FOLDED|POKER_PLAYER_STATE_OUT)) { + continue; + } + + pokerPlayerDeal(poker, player, count); + } +} + +// Betting +void pokerPlayerBetPot( + poker2_t *poker, poker2pot_t *pot, uint8_t playerIndex, int32_t chips +) { + poker2player_t *player; + player = poker->players + playerIndex; + player->chips -= chips; + pot->chips += chips; + pokerPotAddPlayer(pot, playerIndex); +} + +void pokerPlayerBet(poker2_t *poker, uint8_t playerIndex, int32_t chips) { + pokerPlayerBetPot( + poker, poker->pots + (poker->potCount - 1), playerIndex, chips + ); +} \ No newline at end of file diff --git a/src/poker2/poker.h b/src/poker2/poker.h new file mode 100644 index 00000000..b81fb668 --- /dev/null +++ b/src/poker2/poker.h @@ -0,0 +1,72 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#pragma once +#include "../libs.h" +#include "../util/flags.h" +#include "../util/array.h" +#include "../poker/card.h" + +#define POKER_PLAYER_COUNT_MAX 5 +#define POKER_PLAYER_HAND_SIZE_MAX 2 +#define POKER_PLAYER_STATE_FOLDED flagDefine(0) +#define POKER_PLAYER_STATE_OUT flagDefine(1) + +#define POKER_GRAVE_SIZE_MAX CARD_DECK_SIZE + +#define POKER_COMMUNITY_SIZE_MAX 5 +#define POKER_POT_COUNT_MAX POKER_PLAYER_COUNT_MAX + +typedef struct { + int32_t chips; + card_t cards[POKER_PLAYER_HAND_SIZE_MAX]; + uint8_t cardCount; + uint8_t state; +} poker2player_t; + +typedef struct { + int32_t chips; + uint8_t players[POKER_PLAYER_COUNT_MAX]; + uint8_t playerCount; +} poker2pot_t; + +typedef struct { + card_t deck[CARD_DECK_SIZE]; + uint8_t deckSize; + + card_t grave[POKER_GRAVE_SIZE_MAX]; + uint8_t graveSize; + + card_t community[POKER_COMMUNITY_SIZE_MAX]; + uint8_t communitySize; + + poker2pot_t pots[POKER_POT_COUNT_MAX]; + uint8_t potCount; + + poker2player_t players[POKER_PLAYER_COUNT_MAX]; + uint8_t playerCount; +} poker2_t; + + + + + + + +void pokerInit(poker2_t *poker); +void pokerResetRound(poker2_t *poker); +uint8_t pokerPotAdd(poker2_t *poker); +void pokerPotAddPlayer(poker2pot_t *pot, uint8_t playerIndex); +void pokerTurn(poker2_t *poker, uint8_t count); +void pokerBurn(poker2_t *poker, uint8_t count); +uint8_t pokerPlayerAdd(poker2_t *poker); +void pokerPlayerDeal(poker2_t *poker, poker2player_t *player, uint8_t count); +void pokerPlayerChipsAdd(poker2player_t *player, int32_t chips); +void pokerPlayerDealAll(poker2_t *poker, uint8_t count); +void pokerPlayerBetPot( + poker2_t *poker, poker2pot_t *pot, uint8_t playerIndex, int32_t chips +); \ No newline at end of file diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt new file mode 100644 index 00000000..60915a83 --- /dev/null +++ b/test/CMakeLists.txt @@ -0,0 +1,6 @@ +file(GLOB_RECURSE SRCS ${CMAKE_CURRENT_SOURCE_DIR}/*.c) + +add_executable(tests ${SRCS}) +target_link_libraries(tests game unity) + +add_test(card tests) \ No newline at end of file diff --git a/test/poker2/card.c b/test/poker2/card.c new file mode 100644 index 00000000..aac23502 --- /dev/null +++ b/test/poker2/card.c @@ -0,0 +1,27 @@ +/** + * Copyright (c) 2021 Dominic Masters + * + * This software is released under the MIT License. + * https://opensource.org/licenses/MIT + */ + +#include +#include + +void setUp(void) { +} + +void tearDown(void) { +} + +void test_add_should_AddNumbersTogether(void) { + TEST_ASSERT_EQUAL_INT32(32, 16+16); +} + +int main() { + UNITY_BEGIN(); + + RUN_TEST(test_add_should_AddNumbersTogether); + + return UNITY_END(); +} \ No newline at end of file