aboutsummaryrefslogtreecommitdiff
path: root/thirdparty/fmt/test/util.h
diff options
context:
space:
mode:
authorStefan Boberg <[email protected]>2025-11-07 14:49:13 +0100
committerGitHub Enterprise <[email protected]>2025-11-07 14:49:13 +0100
commit24e43a913f29ac3b314354e8ce5175f135bcc64f (patch)
treeca442937ceeb63461012b33a4576e9835099f106 /thirdparty/fmt/test/util.h
parentget oplog attachments (#622) (diff)
downloadzen-24e43a913f29ac3b314354e8ce5175f135bcc64f.tar.xz
zen-24e43a913f29ac3b314354e8ce5175f135bcc64f.zip
switch to xmake for package management (#611)
This change removes our dependency on vcpkg for package management, in favour of bringing some code in-tree in the `thirdparty` folder as well as using the xmake build-in package management feature. For the latter, all the package definitions are maintained in the zen repo itself, in the `repo` folder. It should now also be easier to build the project as it will no longer depend on having the right version of vcpkg installed, which has been a common problem for new people coming in to the codebase. Now you should only need xmake to build. * Bumps xmake requirement on github runners to 2.9.9 to resolve an issue where xmake on Windows invokes cmake with `v144` toolchain which does not exist * BLAKE3 is now in-tree at `thirdparty/blake3` * cpr is now in-tree at `thirdparty/cpr` * cxxopts is now in-tree at `thirdparty/cxxopts` * fmt is now in-tree at `thirdparty/fmt` * robin-map is now in-tree at `thirdparty/robin-map` * ryml is now in-tree at `thirdparty/ryml` * sol2 is now in-tree at `thirdparty/sol2` * spdlog is now in-tree at `thirdparty/spdlog` * utfcpp is now in-tree at `thirdparty/utfcpp` * xmake package repo definitions is in `repo` * implemented support for sanitizers. ASAN is supported on windows, TSAN, UBSAN, MSAN etc are supported on Linux/MacOS though I have not yet tested it extensively on MacOS * the zencore encryption implementation also now supports using mbedTLS which is used on MacOS, though for now we still use openssl on Linux * crashpad * bumps libcurl to 8.11.0 (from 8.8.0) which should address a rare build upload bug
Diffstat (limited to 'thirdparty/fmt/test/util.h')
-rw-r--r--thirdparty/fmt/test/util.h72
1 files changed, 72 insertions, 0 deletions
diff --git a/thirdparty/fmt/test/util.h b/thirdparty/fmt/test/util.h
new file mode 100644
index 000000000..1f2916a9d
--- /dev/null
+++ b/thirdparty/fmt/test/util.h
@@ -0,0 +1,72 @@
+// Formatting library for C++ - test utilities
+//
+// Copyright (c) 2012 - present, Victor Zverovich
+// All rights reserved.
+//
+// For the license information refer to format.h.
+
+#include <cstdarg>
+#include <cstdio>
+#include <locale>
+#include <string>
+
+#include "fmt/os.h"
+
+#ifdef _MSC_VER
+# define FMT_VSNPRINTF vsprintf_s
+#else
+# define FMT_VSNPRINTF vsnprintf
+#endif
+
+template <size_t SIZE>
+void safe_sprintf(char (&buffer)[SIZE], const char* format, ...) {
+ std::va_list args;
+ va_start(args, format);
+ FMT_VSNPRINTF(buffer, SIZE, format, args);
+ va_end(args);
+}
+
+extern const char* const file_content;
+
+// Opens a buffered file for reading.
+auto open_buffered_file(FILE** fp = nullptr) -> fmt::buffered_file;
+
+template <typename Char> class basic_test_string {
+ private:
+ std::basic_string<Char> value_;
+
+ static const Char empty[];
+
+ public:
+ explicit basic_test_string(const Char* value = empty) : value_(value) {}
+
+ auto value() const -> const std::basic_string<Char>& { return value_; }
+};
+
+template <typename Char> const Char basic_test_string<Char>::empty[] = {0};
+
+using test_string = basic_test_string<char>;
+using test_wstring = basic_test_string<wchar_t>;
+
+template <typename Char>
+auto operator<<(std::basic_ostream<Char>& os, const basic_test_string<Char>& s)
+ -> std::basic_ostream<Char>& {
+ os << s.value();
+ return os;
+}
+
+class date {
+ int year_, month_, day_;
+
+ public:
+ date(int year, int month, int day) : year_(year), month_(month), day_(day) {}
+
+ auto year() const -> int { return year_; }
+ auto month() const -> int { return month_; }
+ auto day() const -> int { return day_; }
+};
+
+// Returns a locale with the given name if available or classic locale
+// otherwise.
+auto get_locale(const char* name, const char* alt_name = nullptr)
+ -> std::locale;