dqn: Forward Dqn_String8 implementation to Dqn_CString8

This commit is contained in:
doyle 2022-10-15 17:12:13 +11:00
parent bfda589b2c
commit 3cac240aa3
5 changed files with 1178 additions and 827 deletions

View File

@ -28,7 +28,7 @@ pushd Build
if not exist msvc mkdir msvc if not exist msvc mkdir msvc
pushd msvc pushd msvc
cl %compile_flags% %msvc_flags% %code_dir%Dqn_Tests.cpp %link_flags% cl %compile_flags% %msvc_flags% %code_dir%dqn_unit_tests.cpp %link_flags%
popd popd
REM Compiler: clang-cl REM Compiler: clang-cl
@ -40,6 +40,6 @@ pushd Build
if not exist clang mkdir clang if not exist clang mkdir clang
pushd clang pushd clang
clang-cl %compile_flags% %clang_flags% %code_dir%Dqn_Tests.cpp %link_flags% clang-cl %compile_flags% %clang_flags% %code_dir%dqn_unit_tests.cpp %link_flags%
popd popd
popd popd

View File

@ -4,5 +4,5 @@ code_dir=${PWD}
mkdir -p Build mkdir -p Build
pushd Build pushd Build
g++ ${code_dir}/Dqn_Tests.cpp -D DQN_TEST_WITH_MAIN -std=c++17 -o Dqn_UnitTests g++ ${code_dir}/dqn_unit_tests.cpp -D DQN_TEST_WITH_MAIN -std=c++17 -o dqn_unit_tests
popd popd

1476
dqn.h

File diff suppressed because it is too large Load Diff

View File

@ -146,9 +146,9 @@ typedef struct Dqn_Tester {
Dqn_TesterState state; Dqn_TesterState state;
} Dqn_Tester; } Dqn_Tester;
void Dqn_TesterBeginV(Dqn_Tester *test, char const *fmt, va_list args); void Dqn_Tester_BeginV(Dqn_Tester *test, char const *fmt, va_list args);
void Dqn_TesterBegin(Dqn_Tester *test, char const *fmt, ...); void Dqn_Tester_Begin(Dqn_Tester *test, char const *fmt, ...);
void Dqn_TesterEnd(Dqn_Tester *test); void Dqn_Tester_End(Dqn_Tester *test);
#if defined(__cplusplus) #if defined(__cplusplus)
struct Dqn_TesterBeginScopedTest { struct Dqn_TesterBeginScopedTest {
@ -162,11 +162,11 @@ struct Dqn_TesterBeginScopedTest {
// NOTE: Implementation // NOTE: Implementation
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
#if defined(DQN_TESTER_IMPLEMENTATION) #if defined(DQN_TESTER_IMPLEMENTATION)
void Dqn_TesterBeginV(Dqn_Tester *test, char const *fmt, va_list args) void Dqn_Tester_BeginV(Dqn_Tester *test, char const *fmt, va_list args)
{ {
assert(test->state == Dqn_TesterState_Nil && assert(test->state == Dqn_TesterState_Nil &&
"Nesting a unit test within another unit test is not allowed, ensure" "Nesting a unit test within another unit test is not allowed, ensure"
"the first test has finished by calling Dqn_TesterEnd"); "the first test has finished by calling Dqn_Tester_End");
test->num_tests_in_group++; test->num_tests_in_group++;
test->state = Dqn_TesterState_TestBegun; test->state = Dqn_TesterState_TestBegun;
@ -186,17 +186,17 @@ void Dqn_TesterBeginV(Dqn_Tester *test, char const *fmt, va_list args)
putc(DQN_TESTER_RESULT_PAD_CHAR, stdout); putc(DQN_TESTER_RESULT_PAD_CHAR, stdout);
} }
void Dqn_TesterBegin(Dqn_Tester *test, char const *fmt, ...) void Dqn_Tester_Begin(Dqn_Tester *test, char const *fmt, ...)
{ {
va_list args; va_list args;
va_start(args, fmt); va_start(args, fmt);
Dqn_TesterBeginV(test, fmt, args); Dqn_Tester_BeginV(test, fmt, args);
va_end(args); va_end(args);
} }
void Dqn_TesterEnd(Dqn_Tester *test) void Dqn_Tester_End(Dqn_Tester *test)
{ {
assert(test->state != Dqn_TesterState_Nil && "Test was marked as ended but a test was never commenced using Dqn_TesterBegin"); assert(test->state != Dqn_TesterState_Nil && "Test was marked as ended but a test was never commenced using Dqn_Tester_Begin");
if (test->log_count != 0) { if (test->log_count != 0) {
// NOTE: We try and print the result on the same line as the test name, // NOTE: We try and print the result on the same line as the test name,
// but if there were logs printed throughout the test then we must print // but if there were logs printed throughout the test then we must print
@ -227,12 +227,12 @@ Dqn_TesterBeginScopedTest::Dqn_TesterBeginScopedTest(Dqn_Tester *test, char cons
{ {
va_list args; va_list args;
va_start(args, fmt); va_start(args, fmt);
Dqn_TesterBeginV(test, fmt, args); Dqn_Tester_BeginV(test, fmt, args);
va_end(args); va_end(args);
} }
Dqn_TesterBeginScopedTest::~Dqn_TesterBeginScopedTest() { Dqn_TesterBeginScopedTest::~Dqn_TesterBeginScopedTest() {
Dqn_TesterEnd(test); Dqn_Tester_End(test);
} }
#endif // __cplusplus #endif // __cplusplus
#endif // DQN_TESTER_IMPLEMENTATION #endif // DQN_TESTER_IMPLEMENTATION

File diff suppressed because it is too large Load Diff