fmt/test/util.h

86 lines
2.1 KiB
C
Raw Normal View History

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.
#include <cstdarg>
#include <cstdio>
#include <locale>
#include <string>
2021-07-17 19:16:49 +03:00
#ifdef FMT_MODULE_TEST
import fmt;
#else
2019-12-16 01:51:37 +03:00
#include "fmt/os.h"
2021-07-17 19:16:49 +03:00
#endif // FMT_MODULE_TEST
#ifdef _MSC_VER
2019-01-13 05:27:38 +03:00
# define FMT_VSNPRINTF vsprintf_s
#else
2019-01-13 05:27:38 +03:00
# define FMT_VSNPRINTF vsnprintf
#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, ...) {
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;
// Opens a buffered file for reading.
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.
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
}
2021-05-06 03:43:06 +03:00
template <typename Char> class basic_test_string {
private:
std::basic_string<Char> value_;
2021-05-06 03:43:06 +03:00
static const Char empty[];
public:
2021-05-06 03:43:06 +03:00
explicit basic_test_string(const Char* value = empty) : value_(value) {}
2019-01-13 05:27:38 +03:00
const std::basic_string<Char>& value() const { return value_; }
};
2021-05-06 03:43:06 +03:00
template <typename Char> const Char basic_test_string<Char>::empty[] = {0};
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_; }
};
// Returns a locale with the given name if available or classic locale othewise.
std::locale get_locale(const char* name, const char* alt_name = nullptr);