170 похожих чатов

Привет, напомните, как создать вариадик макрос Логгера? типа int a =

5;
const char* b = "fsdfds";
LOG("hello",a,........,myType, b)

И ещё, в конце я енум добавлять должен, типа MessageType::Success

Тоесть в конце:

LOG(a,b,c,d,e,MessageType::Success)

9 ответов

18 просмотров

#define SOMETHING(a, b, ...) something<a>(b, __VA_ARGS__) ?

Павел- Автор вопроса
Arsenii es3n1n
#define SOMETHING(a, b, ...) something<a>(b, __VA_...

namespace LogHelper { template <typename... Args> void PrintErr(Args&&... args) { (std::cerr << RED_TEXT << "[ERROR]" << ... << std::forward<Args>(args)) << RESET_COLOR << std::endl; } template <typename... Args> void PrintWarn(Args&&... args) { (std::cerr << YELLOW_TEXT << "[WARN]" << ... << std::forward<Args>(args)) << RESET_COLOR << std::endl; } template <typename... Args> void PrintSucc(Args&&... args) { (std::cerr << GREEN_TEXT << "[WARN]" << ... << std::forward<Args>(args)) << RESET_COLOR << std::endl; } template <typename... Args> void printLog(Args&&... args) { (std::cout << ... << std::forward<Args>(args)) << std::endl; } } вот так придумал, что думаешь? #define LOG_ERROR(...) LogHelper::PrintErr(__VA__ARGS__) #define LOG_WARN(...) LogHelper::PrintErr(__VA__ARGS__) #define LOG_SUCCESS(...) LogHelper::PrintErr(__VA__ARGS__)

А зачем там макрос с вариадиком? В чем проблема раскрывать макрос в создание логера, у которого будет какой-нибудь оператор <<?

Павел- Автор вопроса
Павел
чтобы можно было на NDEBUG вырубать

это и так можно, но макросом удобнее

Павел
чтобы можно было на NDEBUG вырубать

Так вопрос не в отсутствии макроса

Андрей Будиловский
А зачем там макрос с вариадиком? В чем проблема ра...

Такой оператор в принципе крайне часто критикуется. Лучше делать по образу fmt::format

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
2
Карта сайта