2018-03-04 20:16:51 +03:00
|
|
|
// Formatting library for C++ - test utilities
|
|
|
|
//
|
|
|
|
// Copyright (c) 2012 - present, Victor Zverovich
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// For the license information refer to format.h.
|
2014-06-06 17:38:37 +04:00
|
|
|
|
2014-07-29 18:50:05 +04:00
|
|
|
#include <cstdarg>
|
|
|
|
#include <cstdio>
|
2021-05-24 17:23:56 +03:00
|
|
|
#include <locale>
|
2014-09-05 19:44:41 +04:00
|
|
|
#include <string>
|
2014-07-29 18:50:05 +04:00
|
|
|
|
2023-05-03 17:56:24 +03:00
|
|
|
#include "fmt/os.h"
|
2015-06-24 19:16:03 +03:00
|
|
|
|
2014-07-29 18:50:05 +04:00
|
|
|
#ifdef _MSC_VER
|
2019-01-13 05:27:38 +03:00
|
|
|
# define FMT_VSNPRINTF vsprintf_s
|
2014-07-29 18:50:05 +04:00
|
|
|
#else
|
2019-01-13 05:27:38 +03:00
|
|
|
# define FMT_VSNPRINTF vsnprintf
|
2014-07-29 18:50:05 +04:00
|
|
|
#endif
|
|
|
|
|
2020-05-08 01:59:46 +03:00
|
|
|
template <size_t SIZE>
|
2019-01-13 05:27:38 +03:00
|
|
|
void safe_sprintf(char (&buffer)[SIZE], const char* format, ...) {
|
2014-07-29 18:50:05 +04:00
|
|
|
std::va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
FMT_VSNPRINTF(buffer, SIZE, format, args);
|
|
|
|
va_end(args);
|
|
|
|
}
|
2014-06-10 17:21:41 +04:00
|
|
|
|
2021-05-06 03:43:06 +03:00
|
|
|
extern const char* const file_content;
|
2015-06-24 19:16:03 +03:00
|
|
|
|
|
|
|
// Opens a buffered file for reading.
|
2019-05-30 17:01:31 +03:00
|
|
|
fmt::buffered_file open_buffered_file(FILE** fp = nullptr);
|
2015-07-08 18:04:32 +03:00
|
|
|
|
2019-01-13 05:27:38 +03:00
|
|
|
inline FILE* safe_fopen(const char* filename, const char* mode) {
|
2015-07-08 18:04:32 +03:00
|
|
|
#if defined(_WIN32) && !defined(__MINGW32__)
|
|
|
|
// Fix MSVC warning about "unsafe" fopen.
|
2021-07-09 18:05:02 +03:00
|
|
|
FILE* f = nullptr;
|
2015-07-08 18:04:32 +03:00
|
|
|
errno = fopen_s(&f, filename, mode);
|
|
|
|
return f;
|
|
|
|
#else
|
|
|
|
return std::fopen(filename, mode);
|
|
|
|
#endif
|
|
|
|
}
|
2015-09-08 18:36:20 +03:00
|
|
|
|
2021-05-06 03:43:06 +03:00
|
|
|
template <typename Char> class basic_test_string {
|
2015-09-08 18:36:20 +03:00
|
|
|
private:
|
2015-09-19 02:26:41 +03:00
|
|
|
std::basic_string<Char> value_;
|
|
|
|
|
2021-05-06 03:43:06 +03:00
|
|
|
static const Char empty[];
|
2015-09-08 18:36:20 +03:00
|
|
|
|
|
|
|
public:
|
2021-05-06 03:43:06 +03:00
|
|
|
explicit basic_test_string(const Char* value = empty) : value_(value) {}
|
2015-09-08 18:36:20 +03:00
|
|
|
|
2019-01-13 05:27:38 +03:00
|
|
|
const std::basic_string<Char>& value() const { return value_; }
|
2015-09-08 18:36:20 +03:00
|
|
|
};
|
2015-09-19 02:26:41 +03:00
|
|
|
|
2021-05-06 03:43:06 +03:00
|
|
|
template <typename Char> const Char basic_test_string<Char>::empty[] = {0};
|
2015-09-19 02:26:41 +03:00
|
|
|
|
2021-05-06 03:43:06 +03:00
|
|
|
typedef basic_test_string<char> test_string;
|
|
|
|
typedef basic_test_string<wchar_t> test_wstring;
|
2016-05-06 17:37:20 +03:00
|
|
|
|
2016-08-03 18:52:05 +03:00
|
|
|
template <typename Char>
|
2019-01-13 05:27:38 +03:00
|
|
|
std::basic_ostream<Char>& operator<<(std::basic_ostream<Char>& os,
|
2021-05-06 03:43:06 +03:00
|
|
|
const basic_test_string<Char>& s) {
|
2016-08-03 18:52:05 +03:00
|
|
|
os << s.value();
|
|
|
|
return os;
|
|
|
|
}
|
|
|
|
|
2021-05-06 03:43:06 +03:00
|
|
|
class date {
|
2016-05-06 17:37:20 +03:00
|
|
|
int year_, month_, day_;
|
2019-01-13 05:27:38 +03:00
|
|
|
|
2016-05-06 17:37:20 +03:00
|
|
|
public:
|
2021-05-06 03:43:06 +03:00
|
|
|
date(int year, int month, int day) : year_(year), month_(month), day_(day) {}
|
2016-05-06 17:37:20 +03:00
|
|
|
|
|
|
|
int year() const { return year_; }
|
|
|
|
int month() const { return month_; }
|
|
|
|
int day() const { return day_; }
|
|
|
|
};
|
2021-05-24 17:23:56 +03:00
|
|
|
|
2023-02-22 02:14:41 +03:00
|
|
|
// Returns a locale with the given name if available or classic locale otherwise.
|
2021-05-24 22:22:52 +03:00
|
|
|
std::locale get_locale(const char* name, const char* alt_name = nullptr);
|