Use HandleWrapper and initialize variables for FileOutputManager (#986)
This commit is contained in:
parent
27780c28ba
commit
4a09d4795e
|
|
@ -216,6 +216,7 @@
|
|||
<ClCompile Include="debugutil.cpp" />
|
||||
<ClCompile Include="fx_ver.cxx" />
|
||||
<ClCompile Include="GlobalVersionUtility.cpp" />
|
||||
<ClCompile Include="HandleWrapper.cpp" />
|
||||
<ClCompile Include="hostfxr_utility.cpp" />
|
||||
<ClCompile Include="hostfxroptions.cpp" />
|
||||
<ClCompile Include="SRWExclusiveLock.cpp" />
|
||||
|
|
|
|||
|
|
@ -0,0 +1,7 @@
|
|||
// Copyright (c) .NET Foundation. All rights reserved.
|
||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
||||
|
||||
#include "HandleWrapper.h"
|
||||
|
||||
// Workaround for VC++ bug https://developercommunity.visualstudio.com/content/problem/33928/constexpr-failing-on-nullptr-v141-compiler-regress.html
|
||||
const HANDLE InvalidHandleTraits::DefaultHandle = INVALID_HANDLE_VALUE;
|
||||
|
|
@ -12,9 +12,6 @@ struct InvalidHandleTraits
|
|||
static void Close(HANDLE handle) { CloseHandle(handle); }
|
||||
};
|
||||
|
||||
// Workaround for VC++ bug https://developercommunity.visualstudio.com/content/problem/33928/constexpr-failing-on-nullptr-v141-compiler-regress.html
|
||||
const HANDLE InvalidHandleTraits::DefaultHandle = INVALID_HANDLE_VALUE;
|
||||
|
||||
struct NullHandleTraits
|
||||
{
|
||||
using HandleType = HANDLE;
|
||||
|
|
|
|||
|
|
@ -11,6 +11,7 @@
|
|||
#include "EventLog.h"
|
||||
#include "SRWExclusiveLock.h"
|
||||
#include "exceptions.h"
|
||||
#include "LoggingHelpers.h"
|
||||
|
||||
IN_PROCESS_APPLICATION* IN_PROCESS_APPLICATION::s_Application = NULL;
|
||||
|
||||
|
|
|
|||
|
|
@ -7,7 +7,7 @@
|
|||
#include "InProcessApplicationBase.h"
|
||||
#include "inprocesshandler.h"
|
||||
#include "requesthandler_config.h"
|
||||
|
||||
#include "IOutputManager.h"
|
||||
|
||||
typedef REQUEST_NOTIFICATION_STATUS(WINAPI * PFN_REQUEST_HANDLER) (IN_PROCESS_HANDLER* pInProcessHandler, void* pvRequestHandlerContext);
|
||||
typedef BOOL(WINAPI * PFN_SHUTDOWN_HANDLER) (void* pvShutdownHandlerContext);
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@
|
|||
#include "inprocesshandler.h"
|
||||
#include "inprocessapplication.h"
|
||||
#include "aspnetcore_event.h"
|
||||
#include "IOutputManager.h"
|
||||
|
||||
ALLOC_CACHE_HANDLER * IN_PROCESS_HANDLER::sm_pAlloc = NULL;
|
||||
|
||||
|
|
|
|||
|
|
@ -2,12 +2,16 @@
|
|||
// Licensed under the MIT License. See License.txt in the project root for license information.
|
||||
|
||||
#include "stdafx.h"
|
||||
#include "FileOutputManager.h"
|
||||
#include "sttimer.h"
|
||||
#include "utility.h"
|
||||
#include "exceptions.h"
|
||||
#include "debugutil.h"
|
||||
|
||||
FileOutputManager::FileOutputManager()
|
||||
FileOutputManager::FileOutputManager() :
|
||||
m_hLogFileHandle(INVALID_HANDLE_VALUE),
|
||||
m_fdPreviousStdOut(0),
|
||||
m_fdPreviousStdErr(0)
|
||||
{
|
||||
}
|
||||
|
||||
|
|
@ -19,8 +23,6 @@ FileOutputManager::~FileOutputManager()
|
|||
if (m_hLogFileHandle != INVALID_HANDLE_VALUE)
|
||||
{
|
||||
m_Timer.CancelTimer();
|
||||
CloseHandle(m_hLogFileHandle);
|
||||
m_hLogFileHandle = INVALID_HANDLE_VALUE;
|
||||
}
|
||||
|
||||
// delete empty log file
|
||||
|
|
@ -122,6 +124,7 @@ FileOutputManager::Start()
|
|||
RETURN_IF_FAILED(UTILITY::EnsureDirectoryPathExist(struPath.QueryStr()));
|
||||
|
||||
GetSystemTime(&systemTime);
|
||||
|
||||
RETURN_IF_FAILED(
|
||||
m_struLogFilePath.SafeSnwprintf(L"%s_%d%02d%02d%02d%02d%02d_%d.log",
|
||||
struPath.QueryStr(),
|
||||
|
|
|
|||
|
|
@ -4,6 +4,8 @@
|
|||
#pragma once
|
||||
|
||||
#include "sttimer.h"
|
||||
#include "IOutputManager.h"
|
||||
#include "HandleWrapper.h"
|
||||
|
||||
class FileOutputManager : public IOutputManager
|
||||
{
|
||||
|
|
@ -20,7 +22,7 @@ public:
|
|||
virtual void NotifyStartupComplete() override;
|
||||
|
||||
private:
|
||||
HANDLE m_hLogFileHandle;
|
||||
HandleWrapper<InvalidHandleTraits> m_hLogFileHandle;
|
||||
STTIMER m_Timer;
|
||||
STRU m_wsStdOutLogFileName;
|
||||
STRU m_wsApplicationPath;
|
||||
|
|
|
|||
|
|
@ -2,6 +2,11 @@
|
|||
// Licensed under the MIT License. See License.txt in the project root for license information.
|
||||
|
||||
#include "stdafx.h"
|
||||
#include "LoggingHelpers.h"
|
||||
#include "IOutputManager.h"
|
||||
#include "FileOutputManager.h"
|
||||
#include "PipeOutputManager.h"
|
||||
#include "NullOutputManager.h"
|
||||
|
||||
HRESULT
|
||||
LoggingHelpers::CreateLoggingProvider(
|
||||
|
|
|
|||
|
|
@ -3,6 +3,8 @@
|
|||
|
||||
#pragma once
|
||||
|
||||
#include "IOutputManager.h"
|
||||
|
||||
class LoggingHelpers
|
||||
{
|
||||
public:
|
||||
|
|
|
|||
|
|
@ -2,6 +2,7 @@
|
|||
// Licensed under the MIT License. See License.txt in the project root for license information.
|
||||
|
||||
#include "stdafx.h"
|
||||
#include "PipeOutputManager.h"
|
||||
#include "exceptions.h"
|
||||
#include "SRWExclusiveLock.h"
|
||||
|
||||
|
|
|
|||
|
|
@ -3,6 +3,8 @@
|
|||
|
||||
#pragma once
|
||||
|
||||
#include "IOutputManager.h"
|
||||
|
||||
class PipeOutputManager : public IOutputManager
|
||||
{
|
||||
#define PIPE_OUTPUT_THREAD_TIMEOUT 2000
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@
|
|||
#include "stdafx.h"
|
||||
#include "requesthandler_config.h"
|
||||
#include "debugutil.h"
|
||||
#include "environmentvariablehash.h"
|
||||
|
||||
REQUESTHANDLER_CONFIG::~REQUESTHANDLER_CONFIG()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -42,6 +42,7 @@
|
|||
//#define HEX_TO_ASCII(c) ((CHAR)(((c) < 10) ? ((c) + '0') : ((c) + 'a' - 10)))
|
||||
|
||||
#include "stdafx.h"
|
||||
#include "environmentvariablehash.h"
|
||||
|
||||
enum APP_HOSTING_MODEL
|
||||
{
|
||||
|
|
|
|||
|
|
@ -16,6 +16,7 @@
|
|||
|
||||
#include "Shlwapi.h"
|
||||
#include <io.h>
|
||||
|
||||
#include "hashtable.h"
|
||||
#include "stringu.h"
|
||||
#include "stringa.h"
|
||||
|
|
@ -23,10 +24,5 @@
|
|||
#include "dbgutil.h"
|
||||
#include "ahutil.h"
|
||||
#include "hashfn.h"
|
||||
#include "environmentvariablehash.h"
|
||||
#include "IOutputManager.h"
|
||||
#include "FileOutputManager.h"
|
||||
#include "PipeOutputManager.h"
|
||||
#include "NullOutputManager.h"
|
||||
#include "LoggingHelpers.h"
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@
|
|||
|
||||
#include "stdafx.h"
|
||||
#include "gtest/internal/gtest-port.h"
|
||||
#include "FileOutputManager.h"
|
||||
|
||||
class FileManagerWrapper
|
||||
{
|
||||
|
|
|
|||
|
|
@ -3,6 +3,7 @@
|
|||
|
||||
#include "stdafx.h"
|
||||
#include "gtest/internal/gtest-port.h"
|
||||
#include "PipeOutputManager.h"
|
||||
|
||||
class FileManagerWrapper
|
||||
{
|
||||
|
|
|
|||
|
|
@ -58,5 +58,3 @@
|
|||
#include "gtest/gtest.h"
|
||||
#include "fakeclasses.h"
|
||||
|
||||
\
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue