in Sources/aliyun-log-c-sdk/inner_log.c [27:70]
void aos_log_format(int level,
const char *file,
int line,
const char *function,
const char *fmt, ...)
{
va_list args;
char buffer[1024];
int maxLen = 1020;
// @note return value maybe < 0 || > maxLen
int len = snprintf(buffer, maxLen, "[%s] [%s][%s:%d] ",
_aos_log_level_str[level],
file, function, line);
// should never happen
if (len < 0 || len > maxLen) {
print_log(AOS_LOG_ERROR, "[aos_log_format] error log fmt\n");
return;
}
va_start(args, fmt);
// @note return value maybe < 0 || > maxLen
int rst = vsnprintf(buffer + len, maxLen - len, fmt, args);
va_end(args);
if (rst < 0) {
print_log(AOS_LOG_ERROR, "[aos_log_format] error log fmt\n");
return;
}
if (rst > maxLen - len) {
rst = maxLen - len;
}
len += rst;
while (len > 0 && buffer[len -1] == '\n')
{
len--;
}
buffer[len++] = '\n';
buffer[len] = '\0';
print_log(level, buffer);
}