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

gitlab.com/Remmina/remminadoc.gitlab.io.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAntenore Gatta <antenore@simbiosi.org>2021-12-20 01:56:43 +0300
committerAntenore Gatta <antenore@simbiosi.org>2021-12-20 01:56:43 +0300
commit34f964815ac0cccae1b96536bf49383bfae032fd (patch)
tree8363b2a40010753fbd799f302aa9e6589ba281cb /public/remmina__log_8c_source.html
parent0748c0d914c5208b6c3492bc80680e53dafba892 (diff)
Automatic doc build by remmina-ci
Diffstat (limited to 'public/remmina__log_8c_source.html')
-rw-r--r--public/remmina__log_8c_source.html4
1 files changed, 2 insertions, 2 deletions
diff --git a/public/remmina__log_8c_source.html b/public/remmina__log_8c_source.html
index 7843ce456..3542a6422 100644
--- a/public/remmina__log_8c_source.html
+++ b/public/remmina__log_8c_source.html
@@ -30,7 +30,7 @@
<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.22</span>
+ &#160;<span id="projectnumber">v1.4.23</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>
@@ -86,7 +86,7 @@ $(document).ready(function(){initNavTree('remmina__log_8c_source.html','');});
<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-2021 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__log_8h.html">remmina_log.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__stats_8h.html">remmina_stats.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__trace__calls_8h.html">remmina/remmina_trace_calls.h</a>&quot;</span></div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;</div><div class="line"><a name="l00044"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0"> 44</a></span>&#160;gboolean <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a>;</div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;</div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160;<span class="comment">/***** Define the log window GUI *****/</span></div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;<span class="preprocessor">#define REMMINA_TYPE_LOG_WINDOW (remmina_log_window_get_type())</span></div><div class="line"><a name="l00048"></a><span class="lineno"> 48</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="l00049"></a><span class="lineno"> 49</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="l00050"></a><span class="lineno"> 50</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="l00051"></a><span class="lineno"> 51</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="l00052"></a><span class="lineno"> 52</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="l00053"></a><span class="lineno"> 53</span>&#160;</div><div class="line"><a name="l00054"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html"> 54</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="l00055"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184"> 55</a></span>&#160; GtkWindow <a class="code" href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184">window</a>;</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160;</div><div class="line"><a name="l00057"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087"> 57</a></span>&#160; GtkWidget *<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a>;</div><div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232"> 58</a></span>&#160; GtkTextBuffer *<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a>;</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160;} <a class="code" href="remmina__log_8c.html#ad5a920aad512279bb932bcb26a2c3c19">RemminaLogWindow</a>;</div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160;</div><div class="line"><a name="l00061"></a><span class="lineno"><a class="line" href="struct___remmina_log_window_class.html"> 61</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="l00062"></a><span class="lineno"><a class="line" href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af"> 62</a></span>&#160; GtkWindowClass <a class="code" href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af">parent_class</a>;</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160;} <a class="code" href="remmina__log_8c.html#a5682db89dd84e1c413326e17a4f79dbe">RemminaLogWindowClass</a>;</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160;</div><div class="line"><a name="l00065"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a8f8d45cce779ec2a8db7bfdd02097a3e"> 65</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="l00066"></a><span class="lineno"> 66</span>&#160;G_GNUC_CONST;</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160;</div><div class="line"><a name="l00068"></a><span class="lineno"> 68</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="l00069"></a><span class="lineno"> 69</span>&#160;</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160;<span class="keywordtype">void</span> remmina_log_stats()</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160;{</div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; JsonNode *n;</div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160;</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; n = <a class="code" href="remmina__stats_8c.html#a7398b36347e3621772776c466b565641">remmina_stats_get_all</a>();</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keywordflow">if</span> (n != NULL) {</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160;</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; JsonGenerator *g = json_generator_new();</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; json_generator_set_pretty (g, TRUE);</div><div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; json_generator_set_root(g, n);</div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; json_node_unref(n);</div><div class="line"><a name="l00082"></a><span class="lineno"> 82</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="l00083"></a><span class="lineno"> 83</span>&#160; REMMINA_DEBUG(<span class="stringliteral">&quot;STATS: JSON data%s\n&quot;</span>, s);</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; g_object_unref(g);</div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; }</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"><a class="line" href="remmina__log_8c.html#a0c3592cad5a8e91cd4d0c3c1b2b1f427"> 88</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="l00089"></a><span class="lineno"> 89</span>&#160;{</div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160;}</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;<span class="comment">/* We will always only have one log window per instance */</span></div><div class="line"><a name="l00094"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a"> 94</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="l00095"></a><span class="lineno"> 95</span>&#160;</div><div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160;<span class="keyword">static</span> GtkWidget*</div><div class="line"><a name="l00097"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a070042aa580b708536dc793336722660"> 97</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="l00098"></a><span class="lineno"> 98</span>&#160;{</div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <span class="keywordflow">return</span> GTK_WIDGET(g_object_new(REMMINA_TYPE_LOG_WINDOW, NULL));</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160;}</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"><a class="line" href="remmina__log_8c.html#a355067bd2e33d8942ad9d8af60c19f0c"> 103</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="l00104"></a><span class="lineno"> 104</span>&#160;{</div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; <a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> = NULL;</div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160;}</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"><a class="line" href="remmina__log_8c.html#a8a5e75012fecec3ede5b29247760d5c3"> 109</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="l00110"></a><span class="lineno"> 110</span>&#160;{</div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</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="l00113"></a><span class="lineno"> 113</span>&#160;}</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"><a class="line" href="remmina__log_8h.html#a72cf53183f3ef89c4208fdccb629003d"> 115</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="l00116"></a><span class="lineno"> 116</span>&#160;{</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</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="l00119"></a><span class="lineno"> 119</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="l00120"></a><span class="lineno"> 120</span>&#160; }<span class="keywordflow">else</span> {</div><div class="line"><a name="l00121"></a><span class="lineno"> 121</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="l00122"></a><span class="lineno"> 122</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="l00123"></a><span class="lineno"> 123</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="l00124"></a><span class="lineno"> 124</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="l00125"></a><span class="lineno"> 125</span>&#160;</div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; <span class="comment">/* Header bar */</span></div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; GtkWidget *header = gtk_header_bar_new ();</div><div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; gtk_header_bar_set_show_close_button (GTK_HEADER_BAR (header), TRUE);</div><div class="line"><a name="l00129"></a><span class="lineno"> 129</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="l00130"></a><span class="lineno"> 130</span>&#160; gtk_header_bar_set_has_subtitle (GTK_HEADER_BAR (header), FALSE);</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; <span class="comment">/* Stats */</span></div><div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; GtkWidget *getstat = gtk_button_new ();</div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; gtk_widget_set_tooltip_text (getstat, _(<span class="stringliteral">&quot;Paste sytem info in the Remmina debugging window&quot;</span>));</div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; GIcon *icon = g_themed_icon_new (<span class="stringliteral">&quot;edit-paste-symbolic&quot;</span>);</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; GtkWidget *image = gtk_image_new_from_gicon (icon, GTK_ICON_SIZE_BUTTON);</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; g_object_unref (icon);</div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; gtk_container_add (GTK_CONTAINER (getstat), image);</div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; gtk_header_bar_pack_start (GTK_HEADER_BAR (header), getstat);</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160; <span class="comment">/* Start logging */</span></div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160; GtkWidget *start = gtk_switch_new ();</div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a> = TRUE;</div><div class="line"><a name="l00142"></a><span class="lineno"> 142</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="l00143"></a><span class="lineno"> 143</span>&#160; gtk_header_bar_pack_start (GTK_HEADER_BAR (header), start);</div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160;</div><div class="line"><a name="l00145"></a><span class="lineno"> 145</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="l00146"></a><span class="lineno"> 146</span>&#160;</div><div class="line"><a name="l00147"></a><span class="lineno"> 147</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="l00148"></a><span class="lineno"> 148</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="l00149"></a><span class="lineno"> 149</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="l00150"></a><span class="lineno"> 150</span>&#160; gtk_widget_show_all(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>);</div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; }</div><div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160;</div><div class="line"><a name="l00153"></a><span class="lineno"> 153</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="l00154"></a><span class="lineno"> 154</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="l00155"></a><span class="lineno"> 155</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="l00156"></a><span class="lineno"> 156</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="l00157"></a><span class="lineno"> 157</span>&#160; ));</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160;}</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"><a class="line" href="remmina__log_8h.html#a96f5bb72acbdcbf8793b4a5f4a6132b5"> 160</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="l00161"></a><span class="lineno"> 161</span>&#160;{</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</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="l00164"></a><span class="lineno"> 164</span>&#160;}</div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160;</div><div class="line"><a name="l00166"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a6a5cc60197293b97a0c6fa2a471b221b"> 166</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="l00167"></a><span class="lineno"> 167</span>&#160;{</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160; GtkTextIter iter;</div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span>&#160;</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</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="l00172"></a><span class="lineno"> 172</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="l00173"></a><span class="lineno"> 173</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="l00174"></a><span class="lineno"> 174</span>&#160; 0.0);</div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; }</div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160; <span class="keywordflow">return</span> FALSE;</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;</div><div class="line"><a name="l00179"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1"> 179</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="l00180"></a><span class="lineno"> 180</span>&#160;{</div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; GtkTextIter iter;</div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160;</div><div class="line"><a name="l00184"></a><span class="lineno"> 184</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="l00185"></a><span class="lineno"> 185</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="l00186"></a><span class="lineno"> 186</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="l00187"></a><span class="lineno"> 187</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="l00188"></a><span class="lineno"> 188</span>&#160; }</div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span>&#160; g_free(data);</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span>&#160; <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160;}</div><div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160;</div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160;<span class="comment">// Only prints into Remmina&#39;s own debug window. (Not stdout!)</span></div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160;<span class="comment">// See _remmina_{debug, info, error, critical, warning}</span></div><div class="line"><a name="l00195"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#aca8f826a273194e22f4467421af9b3aa"> 195</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="l00196"></a><span class="lineno"> 196</span>&#160;{</div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00198"></a><span class="lineno"> 198</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="l00199"></a><span class="lineno"> 199</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160;</div><div class="line"><a name="l00201"></a><span class="lineno"> 201</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="l00202"></a><span class="lineno"> 202</span>&#160;}</div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160;</div><div class="line"><a name="l00204"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a49817b70a398a2f21514fb0066c6e04c"> 204</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="l00205"></a><span class="lineno"> 205</span>&#160;{</div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160; g_autofree gchar *text;</div><div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160; va_end(args);</div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160;</div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160; g_info (<span class="stringliteral">&quot;%s&quot;</span>, text);</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>&#160;</div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(text, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(INFO) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160;</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</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="l00222"></a><span class="lineno"> 222</span>&#160; free(bufn);</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; }</div><div class="line"><a name="l00225"></a><span class="lineno"> 225</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="l00226"></a><span class="lineno"> 226</span>&#160;}</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160;</div><div class="line"><a name="l00228"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#ae439b5fb61045d22c9474b32d0158185"> 228</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="l00229"></a><span class="lineno"> 229</span>&#160;{</div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00233"></a><span class="lineno"> 233</span>&#160; g_autofree gchar *text;</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; va_end(args);</div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160;</div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; g_message (<span class="stringliteral">&quot;%s&quot;</span>, text);</div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160;</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</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="l00242"></a><span class="lineno"> 242</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span>&#160; }</div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span>&#160;</div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(text, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00246"></a><span class="lineno"> 246</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(MESSAGE) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160;</div><div class="line"><a name="l00249"></a><span class="lineno"> 249</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="l00250"></a><span class="lineno"> 250</span>&#160;}</div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160;</div><div class="line"><a name="l00257"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a9234814488626cc2513e9fb255a90f53"> 257</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="l00258"></a><span class="lineno"> 258</span>&#160;{</div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160; gchar *text;</div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00265"></a><span class="lineno"> 265</span>&#160; va_end(args);</div><div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160;</div><div class="line"><a name="l00267"></a><span class="lineno"> 267</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="l00268"></a><span class="lineno"> 268</span>&#160; g_free(text);</div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span>&#160;</div><div class="line"><a name="l00270"></a><span class="lineno"> 270</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span>&#160; g_debug (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160;</div><div class="line"><a name="l00273"></a><span class="lineno"> 273</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="l00274"></a><span class="lineno"> 274</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00275"></a><span class="lineno"> 275</span>&#160; }</div><div class="line"><a name="l00276"></a><span class="lineno"> 276</span>&#160;</div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00278"></a><span class="lineno"> 278</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(DEBUG) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00280"></a><span class="lineno"> 280</span>&#160;</div><div class="line"><a name="l00281"></a><span class="lineno"> 281</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="l00282"></a><span class="lineno"> 282</span>&#160;}</div><div class="line"><a name="l00283"></a><span class="lineno"> 283</span>&#160;</div><div class="line"><a name="l00284"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a8a47ecac307ae1787cdad1ccc4b43d13"> 284</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="l00285"></a><span class="lineno"> 285</span>&#160;{</div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00289"></a><span class="lineno"> 289</span>&#160; gchar *text;</div><div class="line"><a name="l00290"></a><span class="lineno"> 290</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00291"></a><span class="lineno"> 291</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00292"></a><span class="lineno"> 292</span>&#160; va_end(args);</div><div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160;</div><div class="line"><a name="l00294"></a><span class="lineno"> 294</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="l00295"></a><span class="lineno"> 295</span>&#160; g_free(text);</div><div class="line"><a name="l00296"></a><span class="lineno"> 296</span>&#160;</div><div class="line"><a name="l00297"></a><span class="lineno"> 297</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160; g_warning (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00299"></a><span class="lineno"> 299</span>&#160;</div><div class="line"><a name="l00300"></a><span class="lineno"> 300</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="l00301"></a><span class="lineno"> 301</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00302"></a><span class="lineno"> 302</span>&#160; }</div><div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160;</div><div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00305"></a><span class="lineno"> 305</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00306"></a><span class="lineno"> 306</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(WARN) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00307"></a><span class="lineno"> 307</span>&#160;</div><div class="line"><a name="l00308"></a><span class="lineno"> 308</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="l00309"></a><span class="lineno"> 309</span>&#160;}</div><div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160;</div><div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160;<span class="comment">// !!! Calling this function will crash Remmina !!!</span></div><div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160;<span class="comment">// !!! purposefully and send a trap signal !!!</span></div><div class="line"><a name="l00313"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a984e0494481144aa121893f5d14025f7"> 313</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="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;</div><div class="line"><a name="l00317"></a><span class="lineno"> 317</span>&#160; va_list args;</div><div class="line"><a name="l00318"></a><span class="lineno"> 318</span>&#160; gchar *text;</div><div class="line"><a name="l00319"></a><span class="lineno"> 319</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00321"></a><span class="lineno"> 321</span>&#160; va_end(args);</div><div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160;</div><div class="line"><a name="l00323"></a><span class="lineno"> 323</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="l00324"></a><span class="lineno"> 324</span>&#160; g_free(text);</div><div class="line"><a name="l00325"></a><span class="lineno"> 325</span>&#160;</div><div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00327"></a><span class="lineno"> 327</span>&#160; g_error (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160;</div><div class="line"><a name="l00329"></a><span class="lineno"> 329</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="l00330"></a><span class="lineno"> 330</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00331"></a><span class="lineno"> 331</span>&#160; }</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; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00334"></a><span class="lineno"> 334</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00335"></a><span class="lineno"> 335</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(ERROR) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00336"></a><span class="lineno"> 336</span>&#160;</div><div class="line"><a name="l00337"></a><span class="lineno"> 337</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="l00338"></a><span class="lineno"> 338</span>&#160;}</div><div class="line"><a name="l00339"></a><span class="lineno"> 339</span>&#160;</div><div class="line"><a name="l00340"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a35109f5950931f79c13dac26143a69d3"> 340</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="l00341"></a><span class="lineno"> 341</span>&#160;{</div><div class="line"><a name="l00342"></a><span class="lineno"> 342</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00345"></a><span class="lineno"> 345</span>&#160; gchar *text;</div><div class="line"><a name="l00346"></a><span class="lineno"> 346</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00347"></a><span class="lineno"> 347</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00348"></a><span class="lineno"> 348</span>&#160; va_end(args);</div><div class="line"><a name="l00349"></a><span class="lineno"> 349</span>&#160;</div><div class="line"><a name="l00350"></a><span class="lineno"> 350</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="l00351"></a><span class="lineno"> 351</span>&#160; g_free(text);</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">// always appends newline</span></div><div class="line"><a name="l00354"></a><span class="lineno"> 354</span>&#160; g_critical (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00355"></a><span class="lineno"> 355</span>&#160;</div><div class="line"><a name="l00356"></a><span class="lineno"> 356</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="l00357"></a><span class="lineno"> 357</span>&#160; <span class="keywordflow">return</span>;</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;</div><div class="line"><a name="l00360"></a><span class="lineno"> 360</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00361"></a><span class="lineno"> 361</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00362"></a><span class="lineno"> 362</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(CRIT) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00363"></a><span class="lineno"> 363</span>&#160;</div><div class="line"><a name="l00364"></a><span class="lineno"> 364</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="l00365"></a><span class="lineno"> 365</span>&#160;}</div><div class="line"><a name="l00366"></a><span class="lineno"> 366</span>&#160;</div><div class="line"><a name="l00367"></a><span class="lineno"> 367</span>&#160;<span class="comment">// Only prints into Remmina&#39;s own debug window. (Not stdout!)</span></div><div class="line"><a name="l00368"></a><span class="lineno"> 368</span>&#160;<span class="comment">// See _remmina_{message, info, debug warning, error, critical}</span></div><div class="line"><a name="l00369"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#ac7848510c1fe1990c992e28cd31af9d8"> 369</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="l00370"></a><span class="lineno"> 370</span>&#160;{</div><div class="line"><a name="l00371"></a><span class="lineno"> 371</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00372"></a><span class="lineno"> 372</span>&#160; va_list args;</div><div class="line"><a name="l00373"></a><span class="lineno"> 373</span>&#160; gchar *text;</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; <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="l00376"></a><span class="lineno"> 376</span>&#160;</div><div class="line"><a name="l00377"></a><span class="lineno"> 377</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00378"></a><span class="lineno"> 378</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00379"></a><span class="lineno"> 379</span>&#160; va_end(args);</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; IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, text);</div><div class="line"><a name="l00382"></a><span class="lineno"> 382</span>&#160;}</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"><a class="line" href="remmina__log_8c.html#a43a42f51f64b54924564e166c56b39e1"> 384</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="l00385"></a><span class="lineno"> 385</span>&#160;{</div><div class="line"><a name="l00386"></a><span class="lineno"> 386</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00387"></a><span class="lineno"> 387</span>&#160;</div><div class="line"><a name="l00388"></a><span class="lineno"> 388</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="l00389"></a><span class="lineno"> 389</span>&#160; <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00390"></a><span class="lineno"> 390</span>&#160;</div><div class="line"><a name="l00391"></a><span class="lineno"> 391</span>&#160; GdkEventKey *e = (GdkEventKey *)event;</div><div class="line"><a name="l00392"></a><span class="lineno"> 392</span>&#160;</div><div class="line"><a name="l00393"></a><span class="lineno"> 393</span>&#160; <span class="keywordflow">if</span> ((e-&gt;state &amp; GDK_CONTROL_MASK) == GDK_CONTROL_MASK) {</div><div class="line"><a name="l00394"></a><span class="lineno"> 394</span>&#160; <span class="keywordflow">if</span> (e-&gt;keyval == GDK_KEY_t) {</div><div class="line"><a name="l00395"></a><span class="lineno"> 395</span>&#160; remmina_log_stats();</div><div class="line"><a name="l00396"></a><span class="lineno"> 396</span>&#160; }</div><div class="line"><a name="l00397"></a><span class="lineno"> 397</span>&#160; <span class="keywordflow">return</span> TRUE;</div><div class="line"><a name="l00398"></a><span class="lineno"> 398</span>&#160; }</div><div class="line"><a name="l00399"></a><span class="lineno"> 399</span>&#160;</div><div class="line"><a name="l00400"></a><span class="lineno"> 400</span>&#160; <span class="keywordflow">return</span> FALSE;</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;</div><div class="line"><a name="l00403"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a1e5960f194353bd36d82bd9476c309bd"> 403</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="l00404"></a><span class="lineno"> 404</span>&#160;{</div><div class="line"><a name="l00405"></a><span class="lineno"> 405</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00406"></a><span class="lineno"> 406</span>&#160; GtkWidget *scrolledwindow;</div><div class="line"><a name="l00407"></a><span class="lineno"> 407</span>&#160; GtkWidget *widget;</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; gtk_container_set_border_width(GTK_CONTAINER(logwin), 4);</div><div class="line"><a name="l00410"></a><span class="lineno"> 410</span>&#160;</div><div class="line"><a name="l00411"></a><span class="lineno"> 411</span>&#160; scrolledwindow = gtk_scrolled_window_new(NULL, NULL);</div><div class="line"><a name="l00412"></a><span class="lineno"> 412</span>&#160; gtk_widget_show(scrolledwindow);</div><div class="line"><a name="l00413"></a><span class="lineno"> 413</span>&#160; gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS);</div><div class="line"><a name="l00414"></a><span class="lineno"> 414</span>&#160; gtk_container_add(GTK_CONTAINER(logwin), scrolledwindow);</div><div class="line"><a name="l00415"></a><span class="lineno"> 415</span>&#160;</div><div class="line"><a name="l00416"></a><span class="lineno"> 416</span>&#160; widget = gtk_text_view_new();</div><div class="line"><a name="l00417"></a><span class="lineno"> 417</span>&#160; gtk_widget_show(widget);</div><div class="line"><a name="l00418"></a><span class="lineno"> 418</span>&#160; gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(widget), GTK_WRAP_WORD_CHAR);</div><div class="line"><a name="l00419"></a><span class="lineno"> 419</span>&#160; gtk_text_view_set_editable(GTK_TEXT_VIEW(widget), FALSE);</div><div class="line"><a name="l00420"></a><span class="lineno"> 420</span>&#160; gtk_text_view_set_monospace(GTK_TEXT_VIEW(widget), TRUE);</div><div class="line"><a name="l00421"></a><span class="lineno"> 421</span>&#160; gtk_container_add(GTK_CONTAINER(scrolledwindow), widget);</div><div class="line"><a name="l00422"></a><span class="lineno"> 422</span>&#160; logwin-&gt;<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a> = widget;</div><div class="line"><a name="l00423"></a><span class="lineno"> 423</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="l00424"></a><span class="lineno"> 424</span>&#160;</div><div class="line"><a name="l00425"></a><span class="lineno"> 425</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="l00426"></a><span class="lineno"> 426</span>&#160;}</div><div class="line"><a name="l00427"></a><span class="lineno"> 427</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#l00115">remmina_log.c:115</a></div></div>
+<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-2022 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__log_8h.html">remmina_log.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__stats_8h.html">remmina_stats.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__trace__calls_8h.html">remmina/remmina_trace_calls.h</a>&quot;</span></div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;</div><div class="line"><a name="l00044"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0"> 44</a></span>&#160;gboolean <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a>;</div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;</div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160;<span class="comment">/***** Define the log window GUI *****/</span></div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;<span class="preprocessor">#define REMMINA_TYPE_LOG_WINDOW (remmina_log_window_get_type())</span></div><div class="line"><a name="l00048"></a><span class="lineno"> 48</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="l00049"></a><span class="lineno"> 49</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="l00050"></a><span class="lineno"> 50</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="l00051"></a><span class="lineno"> 51</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="l00052"></a><span class="lineno"> 52</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="l00053"></a><span class="lineno"> 53</span>&#160;</div><div class="line"><a name="l00054"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html"> 54</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="l00055"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184"> 55</a></span>&#160; GtkWindow <a class="code" href="struct___remmina_log_window.html#ae287dadd2c2a5bf704d7c494bcc74184">window</a>;</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160;</div><div class="line"><a name="l00057"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087"> 57</a></span>&#160; GtkWidget *<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a>;</div><div class="line"><a name="l00058"></a><span class="lineno"><a class="line" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232"> 58</a></span>&#160; GtkTextBuffer *<a class="code" href="struct___remmina_log_window.html#a06774ea75d0ea07580555d34abbb8232">log_buffer</a>;</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160;} <a class="code" href="remmina__log_8c.html#ad5a920aad512279bb932bcb26a2c3c19">RemminaLogWindow</a>;</div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160;</div><div class="line"><a name="l00061"></a><span class="lineno"><a class="line" href="struct___remmina_log_window_class.html"> 61</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="l00062"></a><span class="lineno"><a class="line" href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af"> 62</a></span>&#160; GtkWindowClass <a class="code" href="struct___remmina_log_window_class.html#af63588f4d71726fcda17ae5c2adcf2af">parent_class</a>;</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160;} <a class="code" href="remmina__log_8c.html#a5682db89dd84e1c413326e17a4f79dbe">RemminaLogWindowClass</a>;</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160;</div><div class="line"><a name="l00065"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a8f8d45cce779ec2a8db7bfdd02097a3e"> 65</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="l00066"></a><span class="lineno"> 66</span>&#160;G_GNUC_CONST;</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160;</div><div class="line"><a name="l00068"></a><span class="lineno"> 68</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="l00069"></a><span class="lineno"> 69</span>&#160;</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160;<span class="keywordtype">void</span> remmina_log_stats()</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160;{</div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; JsonNode *n;</div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160;</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; n = <a class="code" href="remmina__stats_8c.html#a7398b36347e3621772776c466b565641">remmina_stats_get_all</a>();</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keywordflow">if</span> (n != NULL) {</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160;</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; JsonGenerator *g = json_generator_new();</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; json_generator_set_pretty (g, TRUE);</div><div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; json_generator_set_root(g, n);</div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; json_node_unref(n);</div><div class="line"><a name="l00082"></a><span class="lineno"> 82</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="l00083"></a><span class="lineno"> 83</span>&#160; REMMINA_DEBUG(<span class="stringliteral">&quot;STATS: JSON data%s\n&quot;</span>, s);</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; g_object_unref(g);</div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; }</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"><a class="line" href="remmina__log_8c.html#a0c3592cad5a8e91cd4d0c3c1b2b1f427"> 88</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="l00089"></a><span class="lineno"> 89</span>&#160;{</div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160;}</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;<span class="comment">/* We will always only have one log window per instance */</span></div><div class="line"><a name="l00094"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a"> 94</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="l00095"></a><span class="lineno"> 95</span>&#160;</div><div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160;<span class="keyword">static</span> GtkWidget*</div><div class="line"><a name="l00097"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a070042aa580b708536dc793336722660"> 97</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="l00098"></a><span class="lineno"> 98</span>&#160;{</div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <span class="keywordflow">return</span> GTK_WIDGET(g_object_new(REMMINA_TYPE_LOG_WINDOW, NULL));</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160;}</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"><a class="line" href="remmina__log_8c.html#a355067bd2e33d8942ad9d8af60c19f0c"> 103</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="l00104"></a><span class="lineno"> 104</span>&#160;{</div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; <a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a> = NULL;</div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160;}</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"><a class="line" href="remmina__log_8c.html#a8a5e75012fecec3ede5b29247760d5c3"> 109</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="l00110"></a><span class="lineno"> 110</span>&#160;{</div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</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="l00113"></a><span class="lineno"> 113</span>&#160;}</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"><a class="line" href="remmina__log_8h.html#a72cf53183f3ef89c4208fdccb629003d"> 115</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="l00116"></a><span class="lineno"> 116</span>&#160;{</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</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="l00119"></a><span class="lineno"> 119</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="l00120"></a><span class="lineno"> 120</span>&#160; }<span class="keywordflow">else</span> {</div><div class="line"><a name="l00121"></a><span class="lineno"> 121</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="l00122"></a><span class="lineno"> 122</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="l00123"></a><span class="lineno"> 123</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="l00124"></a><span class="lineno"> 124</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="l00125"></a><span class="lineno"> 125</span>&#160;</div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; <span class="comment">/* Header bar */</span></div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; GtkWidget *header = gtk_header_bar_new ();</div><div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; gtk_header_bar_set_show_close_button (GTK_HEADER_BAR (header), TRUE);</div><div class="line"><a name="l00129"></a><span class="lineno"> 129</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="l00130"></a><span class="lineno"> 130</span>&#160; gtk_header_bar_set_has_subtitle (GTK_HEADER_BAR (header), FALSE);</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; <span class="comment">/* Stats */</span></div><div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; GtkWidget *getstat = gtk_button_new ();</div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; gtk_widget_set_tooltip_text (getstat, _(<span class="stringliteral">&quot;Paste sytem info in the Remmina debugging window&quot;</span>));</div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; GIcon *icon = g_themed_icon_new (<span class="stringliteral">&quot;edit-paste-symbolic&quot;</span>);</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; GtkWidget *image = gtk_image_new_from_gicon (icon, GTK_ICON_SIZE_BUTTON);</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; g_object_unref (icon);</div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; gtk_container_add (GTK_CONTAINER (getstat), image);</div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; gtk_header_bar_pack_start (GTK_HEADER_BAR (header), getstat);</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160; <span class="comment">/* Start logging */</span></div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160; GtkWidget *start = gtk_switch_new ();</div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; <a class="code" href="remmina__log_8c.html#a973ea192c9eb7562f0590e62d95ba0e0">logstart</a> = TRUE;</div><div class="line"><a name="l00142"></a><span class="lineno"> 142</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="l00143"></a><span class="lineno"> 143</span>&#160; gtk_header_bar_pack_start (GTK_HEADER_BAR (header), start);</div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160;</div><div class="line"><a name="l00145"></a><span class="lineno"> 145</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="l00146"></a><span class="lineno"> 146</span>&#160;</div><div class="line"><a name="l00147"></a><span class="lineno"> 147</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="l00148"></a><span class="lineno"> 148</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="l00149"></a><span class="lineno"> 149</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="l00150"></a><span class="lineno"> 150</span>&#160; gtk_widget_show_all(<a class="code" href="remmina__log_8c.html#a6c06467e9ec98a4ccc6645291cd5d19a">log_window</a>);</div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; }</div><div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160;</div><div class="line"><a name="l00153"></a><span class="lineno"> 153</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="l00154"></a><span class="lineno"> 154</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="l00155"></a><span class="lineno"> 155</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="l00156"></a><span class="lineno"> 156</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="l00157"></a><span class="lineno"> 157</span>&#160; ));</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160;}</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"><a class="line" href="remmina__log_8h.html#a96f5bb72acbdcbf8793b4a5f4a6132b5"> 160</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="l00161"></a><span class="lineno"> 161</span>&#160;{</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</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="l00164"></a><span class="lineno"> 164</span>&#160;}</div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160;</div><div class="line"><a name="l00166"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a6a5cc60197293b97a0c6fa2a471b221b"> 166</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="l00167"></a><span class="lineno"> 167</span>&#160;{</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160; GtkTextIter iter;</div><div class="line"><a name="l00170"></a><span class="lineno"> 170</span>&#160;</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</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="l00172"></a><span class="lineno"> 172</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="l00173"></a><span class="lineno"> 173</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="l00174"></a><span class="lineno"> 174</span>&#160; 0.0);</div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; }</div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160; <span class="keywordflow">return</span> FALSE;</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;</div><div class="line"><a name="l00179"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1"> 179</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="l00180"></a><span class="lineno"> 180</span>&#160;{</div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; GtkTextIter iter;</div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160;</div><div class="line"><a name="l00184"></a><span class="lineno"> 184</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="l00185"></a><span class="lineno"> 185</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="l00186"></a><span class="lineno"> 186</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="l00187"></a><span class="lineno"> 187</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="l00188"></a><span class="lineno"> 188</span>&#160; }</div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span>&#160; g_free(data);</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span>&#160; <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160;}</div><div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160;</div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160;<span class="comment">// Only prints into Remmina&#39;s own debug window. (Not stdout!)</span></div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160;<span class="comment">// See _remmina_{debug, info, error, critical, warning}</span></div><div class="line"><a name="l00195"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#aca8f826a273194e22f4467421af9b3aa"> 195</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="l00196"></a><span class="lineno"> 196</span>&#160;{</div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00198"></a><span class="lineno"> 198</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="l00199"></a><span class="lineno"> 199</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160;</div><div class="line"><a name="l00201"></a><span class="lineno"> 201</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="l00202"></a><span class="lineno"> 202</span>&#160;}</div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160;</div><div class="line"><a name="l00204"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a49817b70a398a2f21514fb0066c6e04c"> 204</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="l00205"></a><span class="lineno"> 205</span>&#160;{</div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160; g_autofree gchar *text;</div><div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160; va_end(args);</div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160;</div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160; g_info (<span class="stringliteral">&quot;%s&quot;</span>, text);</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>&#160;</div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(text, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(INFO) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160;</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</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="l00222"></a><span class="lineno"> 222</span>&#160; free(bufn);</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; }</div><div class="line"><a name="l00225"></a><span class="lineno"> 225</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="l00226"></a><span class="lineno"> 226</span>&#160;}</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160;</div><div class="line"><a name="l00228"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#ae439b5fb61045d22c9474b32d0158185"> 228</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="l00229"></a><span class="lineno"> 229</span>&#160;{</div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00233"></a><span class="lineno"> 233</span>&#160; g_autofree gchar *text;</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; va_end(args);</div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160;</div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; g_message (<span class="stringliteral">&quot;%s&quot;</span>, text);</div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160;</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</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="l00242"></a><span class="lineno"> 242</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span>&#160; }</div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span>&#160;</div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(text, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00246"></a><span class="lineno"> 246</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(MESSAGE) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160;</div><div class="line"><a name="l00249"></a><span class="lineno"> 249</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="l00250"></a><span class="lineno"> 250</span>&#160;}</div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160;</div><div class="line"><a name="l00257"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a9234814488626cc2513e9fb255a90f53"> 257</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="l00258"></a><span class="lineno"> 258</span>&#160;{</div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160; gchar *text;</div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00265"></a><span class="lineno"> 265</span>&#160; va_end(args);</div><div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160;</div><div class="line"><a name="l00267"></a><span class="lineno"> 267</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="l00268"></a><span class="lineno"> 268</span>&#160; g_free(text);</div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span>&#160;</div><div class="line"><a name="l00270"></a><span class="lineno"> 270</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span>&#160; g_debug (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160;</div><div class="line"><a name="l00273"></a><span class="lineno"> 273</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="l00274"></a><span class="lineno"> 274</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00275"></a><span class="lineno"> 275</span>&#160; }</div><div class="line"><a name="l00276"></a><span class="lineno"> 276</span>&#160;</div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00278"></a><span class="lineno"> 278</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(DEBUG) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00280"></a><span class="lineno"> 280</span>&#160;</div><div class="line"><a name="l00281"></a><span class="lineno"> 281</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="l00282"></a><span class="lineno"> 282</span>&#160;}</div><div class="line"><a name="l00283"></a><span class="lineno"> 283</span>&#160;</div><div class="line"><a name="l00284"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a8a47ecac307ae1787cdad1ccc4b43d13"> 284</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="l00285"></a><span class="lineno"> 285</span>&#160;{</div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00289"></a><span class="lineno"> 289</span>&#160; gchar *text;</div><div class="line"><a name="l00290"></a><span class="lineno"> 290</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00291"></a><span class="lineno"> 291</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00292"></a><span class="lineno"> 292</span>&#160; va_end(args);</div><div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160;</div><div class="line"><a name="l00294"></a><span class="lineno"> 294</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="l00295"></a><span class="lineno"> 295</span>&#160; g_free(text);</div><div class="line"><a name="l00296"></a><span class="lineno"> 296</span>&#160;</div><div class="line"><a name="l00297"></a><span class="lineno"> 297</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160; g_warning (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00299"></a><span class="lineno"> 299</span>&#160;</div><div class="line"><a name="l00300"></a><span class="lineno"> 300</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="l00301"></a><span class="lineno"> 301</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00302"></a><span class="lineno"> 302</span>&#160; }</div><div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160;</div><div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00305"></a><span class="lineno"> 305</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00306"></a><span class="lineno"> 306</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(WARN) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00307"></a><span class="lineno"> 307</span>&#160;</div><div class="line"><a name="l00308"></a><span class="lineno"> 308</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="l00309"></a><span class="lineno"> 309</span>&#160;}</div><div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160;</div><div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160;<span class="comment">// !!! Calling this function will crash Remmina !!!</span></div><div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160;<span class="comment">// !!! purposefully and send a trap signal !!!</span></div><div class="line"><a name="l00313"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a984e0494481144aa121893f5d14025f7"> 313</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="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;</div><div class="line"><a name="l00317"></a><span class="lineno"> 317</span>&#160; va_list args;</div><div class="line"><a name="l00318"></a><span class="lineno"> 318</span>&#160; gchar *text;</div><div class="line"><a name="l00319"></a><span class="lineno"> 319</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00321"></a><span class="lineno"> 321</span>&#160; va_end(args);</div><div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160;</div><div class="line"><a name="l00323"></a><span class="lineno"> 323</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="l00324"></a><span class="lineno"> 324</span>&#160; g_free(text);</div><div class="line"><a name="l00325"></a><span class="lineno"> 325</span>&#160;</div><div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160; <span class="comment">// always appends newline</span></div><div class="line"><a name="l00327"></a><span class="lineno"> 327</span>&#160; g_error (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160;</div><div class="line"><a name="l00329"></a><span class="lineno"> 329</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="l00330"></a><span class="lineno"> 330</span>&#160; <span class="keywordflow">return</span>;</div><div class="line"><a name="l00331"></a><span class="lineno"> 331</span>&#160; }</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; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00334"></a><span class="lineno"> 334</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00335"></a><span class="lineno"> 335</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(ERROR) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00336"></a><span class="lineno"> 336</span>&#160;</div><div class="line"><a name="l00337"></a><span class="lineno"> 337</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="l00338"></a><span class="lineno"> 338</span>&#160;}</div><div class="line"><a name="l00339"></a><span class="lineno"> 339</span>&#160;</div><div class="line"><a name="l00340"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#a35109f5950931f79c13dac26143a69d3"> 340</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="l00341"></a><span class="lineno"> 341</span>&#160;{</div><div class="line"><a name="l00342"></a><span class="lineno"> 342</span>&#160; TRACE_CALL(__func__);</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; va_list args;</div><div class="line"><a name="l00345"></a><span class="lineno"> 345</span>&#160; gchar *text;</div><div class="line"><a name="l00346"></a><span class="lineno"> 346</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00347"></a><span class="lineno"> 347</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00348"></a><span class="lineno"> 348</span>&#160; va_end(args);</div><div class="line"><a name="l00349"></a><span class="lineno"> 349</span>&#160;</div><div class="line"><a name="l00350"></a><span class="lineno"> 350</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="l00351"></a><span class="lineno"> 351</span>&#160; g_free(text);</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">// always appends newline</span></div><div class="line"><a name="l00354"></a><span class="lineno"> 354</span>&#160; g_critical (<span class="stringliteral">&quot;%s&quot;</span>, buf);</div><div class="line"><a name="l00355"></a><span class="lineno"> 355</span>&#160;</div><div class="line"><a name="l00356"></a><span class="lineno"> 356</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="l00357"></a><span class="lineno"> 357</span>&#160; <span class="keywordflow">return</span>;</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;</div><div class="line"><a name="l00360"></a><span class="lineno"> 360</span>&#160; g_autofree gchar *buf_tmp = g_strconcat(buf, <span class="stringliteral">&quot;\n&quot;</span>, NULL);</div><div class="line"><a name="l00361"></a><span class="lineno"> 361</span>&#160; <span class="comment">/* freed in remmina_log_print_real */</span></div><div class="line"><a name="l00362"></a><span class="lineno"> 362</span>&#160; gchar *bufn = g_strconcat(<span class="stringliteral">&quot;(CRIT) - &quot;</span>, buf_tmp, NULL);</div><div class="line"><a name="l00363"></a><span class="lineno"> 363</span>&#160;</div><div class="line"><a name="l00364"></a><span class="lineno"> 364</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="l00365"></a><span class="lineno"> 365</span>&#160;}</div><div class="line"><a name="l00366"></a><span class="lineno"> 366</span>&#160;</div><div class="line"><a name="l00367"></a><span class="lineno"> 367</span>&#160;<span class="comment">// Only prints into Remmina&#39;s own debug window. (Not stdout!)</span></div><div class="line"><a name="l00368"></a><span class="lineno"> 368</span>&#160;<span class="comment">// See _remmina_{message, info, debug warning, error, critical}</span></div><div class="line"><a name="l00369"></a><span class="lineno"><a class="line" href="remmina__log_8h.html#ac7848510c1fe1990c992e28cd31af9d8"> 369</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="l00370"></a><span class="lineno"> 370</span>&#160;{</div><div class="line"><a name="l00371"></a><span class="lineno"> 371</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00372"></a><span class="lineno"> 372</span>&#160; va_list args;</div><div class="line"><a name="l00373"></a><span class="lineno"> 373</span>&#160; gchar *text;</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; <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="l00376"></a><span class="lineno"> 376</span>&#160;</div><div class="line"><a name="l00377"></a><span class="lineno"> 377</span>&#160; va_start(args, fmt);</div><div class="line"><a name="l00378"></a><span class="lineno"> 378</span>&#160; text = g_strdup_vprintf(fmt, args);</div><div class="line"><a name="l00379"></a><span class="lineno"> 379</span>&#160; va_end(args);</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; IDLE_ADD(<a class="code" href="remmina__log_8c.html#a7cbb8cc1b0525ae49248a84fb4b2b1a1">remmina_log_print_real</a>, text);</div><div class="line"><a name="l00382"></a><span class="lineno"> 382</span>&#160;}</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"><a class="line" href="remmina__log_8c.html#a43a42f51f64b54924564e166c56b39e1"> 384</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="l00385"></a><span class="lineno"> 385</span>&#160;{</div><div class="line"><a name="l00386"></a><span class="lineno"> 386</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00387"></a><span class="lineno"> 387</span>&#160;</div><div class="line"><a name="l00388"></a><span class="lineno"> 388</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="l00389"></a><span class="lineno"> 389</span>&#160; <span class="keywordflow">return</span> FALSE;</div><div class="line"><a name="l00390"></a><span class="lineno"> 390</span>&#160;</div><div class="line"><a name="l00391"></a><span class="lineno"> 391</span>&#160; GdkEventKey *e = (GdkEventKey *)event;</div><div class="line"><a name="l00392"></a><span class="lineno"> 392</span>&#160;</div><div class="line"><a name="l00393"></a><span class="lineno"> 393</span>&#160; <span class="keywordflow">if</span> ((e-&gt;state &amp; GDK_CONTROL_MASK) == GDK_CONTROL_MASK) {</div><div class="line"><a name="l00394"></a><span class="lineno"> 394</span>&#160; <span class="keywordflow">if</span> (e-&gt;keyval == GDK_KEY_t) {</div><div class="line"><a name="l00395"></a><span class="lineno"> 395</span>&#160; remmina_log_stats();</div><div class="line"><a name="l00396"></a><span class="lineno"> 396</span>&#160; }</div><div class="line"><a name="l00397"></a><span class="lineno"> 397</span>&#160; <span class="keywordflow">return</span> TRUE;</div><div class="line"><a name="l00398"></a><span class="lineno"> 398</span>&#160; }</div><div class="line"><a name="l00399"></a><span class="lineno"> 399</span>&#160;</div><div class="line"><a name="l00400"></a><span class="lineno"> 400</span>&#160; <span class="keywordflow">return</span> FALSE;</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;</div><div class="line"><a name="l00403"></a><span class="lineno"><a class="line" href="remmina__log_8c.html#a1e5960f194353bd36d82bd9476c309bd"> 403</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="l00404"></a><span class="lineno"> 404</span>&#160;{</div><div class="line"><a name="l00405"></a><span class="lineno"> 405</span>&#160; TRACE_CALL(__func__);</div><div class="line"><a name="l00406"></a><span class="lineno"> 406</span>&#160; GtkWidget *scrolledwindow;</div><div class="line"><a name="l00407"></a><span class="lineno"> 407</span>&#160; GtkWidget *widget;</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; gtk_container_set_border_width(GTK_CONTAINER(logwin), 4);</div><div class="line"><a name="l00410"></a><span class="lineno"> 410</span>&#160;</div><div class="line"><a name="l00411"></a><span class="lineno"> 411</span>&#160; scrolledwindow = gtk_scrolled_window_new(NULL, NULL);</div><div class="line"><a name="l00412"></a><span class="lineno"> 412</span>&#160; gtk_widget_show(scrolledwindow);</div><div class="line"><a name="l00413"></a><span class="lineno"> 413</span>&#160; gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow), GTK_POLICY_NEVER, GTK_POLICY_ALWAYS);</div><div class="line"><a name="l00414"></a><span class="lineno"> 414</span>&#160; gtk_container_add(GTK_CONTAINER(logwin), scrolledwindow);</div><div class="line"><a name="l00415"></a><span class="lineno"> 415</span>&#160;</div><div class="line"><a name="l00416"></a><span class="lineno"> 416</span>&#160; widget = gtk_text_view_new();</div><div class="line"><a name="l00417"></a><span class="lineno"> 417</span>&#160; gtk_widget_show(widget);</div><div class="line"><a name="l00418"></a><span class="lineno"> 418</span>&#160; gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(widget), GTK_WRAP_WORD_CHAR);</div><div class="line"><a name="l00419"></a><span class="lineno"> 419</span>&#160; gtk_text_view_set_editable(GTK_TEXT_VIEW(widget), FALSE);</div><div class="line"><a name="l00420"></a><span class="lineno"> 420</span>&#160; gtk_text_view_set_monospace(GTK_TEXT_VIEW(widget), TRUE);</div><div class="line"><a name="l00421"></a><span class="lineno"> 421</span>&#160; gtk_container_add(GTK_CONTAINER(scrolledwindow), widget);</div><div class="line"><a name="l00422"></a><span class="lineno"> 422</span>&#160; logwin-&gt;<a class="code" href="struct___remmina_log_window.html#abfbb6314130ad100aba258087d9d4087">log_view</a> = widget;</div><div class="line"><a name="l00423"></a><span class="lineno"> 423</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="l00424"></a><span class="lineno"> 424</span>&#160;</div><div class="line"><a name="l00425"></a><span class="lineno"> 425</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="l00426"></a><span class="lineno"> 426</span>&#160;}</div><div class="line"><a name="l00427"></a><span class="lineno"> 427</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#l00115">remmina_log.c:115</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#l00044">remmina_log.c:44</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#l00055">remmina_log.c:55</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#l00340">remmina_log.c:340</a></div></div>