653 lines
43 KiB
HTML
Raw Blame History

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
<meta name="generator" content="Doxygen 1.12.0"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Khaotic Engine Reborn: Logger Class Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<script type="text/javascript" src="clipboard.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="cookie.js"></script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr id="projectrow">
<td id="projectalign">
<div id="projectname">Khaotic Engine Reborn
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.12.0 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
var searchBox = new SearchBox("searchBox", "search/",'.html');
/* @license-end */
</script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() { codefold.init(0); });
/* @license-end */
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function() {
initMenu('',true,false,'search.php','Search',true);
$(function() { init_search(); });
});
/* @license-end */
</script>
<div id="main-nav"></div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */
$(function(){initNavTree('class_logger.html',''); initResizable(true); });
/* @license-end */
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<div id="MSearchResults">
<div class="SRPage">
<div id="SRIndex">
<div id="SRResults"></div>
<div class="SRStatus" id="Loading">Loading...</div>
<div class="SRStatus" id="Searching">Searching...</div>
<div class="SRStatus" id="NoMatches">No Matches</div>
</div>
</div>
</div>
</div>
<div class="header">
<div class="summary">
<a href="#nested-classes">Classes</a> &#124;
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pub-static-methods">Static Public Member Functions</a> &#124;
<a href="#pub-attribs">Public Attributes</a> &#124;
<a href="#pub-static-attribs">Static Public Attributes</a> &#124;
<a href="class_logger-members.html">List of all members</a> </div>
<div class="headertitle"><div class="title">Logger Class Reference</div></div>
</div><!--header-->
<div class="contents">
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a>
Classes</h2></td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="struct_logger_1_1_log_entry.html">LogEntry</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="struct_logger_1_1_log_level_info.html">LogLevelInfo</a></td></tr>
<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-types" name="pub-types"></a>
Public Types</h2></td></tr>
<tr class="memitem:ac744681e23720966b5f430ec2060da36" id="r_ac744681e23720966b5f430ec2060da36"><td class="memItemLeft" align="right" valign="top">enum class &#160;</td><td class="memItemRight" valign="bottom"><b>LogLevel</b> { <br />
&#160;&#160;<b>Info</b>
, <b>Warning</b>
, <b>Error</b>
, <b>Shutdown</b>
, <br />
&#160;&#160;<b>Initialize</b>
, <b>Update</b>
, <b>Render</b>
, <b>Input</b>
, <br />
&#160;&#160;<b>Physics</b>
, <b>Audio</b>
, <b>Network</b>
, <b>Scripting</b>
, <br />
&#160;&#160;<b>AI</b>
, <b>Resource</b>
, <b>Memory</b>
, <b>Debug</b>
, <br />
&#160;&#160;<b>Count</b>
<br />
}</td></tr>
<tr class="separator:ac744681e23720966b5f430ec2060da36"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-methods" name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:a0d21ab21689125fbb5e91584e4f37baa" id="r_a0d21ab21689125fbb5e91584e4f37baa"><td class="memItemLeft" align="right" valign="top"><a id="a0d21ab21689125fbb5e91584e4f37baa" name="a0d21ab21689125fbb5e91584e4f37baa"></a>
&#160;</td><td class="memItemRight" valign="bottom"><b>Logger</b> (<a class="el" href="class_logger.html">Logger</a> const &amp;)=delete</td></tr>
<tr class="separator:a0d21ab21689125fbb5e91584e4f37baa"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae14ecca1071f841760f40b5a1398580c" id="r_ae14ecca1071f841760f40b5a1398580c"><td class="memItemLeft" align="right" valign="top"><a id="ae14ecca1071f841760f40b5a1398580c" name="ae14ecca1071f841760f40b5a1398580c"></a>
void&#160;</td><td class="memItemRight" valign="bottom"><b>operator=</b> (<a class="el" href="class_logger.html">Logger</a> const &amp;)=delete</td></tr>
<tr class="separator:ae14ecca1071f841760f40b5a1398580c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a94f47ba0ef38ea7bcf1056f64d2645e4" id="r_a94f47ba0ef38ea7bcf1056f64d2645e4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a94f47ba0ef38ea7bcf1056f64d2645e4">Log</a> (const std::string &amp;message, const std::string &amp;fileName, int lineNumber, LogLevel level=LogLevel::Info)</td></tr>
<tr class="separator:a94f47ba0ef38ea7bcf1056f64d2645e4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac9b431db882705fe2f33687938874676" id="r_ac9b431db882705fe2f33687938874676"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac9b431db882705fe2f33687938874676">Log</a> (const std::string &amp;message, LogLevel level)</td></tr>
<tr class="separator:ac9b431db882705fe2f33687938874676"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0fc50378d880b648733da39e61fa51e3" id="r_a0fc50378d880b648733da39e61fa51e3"><td class="memItemLeft" align="right" valign="top">const std::deque&lt; <a class="el" href="struct_logger_1_1_log_entry.html">LogEntry</a> &gt; &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0fc50378d880b648733da39e61fa51e3">GetLogBuffer</a> () const</td></tr>
<tr class="separator:a0fc50378d880b648733da39e61fa51e3"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a62b3e15fa3c170e5090a846fd0e9283e" id="r_a62b3e15fa3c170e5090a846fd0e9283e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a62b3e15fa3c170e5090a846fd0e9283e">ManageLogFiles</a> (const std::string &amp;directoryPath)</td></tr>
<tr class="separator:a62b3e15fa3c170e5090a846fd0e9283e"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-static-methods" name="pub-static-methods"></a>
Static Public Member Functions</h2></td></tr>
<tr class="memitem:a08e3e1b899767a6d833136c9fb4f15c2" id="r_a08e3e1b899767a6d833136c9fb4f15c2"><td class="memItemLeft" align="right" valign="top">static <a class="el" href="class_logger.html">Logger</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a08e3e1b899767a6d833136c9fb4f15c2">Get</a> ()</td></tr>
<tr class="separator:a08e3e1b899767a6d833136c9fb4f15c2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a44f087518b3a028018146b07b2bc8e3b" id="r_a44f087518b3a028018146b07b2bc8e3b"><td class="memItemLeft" align="right" valign="top">static const <a class="el" href="struct_logger_1_1_log_level_info.html">LogLevelInfo</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a44f087518b3a028018146b07b2bc8e3b">GetLogLevelInfo</a> (LogLevel level)</td></tr>
<tr class="separator:a44f087518b3a028018146b07b2bc8e3b"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a>
Public Attributes</h2></td></tr>
<tr class="memitem:acf4389b1b0b850181d3674f3527fc1cd" id="r_acf4389b1b0b850181d3674f3527fc1cd"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acf4389b1b0b850181d3674f3527fc1cd">m_disabledLogLevels</a> [LogLevelCount]</td></tr>
<tr class="separator:acf4389b1b0b850181d3674f3527fc1cd"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a72080e328dfb167d4ba1162c2f82811f" id="r_a72080e328dfb167d4ba1162c2f82811f"><td class="memItemLeft" align="right" valign="top">std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a72080e328dfb167d4ba1162c2f82811f">m_logFilePath</a></td></tr>
<tr class="separator:a72080e328dfb167d4ba1162c2f82811f"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-static-attribs" name="pub-static-attribs"></a>
Static Public Attributes</h2></td></tr>
<tr class="memitem:a03b2af65e61167f66d3c68f904206206" id="r_a03b2af65e61167f66d3c68f904206206"><td class="memItemLeft" align="right" valign="top">static constexpr int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a03b2af65e61167f66d3c68f904206206">LogLevelCount</a> = static_cast&lt;int&gt;(LogLevel::Count)</td></tr>
<tr class="separator:a03b2af65e61167f66d3c68f904206206"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00013">13</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
</div><h2 class="groupheader">Member Enumeration Documentation</h2>
<a id="ac744681e23720966b5f430ec2060da36" name="ac744681e23720966b5f430ec2060da36"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac744681e23720966b5f430ec2060da36">&#9670;&#160;</a></span>LogLevel</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">enum class Logger::LogLevel</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">strong</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00026">26</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 27</span> {</div>
<div class="line"><span class="lineno"> 28</span> Info,</div>
<div class="line"><span class="lineno"> 29</span> Warning,</div>
<div class="line"><span class="lineno"> 30</span> Error,</div>
<div class="line"><span class="lineno"> 31</span> Shutdown,</div>
<div class="line"><span class="lineno"> 32</span> Initialize,</div>
<div class="line"><span class="lineno"> 33</span> Update,</div>
<div class="line"><span class="lineno"> 34</span> Render,</div>
<div class="line"><span class="lineno"> 35</span> Input,</div>
<div class="line"><span class="lineno"> 36</span> Physics,</div>
<div class="line"><span class="lineno"> 37</span> Audio,</div>
<div class="line"><span class="lineno"> 38</span> Network,</div>
<div class="line"><span class="lineno"> 39</span> Scripting,</div>
<div class="line"><span class="lineno"> 40</span> AI,</div>
<div class="line"><span class="lineno"> 41</span> Resource,</div>
<div class="line"><span class="lineno"> 42</span> Memory,</div>
<div class="line"><span class="lineno"> 43</span> Debug,</div>
<div class="line"><span class="lineno"> 44</span> Count <span class="comment">// Do not use this, it&#39;s just to get the number of log levels it must at the end</span></div>
<div class="line"><span class="lineno"> 45</span> };</div>
</div><!-- fragment -->
</div>
</div>
<h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
<a id="abc41bfb031d896170c7675fa96a6b30c" name="abc41bfb031d896170c7675fa96a6b30c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#abc41bfb031d896170c7675fa96a6b30c">&#9670;&#160;</a></span>Logger()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">Logger::Logger </td>
<td>(</td>
<td class="paramname"><span class="paramname"><em></em></span></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00087">87</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 88</span> {</div>
<div class="line"><span class="lineno"> 89</span> <span class="keywordtype">char</span>* appdata = <span class="keyword">nullptr</span>;</div>
<div class="line"><span class="lineno"> 90</span> <span class="keywordtype">size_t</span> len;</div>
<div class="line"><span class="lineno"> 91</span> _dupenv_s(&amp;appdata, &amp;len, <span class="stringliteral">&quot;APPDATA&quot;</span>);</div>
<div class="line"><span class="lineno"> 92</span> <span class="keywordflow">if</span> (appdata == <span class="keyword">nullptr</span>)</div>
<div class="line"><span class="lineno"> 93</span> {</div>
<div class="line"><span class="lineno"> 94</span> m_appdataPath = <span class="stringliteral">&quot;log.log&quot;</span>;</div>
<div class="line"><span class="lineno"> 95</span> }</div>
<div class="line"><span class="lineno"> 96</span> <span class="keywordflow">else</span></div>
<div class="line"><span class="lineno"> 97</span> {</div>
<div class="line"><span class="lineno"> 98</span> m_appdataPath = appdata;</div>
<div class="line"><span class="lineno"> 99</span> }</div>
<div class="line"><span class="lineno"> 100</span> free(appdata);</div>
<div class="line"><span class="lineno"> 101</span> std::string directoryPath = m_appdataPath + <span class="stringliteral">&quot;\\Khaotic Engine&quot;</span>;</div>
<div class="line"><span class="lineno"> 102</span> CreateDirectoryA(directoryPath.c_str(), NULL);</div>
<div class="line"><span class="lineno"> 103</span> </div>
<div class="line"><span class="lineno"> 104</span> ManageLogFiles(directoryPath);</div>
<div class="line"><span class="lineno"> 105</span> </div>
<div class="line"><span class="lineno"> 106</span> m_logFilePath = directoryPath + <span class="stringliteral">&quot;\\&quot;</span> + m_logFileName;</div>
<div class="line"><span class="lineno"> 107</span> </div>
<div class="line"><span class="lineno"> 108</span> <span class="comment">// Enable only the Error warning and shutdown log levels</span></div>
<div class="line"><span class="lineno"> 109</span> <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i &lt; LogLevelCount; i++)</div>
<div class="line"><span class="lineno"> 110</span> {</div>
<div class="line"><span class="lineno"> 111</span> m_disabledLogLevels[i] = <span class="keyword">true</span>;</div>
<div class="line"><span class="lineno"> 112</span> </div>
<div class="line"><span class="lineno"> 113</span> <span class="keywordflow">if</span> (i == <span class="keyword">static_cast&lt;</span><span class="keywordtype">int</span><span class="keyword">&gt;</span>(LogLevel::Error) || i == <span class="keyword">static_cast&lt;</span><span class="keywordtype">int</span><span class="keyword">&gt;</span>(LogLevel::Warning) || i == <span class="keyword">static_cast&lt;</span><span class="keywordtype">int</span><span class="keyword">&gt;</span>(LogLevel::Shutdown))</div>
<div class="line"><span class="lineno"> 114</span> {</div>
<div class="line"><span class="lineno"> 115</span> m_disabledLogLevels[i] = <span class="keyword">false</span>;</div>
<div class="line"><span class="lineno"> 116</span> </div>
<div class="line"><span class="lineno"> 117</span> }</div>
<div class="line"><span class="lineno"> 118</span> }</div>
<div class="line"><span class="lineno"> 119</span> </div>
<div class="line"><span class="lineno"> 120</span> }</div>
</div><!-- fragment -->
</div>
</div>
<h2 class="groupheader">Member Function Documentation</h2>
<a id="a08e3e1b899767a6d833136c9fb4f15c2" name="a08e3e1b899767a6d833136c9fb4f15c2"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a08e3e1b899767a6d833136c9fb4f15c2">&#9670;&#160;</a></span>Get()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">static <a class="el" href="class_logger.html">Logger</a> &amp; Logger::Get </td>
<td>(</td>
<td class="paramname"><span class="paramname"><em></em></span></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00017">17</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 18</span> {</div>
<div class="line"><span class="lineno"> 19</span> <span class="keyword">static</span> <a class="code hl_class" href="class_logger.html">Logger</a> instance;</div>
<div class="line"><span class="lineno"> 20</span> <span class="keywordflow">return</span> instance;</div>
<div class="line"><span class="lineno"> 21</span> }</div>
<div class="ttc" id="aclass_logger_html"><div class="ttname"><a href="class_logger.html">Logger</a></div><div class="ttdef"><b>Definition</b> <a href="_logger_8h_source.html#l00013">Logger.h:14</a></div></div>
</div><!-- fragment -->
</div>
</div>
<a id="a0fc50378d880b648733da39e61fa51e3" name="a0fc50378d880b648733da39e61fa51e3"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a0fc50378d880b648733da39e61fa51e3">&#9670;&#160;</a></span>GetLogBuffer()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">const std::deque&lt; <a class="el" href="struct_logger_1_1_log_entry.html">LogEntry</a> &gt; &amp; Logger::GetLogBuffer </td>
<td>(</td>
<td class="paramname"><span class="paramname"><em></em></span></td><td>)</td>
<td> const</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00172">172</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 172</span>{ <span class="keywordflow">return</span> logBuffer; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a44f087518b3a028018146b07b2bc8e3b" name="a44f087518b3a028018146b07b2bc8e3b"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a44f087518b3a028018146b07b2bc8e3b">&#9670;&#160;</a></span>GetLogLevelInfo()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">static const <a class="el" href="struct_logger_1_1_log_level_info.html">LogLevelInfo</a> Logger::GetLogLevelInfo </td>
<td>(</td>
<td class="paramtype">LogLevel</td> <td class="paramname"><span class="paramname"><em>level</em></span></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00063">63</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 64</span> {</div>
<div class="line"><span class="lineno"> 65</span> <span class="keywordflow">switch</span> (level)</div>
<div class="line"><span class="lineno"> 66</span> {</div>
<div class="line"><span class="lineno"> 67</span> <span class="keywordflow">case</span> LogLevel::Info: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Info&quot;</span>, 0, ImVec4(0.0f, 1.0f, 0.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 68</span> <span class="keywordflow">case</span> LogLevel::Warning: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Warning&quot;</span>, 1, ImVec4(1.0f, 1.0f, 0.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 69</span> <span class="keywordflow">case</span> LogLevel::Error: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Error&quot;</span>, 2, ImVec4(1.0f, 0.0f, 0.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 70</span> <span class="keywordflow">case</span> LogLevel::Shutdown: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;shutdown&quot;</span>, 3, ImVec4(0.5f, 0.0f, 0.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 71</span> <span class="keywordflow">case</span> LogLevel::Initialize: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;initialize&quot;</span>, 4, ImVec4(0.0f, 1.0f, 1.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 72</span> <span class="keywordflow">case</span> LogLevel::Update: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Update&quot;</span>, 5, ImVec4(1.0f, 0.0f, 1.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 73</span> <span class="keywordflow">case</span> LogLevel::Render: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;render&quot;</span>, 6, ImVec4(1.0f, 1.0f, 1.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 74</span> <span class="keywordflow">case</span> LogLevel::Input: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Input&quot;</span>, 7, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 75</span> <span class="keywordflow">case</span> LogLevel::Physics: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;physics&quot;</span>, 8, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 76</span> <span class="keywordflow">case</span> LogLevel::Audio: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Audio&quot;</span>, 9, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 77</span> <span class="keywordflow">case</span> LogLevel::Network: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Network&quot;</span>, 10, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 78</span> <span class="keywordflow">case</span> LogLevel::Scripting: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Scripting&quot;</span>, 11, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 79</span> <span class="keywordflow">case</span> LogLevel::AI: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;AI&quot;</span>, 12, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 80</span> <span class="keywordflow">case</span> LogLevel::Resource: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Resource&quot;</span>, 13, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 81</span> <span class="keywordflow">case</span> LogLevel::Memory: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Memory&quot;</span>, 14, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 82</span> <span class="keywordflow">case</span> LogLevel::Debug: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Debug&quot;</span>, 15, ImVec4(0.5f, 0.5f, 0.5f, 1.0f) };</div>
<div class="line"><span class="lineno"> 83</span> <span class="keywordflow">default</span>: <span class="keywordflow">return</span> LogLevelInfo{ <span class="stringliteral">&quot;Unknown&quot;</span>, 16, ImVec4(1.0f, 1.0f, 1.0f, 1.0f) };</div>
<div class="line"><span class="lineno"> 84</span> }</div>
<div class="line"><span class="lineno"> 85</span> }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a94f47ba0ef38ea7bcf1056f64d2645e4" name="a94f47ba0ef38ea7bcf1056f64d2645e4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a94f47ba0ef38ea7bcf1056f64d2645e4">&#9670;&#160;</a></span>Log() <span class="overload">[1/2]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void Logger::Log </td>
<td>(</td>
<td class="paramtype">const std::string &amp;</td> <td class="paramname"><span class="paramname"><em>message</em></span>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const std::string &amp;</td> <td class="paramname"><span class="paramname"><em>fileName</em></span>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>lineNumber</em></span>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">LogLevel</td> <td class="paramname"><span class="paramname"><em>level</em></span><span class="paramdefsep"> = </span><span class="paramdefval">LogLevel::Info</span>&#160;)</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00123">123</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 124</span> {</div>
<div class="line"><span class="lineno"> 125</span> </div>
<div class="line"><span class="lineno"> 126</span> <span class="keyword">auto</span> now = std::chrono::system_clock::now();</div>
<div class="line"><span class="lineno"> 127</span> <span class="keyword">auto</span> in_time_t = std::chrono::system_clock::to_time_t(now);</div>
<div class="line"><span class="lineno"> 128</span> </div>
<div class="line"><span class="lineno"> 129</span> std::tm buf;</div>
<div class="line"><span class="lineno"> 130</span> localtime_s(&amp;buf, &amp;in_time_t);</div>
<div class="line"><span class="lineno"> 131</span> </div>
<div class="line"><span class="lineno"> 132</span> <span class="comment">// Obtenez les millisecondes <20> partir de maintenant</span></div>
<div class="line"><span class="lineno"> 133</span> <span class="keyword">auto</span> ms = std::chrono::duration_cast&lt;std::chrono::milliseconds&gt;(now.time_since_epoch()) % 1000;</div>
<div class="line"><span class="lineno"> 134</span> </div>
<div class="line"><span class="lineno"> 135</span> <span class="comment">// Utilisez LogLevelToString pour obtenir la cha<68>ne de caract<63>res du niveau de log</span></div>
<div class="line"><span class="lineno"> 136</span> std::string levelStr = GetLogLevelInfo(level).name;</div>
<div class="line"><span class="lineno"> 137</span> </div>
<div class="line"><span class="lineno"> 138</span> std::stringstream ss;</div>
<div class="line"><span class="lineno"> 139</span> ss &lt;&lt; <span class="stringliteral">&quot;[&quot;</span> &lt;&lt; std::put_time(&amp;buf, <span class="stringliteral">&quot;%Y-%m-%d&quot;</span>) &lt;&lt; <span class="stringliteral">&quot;] &quot;</span></div>
<div class="line"><span class="lineno"> 140</span> &lt;&lt; <span class="stringliteral">&quot;[&quot;</span> &lt;&lt; std::put_time(&amp;buf, <span class="stringliteral">&quot;%X&quot;</span>) &lt;&lt; <span class="stringliteral">&quot;.&quot;</span> &lt;&lt; std::setfill(<span class="charliteral">&#39;0&#39;</span>) &lt;&lt; std::setw(3) &lt;&lt; ms.count() &lt;&lt; <span class="stringliteral">&quot;] &quot;</span></div>
<div class="line"><span class="lineno"> 141</span> &lt;&lt; <span class="stringliteral">&quot;[&quot;</span> &lt;&lt; levelStr &lt;&lt; <span class="stringliteral">&quot;] &quot;</span></div>
<div class="line"><span class="lineno"> 142</span> &lt;&lt; <span class="stringliteral">&quot;[&quot;</span> &lt;&lt; fileName &lt;&lt; <span class="stringliteral">&quot;:&quot;</span> &lt;&lt; lineNumber &lt;&lt; <span class="stringliteral">&quot;] &quot;</span></div>
<div class="line"><span class="lineno"> 143</span> &lt;&lt; message;</div>
<div class="line"><span class="lineno"> 144</span> </div>
<div class="line"><span class="lineno"> 145</span> Log(ss.str(), level);</div>
<div class="line"><span class="lineno"> 146</span> </div>
<div class="line"><span class="lineno"> 147</span> std::ofstream file(m_logFilePath, std::ios::app);</div>
<div class="line"><span class="lineno"> 148</span> <span class="keywordflow">if</span> (file.is_open())</div>
<div class="line"><span class="lineno"> 149</span> {</div>
<div class="line"><span class="lineno"> 150</span> file &lt;&lt; ss.str() &lt;&lt; std::endl;</div>
<div class="line"><span class="lineno"> 151</span> file.close();</div>
<div class="line"><span class="lineno"> 152</span> }</div>
<div class="line"><span class="lineno"> 153</span> }</div>
</div><!-- fragment -->
</div>
</div>
<a id="ac9b431db882705fe2f33687938874676" name="ac9b431db882705fe2f33687938874676"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac9b431db882705fe2f33687938874676">&#9670;&#160;</a></span>Log() <span class="overload">[2/2]</span></h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void Logger::Log </td>
<td>(</td>
<td class="paramtype">const std::string &amp;</td> <td class="paramname"><span class="paramname"><em>message</em></span>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">LogLevel</td> <td class="paramname"><span class="paramname"><em>level</em></span>&#160;)</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00156">156</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 157</span> {</div>
<div class="line"><span class="lineno"> 158</span> </div>
<div class="line"><span class="lineno"> 159</span> <span class="comment">// Si le niveau de log est d<>sactiv<69>, ne faites rien</span></div>
<div class="line"><span class="lineno"> 160</span> <span class="keywordflow">if</span> (m_disabledLogLevels[GetLogLevelInfo(level).value])</div>
<div class="line"><span class="lineno"> 161</span> {</div>
<div class="line"><span class="lineno"> 162</span> <span class="keywordflow">return</span>;</div>
<div class="line"><span class="lineno"> 163</span> }</div>
<div class="line"><span class="lineno"> 164</span> </div>
<div class="line"><span class="lineno"> 165</span> <span class="keywordflow">if</span> (logBuffer.size() &gt;= logBufferSize)</div>
<div class="line"><span class="lineno"> 166</span> {</div>
<div class="line"><span class="lineno"> 167</span> logBuffer.pop_front();</div>
<div class="line"><span class="lineno"> 168</span> }</div>
<div class="line"><span class="lineno"> 169</span> logBuffer.push_back({ message, level });</div>
<div class="line"><span class="lineno"> 170</span> }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a62b3e15fa3c170e5090a846fd0e9283e" name="a62b3e15fa3c170e5090a846fd0e9283e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a62b3e15fa3c170e5090a846fd0e9283e">&#9670;&#160;</a></span>ManageLogFiles()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void Logger::ManageLogFiles </td>
<td>(</td>
<td class="paramtype">const std::string &amp;</td> <td class="paramname"><span class="paramname"><em>directoryPath</em></span></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00174">174</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
<div class="fragment"><div class="line"><span class="lineno"> 175</span> {</div>
<div class="line"><span class="lineno"> 176</span> std::vector&lt;std::filesystem::path&gt; logFiles;</div>
<div class="line"><span class="lineno"> 177</span> </div>
<div class="line"><span class="lineno"> 178</span> <span class="comment">// Parcourez tous les fichiers dans le dossier</span></div>
<div class="line"><span class="lineno"> 179</span> <span class="keywordflow">for</span> (<span class="keyword">const</span> <span class="keyword">auto</span>&amp; entry : std::filesystem::directory_iterator(directoryPath))</div>
<div class="line"><span class="lineno"> 180</span> {</div>
<div class="line"><span class="lineno"> 181</span> <span class="comment">// Si le fichier est un fichier de log, ajoutez-le <20> la liste</span></div>
<div class="line"><span class="lineno"> 182</span> <span class="keywordflow">if</span> (entry.path().extension() == <span class="stringliteral">&quot;.log&quot;</span>)</div>
<div class="line"><span class="lineno"> 183</span> {</div>
<div class="line"><span class="lineno"> 184</span> logFiles.push_back(entry.path());</div>
<div class="line"><span class="lineno"> 185</span> }</div>
<div class="line"><span class="lineno"> 186</span> }</div>
<div class="line"><span class="lineno"> 187</span> </div>
<div class="line"><span class="lineno"> 188</span> <span class="comment">// Si nous avons plus de trois fichiers de log, supprimez le plus ancien</span></div>
<div class="line"><span class="lineno"> 189</span> <span class="keywordflow">while</span> (logFiles.size() &gt;= 3)</div>
<div class="line"><span class="lineno"> 190</span> {</div>
<div class="line"><span class="lineno"> 191</span> <span class="comment">// Triez les fichiers par date de modification, le plus ancien en premier</span></div>
<div class="line"><span class="lineno"> 192</span> std::sort(logFiles.begin(), logFiles.end(), [](<span class="keyword">const</span> std::filesystem::path&amp; a, <span class="keyword">const</span> std::filesystem::path&amp; b)</div>
<div class="line"><span class="lineno"> 193</span> {</div>
<div class="line"><span class="lineno"> 194</span> return std::filesystem::last_write_time(a) &lt; std::filesystem::last_write_time(b);</div>
<div class="line"><span class="lineno"> 195</span> });</div>
<div class="line"><span class="lineno"> 196</span> </div>
<div class="line"><span class="lineno"> 197</span> <span class="comment">// Supprimez le fichier le plus ancien</span></div>
<div class="line"><span class="lineno"> 198</span> std::filesystem::remove(logFiles[0]);</div>
<div class="line"><span class="lineno"> 199</span> </div>
<div class="line"><span class="lineno"> 200</span> <span class="comment">// Supprimez-le de la liste</span></div>
<div class="line"><span class="lineno"> 201</span> logFiles.erase(logFiles.begin());</div>
<div class="line"><span class="lineno"> 202</span> }</div>
<div class="line"><span class="lineno"> 203</span> </div>
<div class="line"><span class="lineno"> 204</span> <span class="comment">// Cr<43>ez un nouveau fichier de log pour cette ex<65>cution</span></div>
<div class="line"><span class="lineno"> 205</span> <span class="keyword">auto</span> now = std::chrono::system_clock::now();</div>
<div class="line"><span class="lineno"> 206</span> <span class="keyword">auto</span> in_time_t = std::chrono::system_clock::to_time_t(now);</div>
<div class="line"><span class="lineno"> 207</span> std::tm buf;</div>
<div class="line"><span class="lineno"> 208</span> localtime_s(&amp;buf, &amp;in_time_t);</div>
<div class="line"><span class="lineno"> 209</span> </div>
<div class="line"><span class="lineno"> 210</span> std::stringstream ss;</div>
<div class="line"><span class="lineno"> 211</span> ss &lt;&lt; <span class="stringliteral">&quot;Khaotic_log_&quot;</span> &lt;&lt; std::put_time(&amp;buf, <span class="stringliteral">&quot;%Y_%m_%d_%Hh%Mm%Ss&quot;</span>) &lt;&lt; <span class="stringliteral">&quot;.log&quot;</span>;</div>
<div class="line"><span class="lineno"> 212</span> m_logFileName = ss.str();</div>
<div class="line"><span class="lineno"> 213</span> }</div>
</div><!-- fragment -->
</div>
</div>
<h2 class="groupheader">Member Data Documentation</h2>
<a id="a03b2af65e61167f66d3c68f904206206" name="a03b2af65e61167f66d3c68f904206206"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a03b2af65e61167f66d3c68f904206206">&#9670;&#160;</a></span>LogLevelCount</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">int Logger::LogLevelCount = static_cast&lt;int&gt;(LogLevel::Count)</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">static</span><span class="mlabel">constexpr</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00048">48</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
</div>
</div>
<a id="acf4389b1b0b850181d3674f3527fc1cd" name="acf4389b1b0b850181d3674f3527fc1cd"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acf4389b1b0b850181d3674f3527fc1cd">&#9670;&#160;</a></span>m_disabledLogLevels</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool Logger::m_disabledLogLevels[LogLevelCount]</td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00215">215</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
</div>
</div>
<a id="a72080e328dfb167d4ba1162c2f82811f" name="a72080e328dfb167d4ba1162c2f82811f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a72080e328dfb167d4ba1162c2f82811f">&#9670;&#160;</a></span>m_logFilePath</h2>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::string Logger::m_logFilePath</td>
</tr>
</table>
</div><div class="memdoc">
<p class="definition">Definition at line <a class="el" href="_logger_8h_source.html#l00216">216</a> of file <a class="el" href="_logger_8h_source.html">Logger.h</a>.</p>
</div>
</div>
<hr/>The documentation for this class was generated from the following file:<ul>
<li>enginecustom/src/inc/system/<a class="el" href="_logger_8h_source.html">Logger.h</a></li>
</ul>
</div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="class_logger.html">Logger</a></li>
<li class="footer">Generated by <a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.12.0 </li>
</ul>
</div>
</body>
</html>