Linux.未打印到文件

Linux. Not printing to file

本文关键字:文件 打印 Linux      更新时间:2023-10-16

我只是HLDS服务器扩展元模块的编码模块。我编写了一个简单的实用程序函数,用于以%LOGNAME%_%DATE%.log格式编写日志在windows中,该函数运行良好,但在linux中,它创建文件,但什么也不写。首先,我试图搜索有关这方面的信息,但我没有找到解决方案。我试图取消文件句柄,将缓冲区设置为_IONBF模式,但没有任何帮助。非常感谢你读到这篇文章并帮助我解决这个问题。

void UTIL_LogToFile(char* szFileName, const char *fmt, ...)
{
va_list     argptr;
va_start ( argptr, fmt );
vsnprintf ( g_szLogString, sizeof(g_szLogString), fmt, argptr );
va_end   ( argptr );
char* szFilePath = new char[strlen(GlobalVariables::g_szDLLDirPath) + 12 + 30 + 1];
char* szLogFile = get_timestring("_%Y%m%d.log");
sprintf(szFilePath, "%slogs/%s%s", (GlobalVariables::g_szDLLDirPath), szFileName, szLogFile);
FILE* hFile = fopen(szFilePath, "a+");
delete[] szFilePath;
delete[] szLogFile;
if(hFile == NULL)
{
    char szError[256];
    sprintf(szError, "Error fopen: %sn", strerror(errno));
    SERVER_PRINT(szError);
    clearerr(hFile);
    return;
}
fprintf(hFile, g_szLogString);
if(ferror(hFile))
{
    char szError[256];
    sprintf(szError, "Error fprintf: %sn", strerror(errno));
    SERVER_PRINT(szError);
    clearerr(hFile);
    return;
}
fclose(hFile);
}

如果且仅当上一个函数失败,则应仅检查errno

如果上一次调用没有失败,则errno的值为未定义

因此,要正确检查错误,您必须首先检查fopen调用是否返回空指针:

FILE* hFile = fopen(szFilePath, "a+");
if (hFile == nullptr)
{
    perror(szFilePath);
    return;
}

其他函数出现错误:更改的源代码:https://github.com/In-line/metamod_unprecacher/commit/08b2fabd03f838bee62913b0d2a4f4a4bbf1e6df