Странное
А вот почему ни в одном имеющемся под руками языке программирования нет функции "компилятор сам подставляет в вызов логгера имя функции, из которой его вызвали"?
Я понимаю, в log4net я могу подключить вывод фреймов стека, прямо в конфиге, но они достаточно знатно все тормозят в рантайме, а так бы на этапе компиляции подставлять имена функций в виде строковых констант.
В препроцессорах C и C++ есть __LINE__ и __FILE__, а больше я ничего подходящего вроде и не видел.
Я понимаю, в log4net я могу подключить вывод фреймов стека, прямо в конфиге, но они достаточно знатно все тормозят в рантайме, а так бы на этапе компиляции подставлять имена функций в виде строковых констант.
В препроцессорах C и C++ есть __LINE__ и __FILE__, а больше я ничего подходящего вроде и не видел.
no subject
(no subject)
(no subject)
no subject
no subject
В зависимости от компилятора.
no subject
no subject
Уж на что в дотнете это просто делается, да и то бывает лениво. Последнее время компилирую всё с отладочной информацией, консольный вывод перенаправляю в файл. Вот и лог нахаляву.
no subject
(no subject)
(no subject)
(no subject)
no subject
Стандартный logging не умеет, но http://packages.python.org/Logbook/ вроде бы умеет
no subject
(Anonymous) 2012-08-28 11:42 am (UTC)(link)http://msdn.microsoft.com/en-us/library/hh534540.aspx
(no subject)
(no subject)
no subject
если приспичит экономить полпроцента "тормозов", ну сделайте свой препроцессор
no subject
no subject
if {$debugMode == 1} {puts [info level 0]}
no subject
var caller = currentThread.Reflection.GetStack().GetItem(1);
log(caller.FunctionName + " " + caller.LineNumber);
(no subject)
(no subject)
(no subject)
(no subject)
(no subject)
(no subject)
no subject
Но я это использую только в одном месте: специально написанные функции типа warn и assert в модуле диагностики.
no subject
no subject
no subject
(no subject)
(no subject)
(no subject)
(no subject)
no subject
что в студии, что в gcc
для log4cxx элементарно делается дефайн который сам вставляет имя функции
no subject
(no subject)
no subject
#define sd_journal_print(priority, ...) sd_journal_print_with_location(priority, "CODE_FILE=" __FILE__, "CODE_LINE=" _sd_STRINGIFY(__LINE__), __func__, __VA_ARGS__)
А ещё она сама добавляет: PID, UID, GID, CMDLINE, REALTIME_TIMESTAMP, MONOTONIC_TIMESTAMP, HOSTNAME и некоторые другие, менее важные параметры.