Welcome to mirror list, hosted at ThFree Co, Russian Federation.

remmina__log_8c_source.html « public - gitlab.com/Remmina/remminadoc.gitlab.io.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: b9f18369e48464ba9a2b2cbbc7ee08521f69e664 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.13"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Remmina - The GTK+ Remote Desktop Client: remmina_log.c Source File</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>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
  $(document).ready(initResizable);
</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 style="height: 56px;">
  <td id="projectlogo"><img alt="Logo" src="org.remmina.Remmina.png"/></td>
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">Remmina - The GTK+ Remote Desktop Client
   &#160;<span id="projectnumber">v1.4.33</span>
   </div>
   <div id="projectbrief">Remmina is a remote desktop client written in GTK+, aiming to be useful for system administrators and travellers, who need to work with lots of remote computers in front of either large monitors or tiny netbooks. Remmina supports multiple network protocols in an integrated and consistent user interface. Currently RDP, VNC, NX, XDMCP and SSH are supported.</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.13 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
$(function() {
  initMenu('',true,false,'search.php','Search');
  $(document).ready(function() { init_search(); });
});
</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">
$(document).ready(function(){initNavTree('remmina__log_8c_source.html','');});
</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">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<div class="header">
  <div class="headertitle">
<div class="title">remmina_log.c</div>  </div>
</div><!--header-->
<div class="contents">
<a href="remmina__log_8c.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;<span class="comment">/*</span></div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;<span class="comment"> * Remmina - The GTK+ Remote Desktop Client</span></div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;<span class="comment"> * Copyright (C) 2010 Vic Lee</span></div><div class="line"><a name="l00004"></a><span class="lineno">    4</span>&#160;<span class="comment"> * Copyright (C) 2014-2015 Antenore Gatta, Fabio Castelli, Giovanni Panozzo</span></div><div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;<span class="comment"> * Copyright (C) 2016-2023 Antenore Gatta, Giovanni Panozzo</span></div><div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;<span class="comment"> * This program is free software; you can redistribute it and/or modify</span></div><div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;<span class="comment"> * it under the terms of the GNU General Public License as published by</span></div><div class="line"><a name="l00009"></a><span class="lineno">    9</span>&#160;<span class="comment"> * the Free Software Foundation; either version 2 of the License, or</span></div><div class="line"><a name="l00010"></a><span class="lineno">   10</span>&#160;<span class="comment"> * (at your option) any later version.</span></div><div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span class="comment"> * This program is distributed in the hope that it will be useful,</span></div><div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;<span class="comment"> * but WITHOUT ANY WARRANTY; without even the implied warranty of</span></div><div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;<span class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the</span></div><div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span class="comment"> * GNU General Public License for more details.</span></div><div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;<span class="comment"> * You should have received a copy of the GNU General Public License</span></div><div class="line"><a name="l00018"></a><span class="lineno">   18</span>&#160;<span class="comment"> * along with this program; if not, write to the Free Software</span></div><div class="line"><a name="l00019"></a><span class="lineno">   19</span>&#160;<span class="comment"> * Foundation, Inc., 51 Franklin Street, Fifth Floor,</span></div><div class="line"><a name="l00020"></a><span class="lineno">   20</span>&#160;<span class="comment"> * Boston, MA  02110-1301, USA.</span></div><div class="line"><a name="l00021"></a><span class="lineno">   21</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00022"></a><span class="lineno">   22</span>&#160;<span class="comment"> *  In addition, as a special exception, the copyright holders give</span></div><div class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;<span class="comment"> *  permission to link the code of portions of this program with the</span></div><div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span class="comment"> *  OpenSSL library under certain conditions as described in each</span></div><div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;<span class="comment"> *  individual source file, and distribute linked combinations</span></div><div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span class="comment"> *  including the two.</span></div><div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;<span class="comment"> *  You must obey the GNU General Public License in all respects</span></div><div class="line"><a name="l00028"></a><span class="lineno">   28</span>&#160;<span class="comment"> *  for all of the code used other than OpenSSL. *  If you modify</span></div><div class="line"><a name="l00029"></a><span class="lineno">   29</span>&#160;<span class="comment"> *  file(s) with this exception, you may extend this exception to your</span></div><div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="comment"> *  version of the file(s), but you are not obligated to do so. *  If you</span></div><div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;<span class="comment"> *  do not wish to do so, delete this exception statement from your</span></div><div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="comment"> *  version. *  If you delete this exception statement from all source</span></div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="comment"> *  files in the program, then also delete it here.</span></div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="comment"> *</span></div><div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="comment"> */</span></div><div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;</div><div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span class="preprocessor">#include &lt;gtk/gtk.h&gt;</span></div><div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span class="preprocessor">#include &lt;glib/gi18n.h&gt;</span></div><div class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="remmina__public_8h.html">remmina_public.h</a>&quot;</span></div><div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="remmina__pref_8h.html">remmina_pref.h</a>&quot;</span></div><div class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="remmina__log_8h.html">remmina_log.h</a>&quot;</span></div><div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="remmina__stats_8h.html">remmina_stats.h</a>&quot;</span></div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="remmina__trace__calls_8h.html">remmina/remmina_trace_calls.h</a>&quot;</span></div><div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;</div><div class="line"><a name="l00045"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">   45</a></span>&#160;gboolean <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a>;</div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;</div><div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;<span class="comment">/***** Define the log window GUI *****/</span></div><div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;<span class="preprocessor">#define REMMINA_TYPE_LOG_WINDOW               (remmina_log_window_get_type())</span></div><div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;<span class="preprocessor">#define REMMINA_LOG_WINDOW(obj)               (G_TYPE_CHECK_INSTANCE_CAST((obj), REMMINA_TYPE_LOG_WINDOW, RemminaLogWindow))</span></div><div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;<span class="preprocessor">#define REMMINA_LOG_WINDOW_CLASS(klass)       (G_TYPE_CHECK_CLASS_CAST((klass), REMMINA_TYPE_LOG_WINDOW, RemminaLogWindowClass))</span></div><div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;<span class="preprocessor">#define REMMINA_IS_LOG_WINDOW(obj)            (G_TYPE_CHECK_INSTANCE_TYPE((obj), REMMINA_TYPE_LOG_WINDOW))</span></div><div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;<span class="preprocessor">#define REMMINA_IS_LOG_WINDOW_CLASS(klass)    (G_TYPE_CHECK_CLASS_TYPE((klass), REMMINA_TYPE_LOG_WINDOW))</span></div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;<span class="preprocessor">#define REMMINA_LOG_WINDOW_GET_CLASS(obj)     (G_TYPE_INSTANCE_GET_CLASS((obj), REMMINA_TYPE_LOG_WINDOW, RemminaLogWindowClass))</span></div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;</div><div class="line"><a name="l00055"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html">   55</a></span>&#160;<span class="keyword">typedef</span> <span class="keyword">struct </span><a class="code" href="struct___remmina_log_window.html">_RemminaLogWindow</a> {</div><div class="line"><a name="l00056"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184">   56</a></span>&#160;    GtkWindow <a class="code" href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184">window</a>;</div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;</div><div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">   58</a></span>&#160;    GtkWidget *<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a>;</div><div class="line"><a name="l00059"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">   59</a></span>&#160;    GtkTextBuffer *<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a>;</div><div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;} <a class="code" href="remmina__log_8c.html#ad5a920aad512279bb932bcb26a2c3c19">RemminaLogWindow</a>;</div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;</div><div class="line"><a name="l00062"></a><span class="lineno"><a class="line" href="struct___remmina_log_window_class.html">   62</a></span>&#160;<span class="keyword">typedef</span> <span class="keyword">struct </span><a class="code" href="struct___remmina_log_window_class.html">_RemminaLogWindowClass</a> {</div><div class="line"><a name="l00063"></a><span class="lineno"><a class="line" href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af">   63</a></span>&#160;    GtkWindowClass <a class="code" href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af">parent_class</a>;</div><div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;} <a class="code" href="remmina__log_8c.html#a5682db89dd84e1c413326e17a4f79dbe">RemminaLogWindowClass</a>;</div><div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;</div><div class="line"><a name="l00066"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a8f8d45cce779ec2a8db7bfdd02097a3e">   66</a></span>&#160;GType <a class="code" href="remmina__log_8c.html#a8f8d45cce779ec2a8db7bfdd02097a3e">remmina_log_window_get_type</a>(<span class="keywordtype">void</span>)</div><div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;G_GNUC_CONST;</div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;</div><div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;<a class="code" href="rcw_8c.html#a21e0a6e416667f30c2b1599b8b24faec">G_DEFINE_TYPE</a>(<a class="code" href="struct___remmina_log_window.html">RemminaLogWindow</a>, remmina_log_window, GTK_TYPE_WINDOW)</div><div class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;</div><div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;<span class="keywordtype">void</span> remmina_log_stats()</div><div class="line"><a name="l00072"></a><span class="lineno">   72</span>&#160;{</div><div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;    JsonNode *n;</div><div class="line"><a name="l00075"></a><span class="lineno">   75</span>&#160;</div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;    n = <a class="code" href="remmina__stats_8c.html#a7398b36347e3621772776c466b565641">remmina_stats_get_all</a>();</div><div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;    <span class="keywordflow">if</span> (n != NULL) {</div><div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;</div><div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;        JsonGenerator *g = json_generator_new();</div><div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;        json_generator_set_pretty (g, TRUE);</div><div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;        json_generator_set_root(g, n);</div><div class="line"><a name="l00082"></a><span class="lineno">   82</span>&#160;        json_node_unref(n);</div><div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;        g_autofree gchar *s = json_generator_to_data(g, NULL);  <span class="comment">// s=serialized stats</span></div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;        REMMINA_DEBUG(<span class="stringliteral">&quot;STATS: JSON data%s\n&quot;</span>, s);</div><div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;        g_object_unref(g);</div><div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;    }</div><div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;}</div><div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;</div><div class="line"><a name="l00089"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a0c3592cad5a8e91cd4d0c3c1b2b1f427">   89</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a0c3592cad5a8e91cd4d0c3c1b2b1f427">remmina_log_window_class_init</a>(<a class="code" href="struct___remmina_log_window_class.html">RemminaLogWindowClass</a> *klass)</div><div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;{</div><div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;}</div><div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;</div><div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;<span class="comment">/* We will always only have one log window per instance */</span></div><div class="line"><a name="l00095"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">   95</a></span>&#160;<span class="keyword">static</span> GtkWidget *<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> = NULL;</div><div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;</div><div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;<span class="keyword">static</span> GtkWidget*</div><div class="line"><a name="l00098"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a070042aa580b708536dc793336722660">   98</a></span>&#160;<a class="code" href="remmina__log_8c.html#a070042aa580b708536dc793336722660">remmina_log_window_new</a>(<span class="keywordtype">void</span>)</div><div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;{</div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;    <span class="keywordflow">return</span> GTK_WIDGET(g_object_new(REMMINA_TYPE_LOG_WINDOW, NULL));</div><div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;}</div><div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;</div><div class="line"><a name="l00104"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a355067bd2e33d8942ad9d8af60c19f0c">  104</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a355067bd2e33d8942ad9d8af60c19f0c">remmina_log_end</a>(GtkWidget *widget, gpointer data)</div><div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;{</div><div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;    <a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> = NULL;</div><div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;}</div><div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;</div><div class="line"><a name="l00110"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a8a5e75012fecec3ede5b29247760d5c3">  110</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a8a5e75012fecec3ede5b29247760d5c3">remmina_log_start_stop</a> (GtkSwitch *logswitch, gpointer user_data)</div><div class="line"><a name="l00111"></a><span class="lineno">  111</span>&#160;{</div><div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00113"></a><span class="lineno">  113</span>&#160;    <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a> = !<a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a>;</div><div class="line"><a name="l00114"></a><span class="lineno">  114</span>&#160;}</div><div class="line"><a name="l00115"></a><span class="lineno">  115</span>&#160;</div><div class="line"><a name="l00116"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a72cf53183f3ef89c4208fdccb629003d">  116</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a72cf53183f3ef89c4208fdccb629003d">remmina_log_start</a>(<span class="keywordtype">void</span>)</div><div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;{</div><div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00120"></a><span class="lineno">  120</span>&#160;        gtk_window_present(GTK_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>));</div><div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;    }<span class="keywordflow">else</span>  {</div><div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;        <a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> = <a class="code" href="remmina__log_8c.html#a070042aa580b708536dc793336722660">remmina_log_window_new</a>();</div><div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;        gtk_window_set_default_size(GTK_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>), 640, 480);</div><div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;        gtk_window_set_resizable (GTK_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>), TRUE);</div><div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;        gtk_window_set_decorated (GTK_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>), TRUE);</div><div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;</div><div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;        <span class="comment">/* Header bar */</span></div><div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;        GtkWidget *header = gtk_header_bar_new ();</div><div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;        gtk_header_bar_set_show_close_button (GTK_HEADER_BAR (header), TRUE);</div><div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;        gtk_header_bar_set_title (GTK_HEADER_BAR (header), _(<span class="stringliteral">&quot;Remmina debugging window&quot;</span>));</div><div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;        gtk_header_bar_set_has_subtitle (GTK_HEADER_BAR (header), FALSE);</div><div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;        <span class="comment">/* Stats */</span></div><div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;        GtkWidget *getstat = gtk_button_new ();</div><div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;        gtk_widget_set_tooltip_text (getstat, _(<span class="stringliteral">&quot;Paste system info in the Remmina debugging window&quot;</span>));</div><div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;        GIcon *icon = g_themed_icon_new (<span class="stringliteral">&quot;edit-paste-symbolic&quot;</span>);</div><div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;        GtkWidget *image = gtk_image_new_from_gicon (icon, GTK_ICON_SIZE_BUTTON);</div><div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;        g_object_unref (icon);</div><div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;        gtk_container_add (GTK_CONTAINER (getstat), image);</div><div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;        gtk_header_bar_pack_start (GTK_HEADER_BAR (header), getstat);</div><div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;        <span class="comment">/* Start logging */</span></div><div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;        GtkWidget *start = gtk_switch_new ();</div><div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;        <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a> = TRUE;</div><div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;        gtk_switch_set_active (GTK_SWITCH(start), <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a>);</div><div class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;        gtk_widget_set_valign (start, GTK_ALIGN_CENTER);</div><div class="line"><a name="l00145"></a><span class="lineno">  145</span>&#160;        gtk_header_bar_pack_start (GTK_HEADER_BAR (header), start);</div><div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;</div><div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;        gtk_window_set_titlebar (GTK_WINDOW (<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>), header);</div><div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;</div><div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;        g_signal_connect(getstat, <span class="stringliteral">&quot;button-press-event&quot;</span>, G_CALLBACK(remmina_log_stats), NULL);</div><div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;        g_signal_connect(start, <span class="stringliteral">&quot;notify::active&quot;</span>, G_CALLBACK(<a class="code" href="remmina__log_8c.html#a8a5e75012fecec3ede5b29247760d5c3">remmina_log_start_stop</a>), NULL);</div><div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;        g_signal_connect(G_OBJECT(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>), <span class="stringliteral">&quot;destroy&quot;</span>, G_CALLBACK(<a class="code" href="remmina__log_8c.html#a355067bd2e33d8942ad9d8af60c19f0c">remmina_log_end</a>), NULL);</div><div class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;        gtk_widget_show_all(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>);</div><div class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;    }</div><div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;</div><div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;    <a class="code" href="remmina__log_8c.html#aca8f826a273194e22f4467421af9b3aa">remmina_log_print</a>(_(<span class="stringliteral">&quot;This window can help you find connection problems.\n&quot;</span></div><div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;        <span class="stringliteral">&quot;You can stop and start the logging at any moment using the On/Off switch.\n&quot;</span></div><div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;        <span class="stringliteral">&quot;The stats button (Ctrl+T), can be useful to gather system info you may share when reporting a bug.\n&quot;</span></div><div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;        <span class="stringliteral">&quot;There is more info about debugging Remmina on https://gitlab.com/Remmina/Remmina/-/wikis/Usage/Remmina-debugging\n&quot;</span></div><div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;        ));</div><div class="line"><a name="l00160"></a><span class="lineno">  160</span>&#160;}</div><div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;</div><div class="line"><a name="l00162"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a96f5bb72acbdcbf8793b4a5f4a6132b5">  162</a></span>&#160;gboolean <a class="code" href="remmina__log_8c.html#a96f5bb72acbdcbf8793b4a5f4a6132b5">remmina_log_running</a>(<span class="keywordtype">void</span>)</div><div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;{</div><div class="line"><a name="l00164"></a><span class="lineno">  164</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00165"></a><span class="lineno">  165</span>&#160;    <span class="keywordflow">return</span> (<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> != NULL);</div><div class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;}</div><div class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;</div><div class="line"><a name="l00168"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a6a5cc60197293b97a0c6fa2a471b221b">  168</a></span>&#160;<span class="keyword">static</span> gboolean <a class="code" href="remmina__log_8c.html#a6a5cc60197293b97a0c6fa2a471b221b">remmina_log_scroll_to_end</a>(gpointer data)</div><div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;{</div><div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;    GtkTextIter iter;</div><div class="line"><a name="l00172"></a><span class="lineno">  172</span>&#160;</div><div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;        gtk_text_buffer_get_end_iter(REMMINA_LOG_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>)-&gt;<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a>, &amp;iter);</div><div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;        gtk_text_view_scroll_to_iter(GTK_TEXT_VIEW(REMMINA_LOG_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>)-&gt;<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a>), &amp;iter, 0.0, FALSE, 0.0,</div><div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;            0.0);</div><div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;    }</div><div class="line"><a name="l00178"></a><span class="lineno">  178</span>&#160;    <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;}</div><div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;</div><div class="line"><a name="l00181"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">  181</a></span>&#160;<span class="keyword">static</span> gboolean <a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>(gpointer data)</div><div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;{</div><div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;    GtkTextIter iter;</div><div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;</div><div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> &amp;&amp; <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a>) {</div><div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;        gtk_text_buffer_get_end_iter(REMMINA_LOG_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>)-&gt;<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a>, &amp;iter);</div><div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;        gtk_text_buffer_insert(REMMINA_LOG_WINDOW(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>)-&gt;<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a>, &amp;iter, (<span class="keyword">const</span> gchar*)data, -1);</div><div class="line"><a name="l00189"></a><span class="lineno">  189</span>&#160;        IDLE_ADD(<a class="code" href="remmina__log_8c.html#a6a5cc60197293b97a0c6fa2a471b221b">remmina_log_scroll_to_end</a>, NULL);</div><div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;    }</div><div class="line"><a name="l00191"></a><span class="lineno">  191</span>&#160;    g_free(data);</div><div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;    <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;}</div><div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;</div><div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;<span class="comment">// Only prints into Remmina&#39;s own debug window. (Not stdout!)</span></div><div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;<span class="comment">// See _remmina_{debug, info, error, critical, warning}</span></div><div class="line"><a name="l00197"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#aca8f826a273194e22f4467421af9b3aa">  197</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#aca8f826a273194e22f4467421af9b3aa">remmina_log_print</a>(<span class="keyword">const</span> gchar *text)</div><div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;{</div><div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>)</div><div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;</div><div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, g_strdup(text));</div><div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;}</div><div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;</div><div class="line"><a name="l00206"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a49817b70a398a2f21514fb0066c6e04c">  206</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a49817b70a398a2f21514fb0066c6e04c">_remmina_info</a>(<span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;{</div><div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00209"></a><span class="lineno">  209</span>&#160;</div><div class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;    va_list args;</div><div class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;    g_autofree gchar *text;</div><div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00214"></a><span class="lineno">  214</span>&#160;    va_end(args);</div><div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;</div><div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;    <span class="comment">// always appends newline</span></div><div class="line"><a name="l00217"></a><span class="lineno">  217</span>&#160;    g_info (<span class="stringliteral">&quot;%s&quot;</span>, text);</div><div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;</div><div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;    g_autofree gchar *buf_tmp = g_strconcat(text, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;    <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;    gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(INFO) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;</div><div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;        free(bufn);</div><div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;    }</div><div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, bufn);</div><div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;}</div><div class="line"><a name="l00229"></a><span class="lineno">  229</span>&#160;</div><div class="line"><a name="l00230"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#ae439b5fb61045d22c9474b32d0158185">  230</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#ae439b5fb61045d22c9474b32d0158185">_remmina_message</a>(<span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;{</div><div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;</div><div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;    va_list args;</div><div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;    g_autofree gchar *text;</div><div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;    va_end(args);</div><div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;</div><div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;    <span class="comment">// always appends newline</span></div><div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;    g_message (<span class="stringliteral">&quot;%s&quot;</span>, text);</div><div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;</div><div class="line"><a name="l00243"></a><span class="lineno">  243</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00244"></a><span class="lineno">  244</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;    }</div><div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;</div><div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;    g_autofree gchar *buf_tmp = g_strconcat(text, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;    <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;    gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(MESSAGE) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;</div><div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, bufn);</div><div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;}</div><div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;</div><div class="line"><a name="l00259"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a9234814488626cc2513e9fb255a90f53">  259</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a9234814488626cc2513e9fb255a90f53">_remmina_debug</a>(<span class="keyword">const</span> gchar *fun, <span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;{</div><div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;</div><div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;    va_list args;</div><div class="line"><a name="l00264"></a><span class="lineno">  264</span>&#160;    gchar *text;</div><div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00266"></a><span class="lineno">  266</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;    va_end(args);</div><div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;</div><div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;    g_autofree gchar *buf = g_strconcat(<span class="stringliteral">&quot;(&quot;</span>, fun, <span class="stringliteral">&quot;) - &quot;</span>, text, NULL);</div><div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;    g_free(text);</div><div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;</div><div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;    <span class="comment">// always appends newline</span></div><div class="line"><a name="l00273"></a><span class="lineno">  273</span>&#160;    g_debug (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00274"></a><span class="lineno">  274</span>&#160;</div><div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;    }</div><div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;</div><div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;    g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;    <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;    gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(DEBUG) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;</div><div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, bufn);</div><div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;}</div><div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;</div><div class="line"><a name="l00286"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a8a47ecac307ae1787cdad1ccc4b43d13">  286</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a8a47ecac307ae1787cdad1ccc4b43d13">_remmina_warning</a>(<span class="keyword">const</span> gchar *fun, <span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;{</div><div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;</div><div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;    va_list args;</div><div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;    gchar *text;</div><div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;    va_end(args);</div><div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;</div><div class="line"><a name="l00296"></a><span class="lineno">  296</span>&#160;    g_autofree gchar *buf = g_strconcat(<span class="stringliteral">&quot;(&quot;</span>, fun, <span class="stringliteral">&quot;) - &quot;</span>, text, NULL);</div><div class="line"><a name="l00297"></a><span class="lineno">  297</span>&#160;    g_free(text);</div><div class="line"><a name="l00298"></a><span class="lineno">  298</span>&#160;</div><div class="line"><a name="l00299"></a><span class="lineno">  299</span>&#160;    <span class="comment">// always appends newline</span></div><div class="line"><a name="l00300"></a><span class="lineno">  300</span>&#160;    g_warning (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;</div><div class="line"><a name="l00302"></a><span class="lineno">  302</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00303"></a><span class="lineno">  303</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00304"></a><span class="lineno">  304</span>&#160;    }</div><div class="line"><a name="l00305"></a><span class="lineno">  305</span>&#160;</div><div class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;    g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00307"></a><span class="lineno">  307</span>&#160;    <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00308"></a><span class="lineno">  308</span>&#160;    gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(WARN) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00309"></a><span class="lineno">  309</span>&#160;</div><div class="line"><a name="l00310"></a><span class="lineno">  310</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, bufn);</div><div class="line"><a name="l00311"></a><span class="lineno">  311</span>&#160;}</div><div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;</div><div class="line"><a name="l00313"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a19da9a0d0eac2a2b7fcc926dee2eb368">  313</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a19da9a0d0eac2a2b7fcc926dee2eb368">_remmina_audit</a>(<span class="keyword">const</span> gchar *fun, <span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00314"></a><span class="lineno">  314</span>&#160;{</div><div class="line"><a name="l00315"></a><span class="lineno">  315</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;    va_list args;</div><div class="line"><a name="l00317"></a><span class="lineno">  317</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;    gchar *text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;    va_end(args);</div><div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;</div><div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;<span class="preprocessor">#if GLIB_CHECK_VERSION(2,62,0)</span></div><div class="line"><a name="l00322"></a><span class="lineno">  322</span>&#160;    GDateTime* tv = g_date_time_new_now_local();</div><div class="line"><a name="l00323"></a><span class="lineno">  323</span>&#160;    gchar *isodate = g_date_time_format_iso8601(tv);</div><div class="line"><a name="l00324"></a><span class="lineno">  324</span>&#160;    g_date_time_unref(tv);</div><div class="line"><a name="l00325"></a><span class="lineno">  325</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;    GTimeVal tv;</div><div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;    g_get_current_time(&amp;tv);</div><div class="line"><a name="l00328"></a><span class="lineno">  328</span>&#160;    gchar *isodate = g_time_val_to_iso8601(&amp;tv);</div><div class="line"><a name="l00329"></a><span class="lineno">  329</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;</div><div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;    g_autofree gchar *buf = g_strdup(<span class="stringliteral">&quot;&quot;</span>);</div><div class="line"><a name="l00332"></a><span class="lineno">  332</span>&#160;</div><div class="line"><a name="l00333"></a><span class="lineno">  333</span>&#160;    <span class="keywordflow">if</span> (isodate) {</div><div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;</div><div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;        buf = g_strconcat(</div><div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;                <span class="stringliteral">&quot;[&quot;</span>, isodate, <span class="stringliteral">&quot;] - &quot;</span>,</div><div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;                g_get_host_name (),</div><div class="line"><a name="l00338"></a><span class="lineno">  338</span>&#160;                <span class="stringliteral">&quot; - &quot;</span>,</div><div class="line"><a name="l00339"></a><span class="lineno">  339</span>&#160;                g_get_user_name (),</div><div class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;                <span class="stringliteral">&quot; - &quot;</span>,</div><div class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;                text,</div><div class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;                NULL);</div><div class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;</div><div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;    }</div><div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;</div><div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;    g_free(text);</div><div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="remmina__pref_8c.html#a9a8d02227eb703bccc3f9296a5d89d6f">remmina_pref_get_boolean</a>(<span class="stringliteral">&quot;audit&quot;</span>))</div><div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;        <a class="code" href="remmina__log_8c.html#ae439b5fb61045d22c9474b32d0158185">_remmina_message</a>(buf);</div><div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;        <a class="code" href="remmina__log_8c.html#a9234814488626cc2513e9fb255a90f53">_remmina_debug</a>(fun, buf);</div><div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;}</div><div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;</div><div class="line"><a name="l00353"></a><span class="lineno">  353</span>&#160;<span class="comment">// !!! Calling this function will crash Remmina !!!</span></div><div class="line"><a name="l00354"></a><span class="lineno">  354</span>&#160;<span class="comment">// !!! purposefully and send a trap signal !!!</span></div><div class="line"><a name="l00355"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a984e0494481144aa121893f5d14025f7">  355</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a984e0494481144aa121893f5d14025f7">_remmina_error</a>(<span class="keyword">const</span> gchar *fun, <span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;{</div><div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00358"></a><span class="lineno">  358</span>&#160;</div><div class="line"><a name="l00359"></a><span class="lineno">  359</span>&#160;    va_list args;</div><div class="line"><a name="l00360"></a><span class="lineno">  360</span>&#160;    gchar *text;</div><div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;    va_end(args);</div><div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;</div><div class="line"><a name="l00365"></a><span class="lineno">  365</span>&#160;    g_autofree gchar *buf = g_strconcat(<span class="stringliteral">&quot;(&quot;</span>, fun, <span class="stringliteral">&quot;) - &quot;</span>, text, NULL);</div><div class="line"><a name="l00366"></a><span class="lineno">  366</span>&#160;    g_free(text);</div><div class="line"><a name="l00367"></a><span class="lineno">  367</span>&#160;</div><div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;    <span class="comment">// always appends newline</span></div><div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;    g_error (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;</div><div class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;    }</div><div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;</div><div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;    g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;    <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;    gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(ERROR) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;</div><div class="line"><a name="l00379"></a><span class="lineno">  379</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, bufn);</div><div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;}</div><div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;</div><div class="line"><a name="l00382"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a35109f5950931f79c13dac26143a69d3">  382</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a35109f5950931f79c13dac26143a69d3">_remmina_critical</a>(<span class="keyword">const</span> gchar *fun, <span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00383"></a><span class="lineno">  383</span>&#160;{</div><div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00385"></a><span class="lineno">  385</span>&#160;</div><div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;    va_list args;</div><div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;    gchar *text;</div><div class="line"><a name="l00388"></a><span class="lineno">  388</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00389"></a><span class="lineno">  389</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;    va_end(args);</div><div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;</div><div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;    g_autofree gchar *buf = g_strconcat(<span class="stringliteral">&quot;(&quot;</span>, fun, <span class="stringliteral">&quot;) - &quot;</span>, text, NULL);</div><div class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;    g_free(text);</div><div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;</div><div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;    <span class="comment">// always appends newline</span></div><div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;    g_critical (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;</div><div class="line"><a name="l00398"></a><span class="lineno">  398</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) {</div><div class="line"><a name="l00399"></a><span class="lineno">  399</span>&#160;        <span class="keywordflow">return</span>;</div><div class="line"><a name="l00400"></a><span class="lineno">  400</span>&#160;    }</div><div class="line"><a name="l00401"></a><span class="lineno">  401</span>&#160;</div><div class="line"><a name="l00402"></a><span class="lineno">  402</span>&#160;    g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;    <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;    gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(CRIT) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;</div><div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, bufn);</div><div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;}</div><div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;</div><div class="line"><a name="l00409"></a><span class="lineno">  409</span>&#160;<span class="comment">// Only prints into Remmina&#39;s own debug window. (Not stdout!)</span></div><div class="line"><a name="l00410"></a><span class="lineno">  410</span>&#160;<span class="comment">// See _remmina_{message, info, debug warning, error, critical}</span></div><div class="line"><a name="l00411"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#ac7848510c1fe1990c992e28cd31af9d8">  411</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#ac7848510c1fe1990c992e28cd31af9d8">remmina_log_printf</a>(<span class="keyword">const</span> gchar *fmt, ...)</div><div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;{</div><div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;    va_list args;</div><div class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;    gchar *text;</div><div class="line"><a name="l00416"></a><span class="lineno">  416</span>&#160;</div><div class="line"><a name="l00417"></a><span class="lineno">  417</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>) <span class="keywordflow">return</span>;</div><div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160;</div><div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;    va_start(args, fmt);</div><div class="line"><a name="l00420"></a><span class="lineno">  420</span>&#160;    text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;    va_end(args);</div><div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;</div><div class="line"><a name="l00423"></a><span class="lineno">  423</span>&#160;    IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, text);</div><div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;}</div><div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;</div><div class="line"><a name="l00426"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a43a42f51f64b54924564e166c56b39e1">  426</a></span>&#160;<span class="keyword">static</span> gboolean <a class="code" href="remmina__log_8c.html#a43a42f51f64b54924564e166c56b39e1">remmina_log_on_keypress</a>(GtkWidget *widget, GdkEvent *event, gpointer user_data)</div><div class="line"><a name="l00427"></a><span class="lineno">  427</span>&#160;{</div><div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;</div><div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;    <span class="keywordflow">if</span> (!<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>)</div><div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;        <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;</div><div class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;    GdkEventKey *e = (GdkEventKey *)event;</div><div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;</div><div class="line"><a name="l00435"></a><span class="lineno">  435</span>&#160;    <span class="keywordflow">if</span> ((e-&gt;state &amp; GDK_CONTROL_MASK) == GDK_CONTROL_MASK) {</div><div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;        <span class="keywordflow">if</span> (e-&gt;keyval == GDK_KEY_t) {</div><div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;            remmina_log_stats();</div><div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;        }</div><div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;        <span class="keywordflow">return</span> TRUE;</div><div class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;    }</div><div class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;</div><div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;    <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;}</div><div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;</div><div class="line"><a name="l00445"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a1e5960f194353bd36d82bd9476c309bd">  445</a></span>&#160;<span class="keyword">static</span> <span class="keywordtype">void</span> <a class="code" href="remmina__log_8c.html#a1e5960f194353bd36d82bd9476c309bd">remmina_log_window_init</a>(<a class="code" href="struct___remmina_log_window.html">RemminaLogWindow</a> *logwin)</div><div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;{</div><div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;    TRACE_CALL(__func__);</div><div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;    GtkWidget *scrolledwindow;</div><div class="line"><a name="l00449"></a><span class="lineno">  449</span>&#160;    GtkWidget *widget;</div><div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;</div><div class="line"><a name="l00451"></a><span class="lineno">  451</span>&#160;    gtk_container_set_border_width(GTK_CONTAINER(logwin), 4);</div><div class="line"><a name="l00452"></a><span class="lineno">  452</span>&#160;</div><div class="line"><a name="l00453"></a><span class="lineno">  453</span>&#160;    scrolledwindow = gtk_scrolled_window_new(NULL, NULL);</div><div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;    gtk_widget_show(scrolledwindow);</div><div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;    gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS);</div><div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;    gtk_container_add(GTK_CONTAINER(logwin), scrolledwindow);</div><div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;</div><div class="line"><a name="l00458"></a><span class="lineno">  458</span>&#160;    widget = gtk_text_view_new();</div><div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;    gtk_widget_show(widget);</div><div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;    gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(widget), GTK_WRAP_WORD_CHAR);</div><div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;    gtk_text_view_set_editable(GTK_TEXT_VIEW(widget), FALSE);</div><div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;    gtk_text_view_set_monospace(GTK_TEXT_VIEW(widget), TRUE);</div><div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;    gtk_container_add(GTK_CONTAINER(scrolledwindow), widget);</div><div class="line"><a name="l00464"></a><span class="lineno">  464</span>&#160;    logwin-&gt;<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a> = widget;</div><div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;    logwin-&gt;<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a> = gtk_text_view_get_buffer(GTK_TEXT_VIEW(widget));</div><div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;</div><div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;    g_signal_connect(G_OBJECT(logwin-&gt;<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a>), <span class="stringliteral">&quot;key-press-event&quot;</span>, G_CALLBACK(<a class="code" href="remmina__log_8c.html#a43a42f51f64b54924564e166c56b39e1">remmina_log_on_keypress</a>), (gpointer)logwin);</div><div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;}</div><div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;</div><div class="ttc" id="remmina__log_8c_html_a72cf53183f3ef89c4208fdccb629003d"><div class="ttname"><a href="remmina__log_8c.html#a72cf53183f3ef89c4208fdccb629003d">remmina_log_start</a></div><div class="ttdeci">void remmina_log_start(void)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00116">remmina_log.c:116</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a973ea192c9eb7562f0590e62d95ba0e0"><div class="ttname"><a href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a></div><div class="ttdeci">gboolean logstart</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00045">remmina_log.c:45</a></div></div>
<div class="ttc" id="struct___remmina_log_window_html_ae287dadd2c2a5bf704d7c494bcc74184"><div class="ttname"><a href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184">_RemminaLogWindow::window</a></div><div class="ttdeci">GtkWindow window</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00056">remmina_log.c:56</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a35109f5950931f79c13dac26143a69d3"><div class="ttname"><a href="remmina__log_8c.html#a35109f5950931f79c13dac26143a69d3">_remmina_critical</a></div><div class="ttdeci">void _remmina_critical(const gchar *fun, const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00382">remmina_log.c:382</a></div></div>
<div class="ttc" id="struct___remmina_log_window_html"><div class="ttname"><a href="struct___remmina_log_window.html">_RemminaLogWindow</a></div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00055">remmina_log.c:55</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a8a5e75012fecec3ede5b29247760d5c3"><div class="ttname"><a href="remmina__log_8c.html#a8a5e75012fecec3ede5b29247760d5c3">remmina_log_start_stop</a></div><div class="ttdeci">static void remmina_log_start_stop(GtkSwitch *logswitch, gpointer user_data)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00110">remmina_log.c:110</a></div></div>
<div class="ttc" id="remmina__trace__calls_8h_html"><div class="ttname"><a href="remmina__trace__calls_8h.html">remmina_trace_calls.h</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a8a47ecac307ae1787cdad1ccc4b43d13"><div class="ttname"><a href="remmina__log_8c.html#a8a47ecac307ae1787cdad1ccc4b43d13">_remmina_warning</a></div><div class="ttdeci">void _remmina_warning(const gchar *fun, const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00286">remmina_log.c:286</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a19da9a0d0eac2a2b7fcc926dee2eb368"><div class="ttname"><a href="remmina__log_8c.html#a19da9a0d0eac2a2b7fcc926dee2eb368">_remmina_audit</a></div><div class="ttdeci">void _remmina_audit(const gchar *fun, const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00313">remmina_log.c:313</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a7cbb8cc1b0525ae49248a84fb4b2b1a1"><div class="ttname"><a href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a></div><div class="ttdeci">static gboolean remmina_log_print_real(gpointer data)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00181">remmina_log.c:181</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a5682db89dd84e1c413326e17a4f79dbe"><div class="ttname"><a href="remmina__log_8c.html#a5682db89dd84e1c413326e17a4f79dbe">RemminaLogWindowClass</a></div><div class="ttdeci">struct _RemminaLogWindowClass RemminaLogWindowClass</div></div>
<div class="ttc" id="remmina__log_8c_html_a6a5cc60197293b97a0c6fa2a471b221b"><div class="ttname"><a href="remmina__log_8c.html#a6a5cc60197293b97a0c6fa2a471b221b">remmina_log_scroll_to_end</a></div><div class="ttdeci">static gboolean remmina_log_scroll_to_end(gpointer data)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00168">remmina_log.c:168</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a9234814488626cc2513e9fb255a90f53"><div class="ttname"><a href="remmina__log_8c.html#a9234814488626cc2513e9fb255a90f53">_remmina_debug</a></div><div class="ttdeci">void _remmina_debug(const gchar *fun, const gchar *fmt,...)</div><div class="ttdoc">Print a string in the Remmina Debug Windows and in the terminal. </div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00259">remmina_log.c:259</a></div></div>
<div class="ttc" id="struct___remmina_log_window_html_a06774ea75d0ea07580555d34abbb8232"><div class="ttname"><a href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">_RemminaLogWindow::log_buffer</a></div><div class="ttdeci">GtkTextBuffer * log_buffer</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00059">remmina_log.c:59</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a96f5bb72acbdcbf8793b4a5f4a6132b5"><div class="ttname"><a href="remmina__log_8c.html#a96f5bb72acbdcbf8793b4a5f4a6132b5">remmina_log_running</a></div><div class="ttdeci">gboolean remmina_log_running(void)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00162">remmina_log.c:162</a></div></div>
<div class="ttc" id="struct___remmina_log_window_html_abfbb6314130ad100aba258087d9d4087"><div class="ttname"><a href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">_RemminaLogWindow::log_view</a></div><div class="ttdeci">GtkWidget * log_view</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00058">remmina_log.c:58</a></div></div>
<div class="ttc" id="rcw_8c_html_a21e0a6e416667f30c2b1599b8b24faec"><div class="ttname"><a href="rcw_8c.html#a21e0a6e416667f30c2b1599b8b24faec">G_DEFINE_TYPE</a></div><div class="ttdeci">G_DEFINE_TYPE(RemminaConnectionWindow, rcw, GTK_TYPE_WINDOW)</div><div class="ttdef"><b>Definition:</b> <a href="rcw_8c_source.html#l00081">rcw.c:81</a></div></div>
<div class="ttc" id="remmina__public_8h_html"><div class="ttname"><a href="remmina__public_8h.html">remmina_public.h</a></div></div>
<div class="ttc" id="struct___remmina_log_window_class_html"><div class="ttname"><a href="struct___remmina_log_window_class.html">_RemminaLogWindowClass</a></div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00062">remmina_log.c:62</a></div></div>
<div class="ttc" id="remmina__log_8h_html"><div class="ttname"><a href="remmina__log_8h.html">remmina_log.h</a></div></div>
<div class="ttc" id="remmina__pref_8c_html_a9a8d02227eb703bccc3f9296a5d89d6f"><div class="ttname"><a href="remmina__pref_8c.html#a9a8d02227eb703bccc3f9296a5d89d6f">remmina_pref_get_boolean</a></div><div class="ttdeci">gboolean remmina_pref_get_boolean(const gchar *key)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__pref_8c_source.html#l01164">remmina_pref.c:1164</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a1e5960f194353bd36d82bd9476c309bd"><div class="ttname"><a href="remmina__log_8c.html#a1e5960f194353bd36d82bd9476c309bd">remmina_log_window_init</a></div><div class="ttdeci">static void remmina_log_window_init(RemminaLogWindow *logwin)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00445">remmina_log.c:445</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a49817b70a398a2f21514fb0066c6e04c"><div class="ttname"><a href="remmina__log_8c.html#a49817b70a398a2f21514fb0066c6e04c">_remmina_info</a></div><div class="ttdeci">void _remmina_info(const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00206">remmina_log.c:206</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a43a42f51f64b54924564e166c56b39e1"><div class="ttname"><a href="remmina__log_8c.html#a43a42f51f64b54924564e166c56b39e1">remmina_log_on_keypress</a></div><div class="ttdeci">static gboolean remmina_log_on_keypress(GtkWidget *widget, GdkEvent *event, gpointer user_data)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00426">remmina_log.c:426</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a8f8d45cce779ec2a8db7bfdd02097a3e"><div class="ttname"><a href="remmina__log_8c.html#a8f8d45cce779ec2a8db7bfdd02097a3e">remmina_log_window_get_type</a></div><div class="ttdeci">GType remmina_log_window_get_type(void)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00066">remmina_log.c:66</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a070042aa580b708536dc793336722660"><div class="ttname"><a href="remmina__log_8c.html#a070042aa580b708536dc793336722660">remmina_log_window_new</a></div><div class="ttdeci">static GtkWidget * remmina_log_window_new(void)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00098">remmina_log.c:98</a></div></div>
<div class="ttc" id="remmina__stats_8h_html"><div class="ttname"><a href="remmina__stats_8h.html">remmina_stats.h</a></div></div>
<div class="ttc" id="remmina__stats_8c_html_a7398b36347e3621772776c466b565641"><div class="ttname"><a href="remmina__stats_8c.html#a7398b36347e3621772776c466b565641">remmina_stats_get_all</a></div><div class="ttdeci">JsonNode * remmina_stats_get_all()</div><div class="ttdoc">Get all statistics in JSON format to send periodically to the PHP server. </div><div class="ttdef"><b>Definition:</b> <a href="remmina__stats_8c_source.html#l00806">remmina_stats.c:806</a></div></div>
<div class="ttc" id="remmina__pref_8h_html"><div class="ttname"><a href="remmina__pref_8h.html">remmina_pref.h</a></div></div>
<div class="ttc" id="remmina__log_8c_html_ad5a920aad512279bb932bcb26a2c3c19"><div class="ttname"><a href="remmina__log_8c.html#ad5a920aad512279bb932bcb26a2c3c19">RemminaLogWindow</a></div><div class="ttdeci">struct _RemminaLogWindow RemminaLogWindow</div></div>
<div class="ttc" id="remmina__log_8c_html_a6c06467e9ec98a4ccc6645291cd5d19a"><div class="ttname"><a href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a></div><div class="ttdeci">static GtkWidget * log_window</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00095">remmina_log.c:95</a></div></div>
<div class="ttc" id="remmina__log_8c_html_ac7848510c1fe1990c992e28cd31af9d8"><div class="ttname"><a href="remmina__log_8c.html#ac7848510c1fe1990c992e28cd31af9d8">remmina_log_printf</a></div><div class="ttdeci">void remmina_log_printf(const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00411">remmina_log.c:411</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a0c3592cad5a8e91cd4d0c3c1b2b1f427"><div class="ttname"><a href="remmina__log_8c.html#a0c3592cad5a8e91cd4d0c3c1b2b1f427">remmina_log_window_class_init</a></div><div class="ttdeci">static void remmina_log_window_class_init(RemminaLogWindowClass *klass)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00089">remmina_log.c:89</a></div></div>
<div class="ttc" id="remmina__log_8c_html_aca8f826a273194e22f4467421af9b3aa"><div class="ttname"><a href="remmina__log_8c.html#aca8f826a273194e22f4467421af9b3aa">remmina_log_print</a></div><div class="ttdeci">void remmina_log_print(const gchar *text)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00197">remmina_log.c:197</a></div></div>
<div class="ttc" id="remmina__log_8c_html_ae439b5fb61045d22c9474b32d0158185"><div class="ttname"><a href="remmina__log_8c.html#ae439b5fb61045d22c9474b32d0158185">_remmina_message</a></div><div class="ttdeci">void _remmina_message(const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00230">remmina_log.c:230</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a355067bd2e33d8942ad9d8af60c19f0c"><div class="ttname"><a href="remmina__log_8c.html#a355067bd2e33d8942ad9d8af60c19f0c">remmina_log_end</a></div><div class="ttdeci">static void remmina_log_end(GtkWidget *widget, gpointer data)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00104">remmina_log.c:104</a></div></div>
<div class="ttc" id="remmina__log_8c_html_a984e0494481144aa121893f5d14025f7"><div class="ttname"><a href="remmina__log_8c.html#a984e0494481144aa121893f5d14025f7">_remmina_error</a></div><div class="ttdeci">void _remmina_error(const gchar *fun, const gchar *fmt,...)</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00355">remmina_log.c:355</a></div></div>
<div class="ttc" id="struct___remmina_log_window_class_html_af63588f4d71726fcda17ae5c2adcf2af"><div class="ttname"><a href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af">_RemminaLogWindowClass::parent_class</a></div><div class="ttdeci">GtkWindowClass parent_class</div><div class="ttdef"><b>Definition:</b> <a href="remmina__log_8c_source.html#l00063">remmina_log.c:63</a></div></div>
</div><!-- fragment --></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="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="remmina__log_8c.html">remmina_log.c</a></li>
    <li class="footer">Generated by
    <a href="http://www.doxygen.org/index.html">
    <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li>
  </ul>
</div>
</body>
</html>