summaryrefslogtreecommitdiff
path: root/docs/CAmDbusWrapper_8cpp_source.html
blob: 63d91df492cb03d22c0ade78e0514b0f02163ec5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.11"/>
<title>AudioManager: AudioManagerUtilities/src/CAmDbusWrapper.cpp Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
  $(document).ready(initResizable);
  $(window).load(resizeHeight);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
  $(document).ready(function() { init_search(); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">AudioManager
   &#160;<span id="projectnumber">7.6.6</span>
   </div>
   <div id="projectbrief">Native Application Runtime Environment</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.11 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li><a href="annotated.html"><span>Classes</span></a></li>
      <li class="current"><a href="files.html"><span>Files</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
        <span class="left">
          <img id="MSearchSelect" src="search/mag_sel.png"
               onmouseover="return searchBox.OnSearchSelectShow()"
               onmouseout="return searchBox.OnSearchSelectHide()"
               alt=""/>
          <input type="text" id="MSearchField" value="Search" accesskey="S"
               onfocus="searchBox.OnSearchFieldFocus(true)" 
               onblur="searchBox.OnSearchFieldFocus(false)" 
               onkeyup="searchBox.OnSearchFieldChange(event)"/>
          </span><span class="right">
            <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
          </span>
        </div>
      </li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="files.html"><span>File&#160;List</span></a></li>
      <li><a href="globals.html"><span>File&#160;Members</span></a></li>
    </ul>
  </div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
      <div id="nav-sync" class="sync"></div>
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('CAmDbusWrapper_8cpp_source.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<div class="header">
  <div class="headertitle">
<div class="title">CAmDbusWrapper.cpp</div>  </div>
</div><!--header-->
<div class="contents">
<a href="CAmDbusWrapper_8cpp.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;</div><div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="CAmDbusWrapper_8h.html">CAmDbusWrapper.h</a>&quot;</span></div><div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;<span class="preprocessor">#include &lt;audiomanagerconfig.h&gt;</span></div><div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span class="preprocessor">#include &lt;fstream&gt;</span></div><div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;<span class="preprocessor">#include &lt;sstream&gt;</span></div><div class="line"><a name="l00028"></a><span class="lineno">   28</span>&#160;<span class="preprocessor">#include &lt;string&gt;</span></div><div class="line"><a name="l00029"></a><span class="lineno">   29</span>&#160;<span class="preprocessor">#include &lt;cassert&gt;</span></div><div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="preprocessor">#include &lt;cstdlib&gt;</span></div><div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;<span class="preprocessor">#include &lt;stdexcept&gt;</span></div><div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="CAmDltWrapper_8h.html">CAmDltWrapper.h</a>&quot;</span></div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="CAmSocketHandler_8h.html">CAmSocketHandler.h</a>&quot;</span></div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;</div><div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespaceam.html">am</a></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;</div><div class="line"><a name="l00041"></a><span class="lineno"><a class="line" href="CAmDbusWrapper_8cpp.html#a6266fa85a7c0adb885300f68b797cea6">   41</a></span>&#160;<span class="preprocessor">#define ROOT_INTROSPECT_XML                                             \</span></div><div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;<span class="preprocessor">DBUS_INTROSPECT_1_0_XML_DOCTYPE_DECL_NODE                               \</span></div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;<span class="preprocessor">&quot;&lt;node&gt;&quot;                                                                \</span></div><div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;<span class="preprocessor">&quot;&lt;interface name=&#39;org.AudioManager.freedesktop.DBus.Introspectable&#39;&gt;&quot;   \</span></div><div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;<span class="preprocessor">&quot;&lt;method name=&#39;Introspect&#39;&gt;&quot;                                            \</span></div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;<span class="preprocessor">&quot;   &lt;arg name=&#39;xml_data&#39; type=&#39;s&#39; direction=&#39;out&#39;/&gt;&quot;                    \</span></div><div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;<span class="preprocessor">&quot;&lt;/method&gt;&quot;                                                             \</span></div><div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;<span class="preprocessor">&quot;&lt;/interface&gt;&quot;                                                          \</span></div><div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;<span class="preprocessor"></span></div><div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;CAmDbusWrapper* CAmDbusWrapper::mpReference = NULL;</div><div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;</div><div class="line"><a name="l00052"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a756a84420f9e599b1208acfdfc338457">   52</a></span>&#160;<a class="code" href="classam_1_1CAmDbusWrapper.html#a756a84420f9e599b1208acfdfc338457">CAmDbusWrapper::CAmDbusWrapper</a>(<a class="code" href="classam_1_1CAmSocketHandler.html">CAmSocketHandler</a>* socketHandler, DBusBusType type, <span class="keyword">const</span> std::string&amp; prefix, <span class="keyword">const</span> std::string&amp; objectPath) :</div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;        pDbusPrepareCallback(this,&amp;<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>::dbusPrepareCallback), <span class="comment">//</span></div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;        pDbusDispatchCallback(this, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>::dbusDispatchCallback), <span class="comment">//</span></div><div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;        pDbusFireCallback(this, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>::dbusFireCallback), <span class="comment">//</span></div><div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;        pDbusCheckCallback(this, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>::dbusCheckCallback), <span class="comment">//</span></div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;        pDbusTimerCallback(this, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>::dbusTimerCallback), <span class="comment">//</span></div><div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;        mpDbusConnection(0), <span class="comment">//</span></div><div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;        mDBusError(), <span class="comment">//</span></div><div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;        mListNodes(), <span class="comment">//</span></div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;        mpListTimerhandles(), <span class="comment">//</span></div><div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;        mpSocketHandler(socketHandler), <span class="comment">//</span></div><div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;        mDbusType(type)</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">   65</span>&#160;    assert(mpSocketHandler!=0);</div><div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;</div><div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;    dbus_error_init(&amp;mDBusError);</div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;</div><div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;    <span class="keywordflow">if</span> (!dbus_threads_init_default())</div><div class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;CAmDbusWrapper::CAmDbusWrapper threads init call failed&quot;</span>);</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;    <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper Opening DBus connection of:&quot;</span>, prefix, objectPath);</div><div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;    mpDbusConnection = dbus_bus_get(mDbusType, &amp;mDBusError);</div><div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;    <span class="keywordflow">if</span> (dbus_error_is_set(&amp;mDBusError))</div><div class="line"><a name="l00075"></a><span class="lineno">   75</span>&#160;    {</div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper Error while getting the DBus&quot;</span>);</div><div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;        dbus_error_free(&amp;mDBusError);</div><div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;    }</div><div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;    <span class="keywordflow">if</span> (NULL == mpDbusConnection)</div><div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;    {</div><div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper DBus Connection is null&quot;</span>);</div><div class="line"><a name="l00082"></a><span class="lineno">   82</span>&#160;    }</div><div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;    {</div><div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper DBus Connection is&quot;</span>, mpDbusConnection);</div><div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;    }</div><div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;</div><div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;    <span class="comment">//then we need to adopt the dbus to our mainloop:</span></div><div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;    <span class="comment">//first, we are old enought to live longer then the connection:</span></div><div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;    dbus_connection_set_exit_on_disconnect(mpDbusConnection, FALSE);</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;    <span class="comment">//we do not need the manual dispatching, since it is not allowed to call from a different thread. So leave it uncommented:</span></div><div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;    <span class="comment">//dbus_connection_set_dispatch_status_function</span></div><div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;</div><div class="line"><a name="l00095"></a><span class="lineno">   95</span>&#160;    <span class="comment">//add watch functions:</span></div><div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;    dbus_bool_t watch = dbus_connection_set_watch_functions(mpDbusConnection, <a class="code" href="classam_1_1CAmDbusWrapper.html#a9f761311f2c1697af7f4656740a1a704">addWatch</a>, <a class="code" href="classam_1_1CAmDbusWrapper.html#a6a23dde3899b82a406fd1d888c677333">removeWatch</a>, <a class="code" href="classam_1_1CAmDbusWrapper.html#ab3a67b10c92bdb7b5f83e58fbd3cb6bc">toogleWatch</a>, <span class="keyword">this</span>, NULL);</div><div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;    <span class="keywordflow">if</span> (!watch)</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;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper Registering of watch functions failed&quot;</span>);</div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;    }</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;    <span class="comment">//add timer functions:</span></div><div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;    dbus_bool_t timer = dbus_connection_set_timeout_functions(mpDbusConnection, <a class="code" href="classam_1_1CAmDbusWrapper.html#adb082d9ab4b3cf9247204bda11b425f6">addTimeout</a>, <a class="code" href="classam_1_1CAmDbusWrapper.html#a18b2719ca3cee290dfef996252b74c18">removeTimeout</a>, <a class="code" href="classam_1_1CAmDbusWrapper.html#aaa20082e0a77721e99c4d7776421faac">toggleTimeout</a>, <span class="keyword">this</span>, NULL);</div><div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;    <span class="keywordflow">if</span> (!timer)</div><div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;    {</div><div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper Registering of timer functions failed&quot;</span>);</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">  109</span>&#160;    <span class="keywordflow">if</span> (prefix.empty() &amp;&amp; objectPath.empty())</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;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper We don&#39;t register a connection object!&quot;</span>);</div><div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;        <span class="keywordflow">return</span>;</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">  115</span>&#160;    <span class="comment">//register callback for Introspectio</span></div><div class="line"><a name="l00116"></a><span class="lineno">  116</span>&#160;    mObjectPathVTable.message_function = CAmDbusWrapper::cbRootIntrospection;</div><div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;    dbus_connection_register_object_path(mpDbusConnection, objectPath.c_str(), &amp;mObjectPathVTable, <span class="keyword">this</span>);</div><div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;    <span class="keywordtype">int</span> ret = dbus_bus_request_name(mpDbusConnection, prefix.c_str(), DBUS_NAME_FLAG_DO_NOT_QUEUE, &amp;mDBusError);</div><div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;    <span class="keywordflow">if</span> (DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER == ret)</div><div class="line"><a name="l00120"></a><span class="lineno">  120</span>&#160;    {</div><div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper We own&quot;</span>, prefix);</div><div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;    }</div><div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;    {</div><div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;        std::ostringstream sserror(<span class="stringliteral">&quot;DBusWrapper::DBusWrapper &quot;</span>);</div><div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;        <span class="keywordflow">switch</span> (ret)</div><div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;        {</div><div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;            <span class="keywordflow">case</span> -1:</div><div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;                sserror &lt;&lt; <span class="stringliteral">&quot;Couldn&#39;t acquire name &quot;</span> &lt;&lt; prefix &lt;&lt; <span class="stringliteral">&quot;. DBus message: &quot;</span> &lt;&lt; mDBusError.message;</div><div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;                dbus_error_free(&amp;mDBusError);</div><div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;                <span class="keywordflow">break</span>;</div><div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;            <span class="keywordflow">case</span> DBUS_REQUEST_NAME_REPLY_IN_QUEUE:</div><div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;                sserror &lt;&lt; <span class="stringliteral">&quot;We are queued for &quot;</span> &lt;&lt; prefix;</div><div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;                <span class="keywordflow">break</span>;</div><div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;            <span class="keywordflow">case</span> DBUS_REQUEST_NAME_REPLY_EXISTS:</div><div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;                sserror &lt;&lt; <span class="stringliteral">&quot;:-( &quot;</span> &lt;&lt; prefix &lt;&lt; <span class="stringliteral">&quot; already exists!&quot;</span>;</div><div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;                <span class="keywordflow">break</span>;</div><div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;            <span class="keywordflow">case</span> DBUS_REQUEST_NAME_REPLY_ALREADY_OWNER:</div><div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;                sserror &lt;&lt; <span class="stringliteral">&quot;Eh? We already own &quot;</span> &lt;&lt; prefix;</div><div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;                <span class="keywordflow">break</span>;</div><div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;            <span class="keywordflow">default</span>:</div><div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;                sserror &lt;&lt; <span class="stringliteral">&quot;Unknown result = &quot;</span> &lt;&lt; ret;</div><div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;                <span class="keywordflow">break</span>;</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;</div><div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(sserror.str());</div><div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;        <span class="keywordflow">throw</span> std::runtime_error(sserror.str().c_str());</div><div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;    }</div><div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;}</div><div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;</div><div class="line"><a name="l00151"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a414b6c967b20f518753ad7f4afa8f811">  151</a></span>&#160;<a class="code" href="classam_1_1CAmDbusWrapper.html#a414b6c967b20f518753ad7f4afa8f811">CAmDbusWrapper::~CAmDbusWrapper</a>()</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;    <span class="comment">//close the connection again</span></div><div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;    <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::~DBusWrapper Closing DBus connection&quot;</span>);</div><div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;    dbus_connection_unref(mpDbusConnection);</div><div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;</div><div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;    <span class="comment">//clean up all timerhandles we created but did not delete before</span></div><div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;    std::vector&lt;sh_timerHandle_t*&gt;::iterator it = mpListTimerhandles.begin();</div><div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;    <span class="keywordflow">for</span> (; it != mpListTimerhandles.end(); ++it)</div><div class="line"><a name="l00160"></a><span class="lineno">  160</span>&#160;    {</div><div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;        <span class="keyword">delete</span> *it;</div><div class="line"><a name="l00162"></a><span class="lineno">  162</span>&#160;    }</div><div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;}</div><div class="line"><a name="l00164"></a><span class="lineno">  164</span>&#160;</div><div class="line"><a name="l00173"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#ac01e0b26e3f9dc7528cd815d24c43bcb">  173</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#ac01e0b26e3f9dc7528cd815d24c43bcb">CAmDbusWrapper::registerCallback</a>(<span class="keyword">const</span> DBusObjectPathVTable* vtable, <span class="keyword">const</span> std::string&amp; path, <span class="keywordtype">void</span>* userdata, <span class="keyword">const</span> std::string&amp; prefix)</div><div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;{</div><div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;    <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::registerCallback register callback:&quot;</span>, path);</div><div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;</div><div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;    std::string completePath = prefix + <span class="stringliteral">&quot;/&quot;</span> + path;</div><div class="line"><a name="l00178"></a><span class="lineno">  178</span>&#160;    dbus_error_init(&amp;mDBusError);</div><div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;    dbus_connection_register_object_path(mpDbusConnection, completePath.c_str(), vtable, userdata);</div><div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;    <span class="keywordflow">if</span> (dbus_error_is_set(&amp;mDBusError))</div><div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;    {</div><div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::registerCallack error: &quot;</span>, mDBusError.message);</div><div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;        dbus_error_free(&amp;mDBusError);</div><div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;    }</div><div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;    mListNodes.push_back(path);</div><div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;}</div><div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;</div><div class="line"><a name="l00194"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#ab126075542a721f22592652fd6dfc2cb">  194</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#ab126075542a721f22592652fd6dfc2cb">CAmDbusWrapper::registerSignalWatch</a>(DBusHandleMessageFunction handler, <span class="keyword">const</span> std::string&amp; rule, <span class="keywordtype">void</span>* userdata)</div><div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;{</div><div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;    <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::registerSignalWatch register callback:&quot;</span>, rule);</div><div class="line"><a name="l00197"></a><span class="lineno">  197</span>&#160;    dbus_error_init(&amp;mDBusError);</div><div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;    dbus_bus_add_match(mpDbusConnection, rule.c_str(), &amp;mDBusError);</div><div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;    dbus_connection_flush(mpDbusConnection);</div><div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;    dbus_connection_add_filter(mpDbusConnection, handler, userdata, 0);</div><div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;</div><div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;    <span class="keywordflow">if</span> (dbus_error_is_set(&amp;mDBusError))</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">  204</span>&#160;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::registerCallack error: &quot;</span>, mDBusError.message);</div><div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;        dbus_error_free(&amp;mDBusError);</div><div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;    }</div><div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;}</div><div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;DBusHandlerResult CAmDbusWrapper::cbRootIntrospection(DBusConnection *conn, DBusMessage *msg, <span class="keywordtype">void</span> *reference)</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;    <span class="comment">//logInfo(&quot;DBusWrapper::~cbRootIntrospection called:&quot;);</span></div><div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;</div><div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) reference;</div><div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;    std::vector&lt;std::string&gt; nodesList = mpReference-&gt;mListNodes;</div><div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;    DBusMessage * reply;</div><div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;    DBusMessageIter args;</div><div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;    dbus_uint32_t serial = 0;</div><div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;    <span class="keywordflow">if</span> (dbus_message_is_method_call(msg, DBUS_INTERFACE_INTROSPECTABLE, <span class="stringliteral">&quot;Introspect&quot;</span>))</div><div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;    {</div><div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;        std::vector&lt;std::string&gt;::iterator nodeIter = nodesList.begin();</div><div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;        <span class="keyword">const</span> <span class="keywordtype">char</span> *xml = <a class="code" href="CAmDbusWrapper_8cpp.html#a6266fa85a7c0adb885300f68b797cea6">ROOT_INTROSPECT_XML</a>;</div><div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;        std::stringstream introspect;</div><div class="line"><a name="l00229"></a><span class="lineno">  229</span>&#160;        introspect &lt;&lt; std::string(xml);</div><div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;        <span class="keywordflow">for</span> (; nodeIter != nodesList.end(); ++nodeIter)</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;            introspect &lt;&lt; <span class="stringliteral">&quot;&lt;node name=&#39;&quot;</span> &lt;&lt; nodeIter-&gt;c_str() &lt;&lt; <span class="stringliteral">&quot;&#39;/&gt;&quot;</span>;</div><div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;        }</div><div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;        introspect &lt;&lt; <span class="stringliteral">&quot;&lt;/node&gt;&quot;</span>;</div><div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;</div><div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;        reply = dbus_message_new_method_return(msg);</div><div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;        std::string s = introspect.str();</div><div class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;        <span class="keyword">const</span> <span class="keywordtype">char</span>* <span class="keywordtype">string</span> = s.c_str();</div><div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;</div><div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;        <span class="comment">// add the arguments to the reply</span></div><div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;        dbus_message_iter_init_append(reply, &amp;args);</div><div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;        <span class="keywordflow">if</span> (!dbus_message_iter_append_basic(&amp;args, DBUS_TYPE_STRING, &amp;<span class="keywordtype">string</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;            <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::~cbRootIntrospection DBUS Out Of Memory!&quot;</span>);</div><div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;        }</div><div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;</div><div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;        <span class="comment">// send the reply &amp;&amp; flush the connection</span></div><div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;        <span class="keywordflow">if</span> (!dbus_connection_send(conn, reply, &amp;serial))</div><div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;        {</div><div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;            <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::~cbRootIntrospection DBUS Out Of Memory!&quot;</span>);</div><div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;        }</div><div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;        dbus_connection_flush(conn);</div><div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;        <span class="comment">// free the reply</span></div><div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;        dbus_message_unref(reply);</div><div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;</div><div class="line"><a name="l00256"></a><span class="lineno">  256</span>&#160;        <span class="keywordflow">return</span> (DBUS_HANDLER_RESULT_HANDLED);</div><div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;    }</div><div class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00259"></a><span class="lineno">  259</span>&#160;    {</div><div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;        <span class="keywordflow">return</span> (DBUS_HANDLER_RESULT_NOT_YET_HANDLED);</div><div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;    }</div><div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;}</div><div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;</div><div class="line"><a name="l00268"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#aae349240016dc3e557d2e83e1437c7eb">  268</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#aae349240016dc3e557d2e83e1437c7eb">CAmDbusWrapper::getDBusConnection</a>(DBusConnection *&amp; connection)<span class="keyword"> const</span></div><div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;    connection = mpDbusConnection;</div><div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;}</div><div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;</div><div class="line"><a name="l00273"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a9f761311f2c1697af7f4656740a1a704">  273</a></span>&#160;dbus_bool_t <a class="code" href="classam_1_1CAmDbusWrapper.html#a9f761311f2c1697af7f4656740a1a704">CAmDbusWrapper::addWatch</a>(DBusWatch *watch, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00274"></a><span class="lineno">  274</span>&#160;{</div><div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) userData;</div><div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;    assert(mpReference!=0);</div><div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;    <span class="keywordflow">return</span> (mpReference-&gt;addWatchDelegate(watch, userData));</div><div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;}</div><div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;</div><div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;dbus_bool_t CAmDbusWrapper::addWatchDelegate(DBusWatch * watch, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;{</div><div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;    (void) userData;</div><div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;    int16_t <span class="keyword">event</span> = 0;</div><div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;    <a class="code" href="namespaceam.html#af782e2735b1adf1e43a9d530cee340aa">sh_pollHandle_t</a> handle = 0;</div><div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;    uint flags = dbus_watch_get_flags(watch);</div><div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;</div><div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;    <span class="comment">/* no watch flags for disabled watches */</span></div><div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;    <span class="keywordflow">if</span> (dbus_watch_get_enabled(watch))</div><div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;    {</div><div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;        <span class="keywordflow">if</span> (flags &amp; DBUS_WATCH_READABLE)</div><div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;            <span class="keyword">event</span> |= POLLIN;</div><div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;        <span class="keywordflow">if</span> (flags &amp; DBUS_WATCH_WRITABLE)</div><div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;            <span class="keyword">event</span> |= POLLOUT;</div><div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;</div><div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::addWatchDelegate entered new watch, fd=&quot;</span>, dbus_watch_get_unix_fd(watch), <span class="stringliteral">&quot;event flag=&quot;</span>, event);</div><div class="line"><a name="l00296"></a><span class="lineno">  296</span>&#160;        <a class="code" href="namespaceam.html#aa3dcb70029da317d661b6f422de1b4ce">am_Error_e</a> error = mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a8ee49d4fbc44291bc6b99fa49fc0350a">addFDPoll</a>(dbus_watch_get_unix_fd(watch), event, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html#a817fcd0bce4f833cadd5767e7b36a007">pDbusPrepareCallback</a>, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html#aa56bb4cb9372b1602eae4e2caf50d57a">pDbusFireCallback</a>, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html#af1abb258907275c66d8c41ba91a82e2f">pDbusCheckCallback</a>, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html#a80c4d0c6e996bc19a161a24dd61ec951">pDbusDispatchCallback</a>, watch, handle);</div><div class="line"><a name="l00297"></a><span class="lineno">  297</span>&#160;</div><div class="line"><a name="l00298"></a><span class="lineno">  298</span>&#160;        <span class="comment">//if everything is alright, add the watch and the handle to our map so we know this relationship</span></div><div class="line"><a name="l00299"></a><span class="lineno">  299</span>&#160;        <span class="keywordflow">if</span> (error == <a class="code" href="namespaceam.html#aa3dcb70029da317d661b6f422de1b4cea796d4cc86cd1605f4307478c128eee36">E_OK</a> &amp;&amp; handle != 0)</div><div class="line"><a name="l00300"></a><span class="lineno">  300</span>&#160;        {</div><div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;            mMapHandleWatch.insert(std::make_pair(watch, handle));</div><div class="line"><a name="l00302"></a><span class="lineno">  302</span>&#160;            <span class="keywordflow">return</span> (<span class="keyword">true</span>);</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;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::addWatchDelegate entering watch failed&quot;</span>);</div><div class="line"><a name="l00305"></a><span class="lineno">  305</span>&#160;    }</div><div class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;    <span class="keywordflow">return</span> (<span class="keyword">true</span>);</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;</div><div class="line"><a name="l00309"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a6a23dde3899b82a406fd1d888c677333">  309</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#a6a23dde3899b82a406fd1d888c677333">CAmDbusWrapper::removeWatch</a>(DBusWatch *watch, <span class="keywordtype">void</span> *userData)</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;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) userData;</div><div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;    assert(mpReference!=0);</div><div class="line"><a name="l00313"></a><span class="lineno">  313</span>&#160;    mpReference-&gt;removeWatchDelegate(watch, userData);</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;</div><div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;<span class="keywordtype">void</span> CAmDbusWrapper::removeWatchDelegate(DBusWatch *watch, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00317"></a><span class="lineno">  317</span>&#160;{</div><div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;    (void) userData;</div><div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;    std::map&lt;DBusWatch*, sh_pollHandle_t&gt;::iterator iterator = mMapHandleWatch.begin();</div><div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;    iterator = mMapHandleWatch.find(watch);</div><div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;    <span class="keywordflow">if</span> (iterator != mMapHandleWatch.end())</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;        mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a57c40a25d4bff6f88ed4ce5e597a5712">removeFDPoll</a>(iterator-&gt;second);</div><div class="line"><a name="l00324"></a><span class="lineno">  324</span>&#160;        <a class="code" href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">logInfo</a>(<span class="stringliteral">&quot;DBusWrapper::removeWatch removed watch with handle&quot;</span>, iterator-&gt;second);</div><div class="line"><a name="l00325"></a><span class="lineno">  325</span>&#160;        mMapHandleWatch.erase(iterator);</div><div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;    }</div><div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;    <span class="keywordflow">else</span></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;        <a class="code" href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">logError</a>(<span class="stringliteral">&quot;DBusWrapper::removeWatch could not find handle !&quot;</span>);</div><div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;    }</div><div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;}</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"><a class="line" href="classam_1_1CAmDbusWrapper.html#ab3a67b10c92bdb7b5f83e58fbd3cb6bc">  333</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#ab3a67b10c92bdb7b5f83e58fbd3cb6bc">CAmDbusWrapper::toogleWatch</a>(DBusWatch *watch, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;{</div><div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) userData;</div><div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;    assert(mpReference!=0);</div><div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;    mpReference-&gt;toogleWatchDelegate(watch, userData);</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">  340</span>&#160;<span class="keywordtype">void</span> CAmDbusWrapper::toogleWatchDelegate(DBusWatch *watch, <span class="keywordtype">void</span> *userData)</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;    (void) userData;</div><div class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;    int16_t <span class="keyword">event</span> = 0;</div><div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;    dbus_watch_get_unix_fd(watch);</div><div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;    uint flags = dbus_watch_get_flags(watch);</div><div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;    <span class="comment">/* no watch flags for disabled watches */</span></div><div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;    <span class="keywordflow">if</span> (dbus_watch_get_enabled(watch))</div><div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;    {</div><div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;        <span class="keywordflow">if</span> (flags &amp; DBUS_WATCH_READABLE)</div><div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;            <span class="keyword">event</span> |= POLLIN;</div><div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;        <span class="keywordflow">if</span> (flags &amp; DBUS_WATCH_WRITABLE)</div><div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;            <span class="keyword">event</span> |= POLLOUT;</div><div class="line"><a name="l00353"></a><span class="lineno">  353</span>&#160;    }</div><div class="line"><a name="l00354"></a><span class="lineno">  354</span>&#160;    std::map&lt;DBusWatch*, sh_pollHandle_t&gt;::iterator iterator = mMapHandleWatch.begin();</div><div class="line"><a name="l00355"></a><span class="lineno">  355</span>&#160;    iterator = mMapHandleWatch.find(watch);</div><div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;    <span class="keywordflow">if</span> (iterator != mMapHandleWatch.end())</div><div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;        mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#af065b5a6143c8566522528bc18ce1f42">updateEventFlags</a>(iterator-&gt;second, event);</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"><a class="line" href="classam_1_1CAmDbusWrapper.html#adb082d9ab4b3cf9247204bda11b425f6">  360</a></span>&#160;dbus_bool_t <a class="code" href="classam_1_1CAmDbusWrapper.html#adb082d9ab4b3cf9247204bda11b425f6">CAmDbusWrapper::addTimeout</a>(DBusTimeout *timeout, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;{</div><div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) userData;</div><div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;    assert(mpReference!=0);</div><div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;    <span class="keywordflow">return</span> (mpReference-&gt;addTimeoutDelegate(timeout, userData));</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;dbus_bool_t CAmDbusWrapper::addTimeoutDelegate(DBusTimeout *timeout, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;{</div><div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;    (void)userData;</div><div class="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;</div><div class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;    <span class="keywordflow">if</span> (!dbus_timeout_get_enabled(timeout))</div><div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;        <span class="keywordflow">return</span> (<span class="keyword">false</span>);</div><div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;</div><div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;    <span class="comment">//calculate the timeout in timeval</span></div><div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;    timespec pollTimeout;</div><div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;    <span class="keywordtype">int</span> localTimeout = dbus_timeout_get_interval(timeout);</div><div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;    pollTimeout.tv_sec = localTimeout / 1000;</div><div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;    pollTimeout.tv_nsec = (localTimeout % 1000) * 1000000;</div><div class="line"><a name="l00379"></a><span class="lineno">  379</span>&#160;</div><div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;    <span class="comment">//prepare handle and callback. new is eval, but there is no other choice because we need the pointer!</span></div><div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;    <a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a>* handle = <span class="keyword">new</span> <a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a>;</div><div class="line"><a name="l00382"></a><span class="lineno">  382</span>&#160;    mpListTimerhandles.push_back(handle);</div><div class="line"><a name="l00383"></a><span class="lineno">  383</span>&#160;</div><div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;    <span class="comment">//add the timer to the pollLoop</span></div><div class="line"><a name="l00385"></a><span class="lineno">  385</span>&#160;    mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#afe4e4806d91f9a4b3b1eb8a278f64cc9">addTimer</a>(pollTimeout, &amp;<a class="code" href="classam_1_1CAmDbusWrapper.html#a9960708bf636f4afbc60dbf7f8262c73">pDbusTimerCallback</a>, *handle, timeout);</div><div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;</div><div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;    <span class="comment">//save the handle with dbus context</span></div><div class="line"><a name="l00388"></a><span class="lineno">  388</span>&#160;    dbus_timeout_set_data(timeout, handle, NULL);</div><div class="line"><a name="l00389"></a><span class="lineno">  389</span>&#160;</div><div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;    <span class="keywordflow">return</span> (<span class="keyword">true</span>);</div><div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;}</div><div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;</div><div class="line"><a name="l00393"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a18b2719ca3cee290dfef996252b74c18">  393</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#a18b2719ca3cee290dfef996252b74c18">CAmDbusWrapper::removeTimeout</a>(DBusTimeout *timeout, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;{</div><div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) userData;</div><div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;    assert(mpReference!=0);</div><div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;    mpReference-&gt;removeTimeoutDelegate(timeout, userData);</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="keywordtype">void</span> CAmDbusWrapper::removeTimeoutDelegate(DBusTimeout *timeout, <span class="keywordtype">void</span>* userData)</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;    (void) userData;</div><div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;    <span class="comment">//get the pointer to the handle and remove the timer</span></div><div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;    <a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a>* handle = (<a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a>*) dbus_timeout_get_data(timeout);</div><div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;    mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a7627416d3b2fd93baa84599b52691bec">removeTimer</a>(*handle);</div><div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;</div><div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;    <span class="comment">//now go throught the timerlist and remove the pointer, free memory</span></div><div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;    std::vector&lt;sh_timerHandle_t*&gt;::iterator it = mpListTimerhandles.begin();</div><div class="line"><a name="l00409"></a><span class="lineno">  409</span>&#160;    <span class="keywordflow">for</span> (; it != mpListTimerhandles.end(); ++it)</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;        <span class="keywordflow">if</span> (*it == handle)</div><div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;        {</div><div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;            mpListTimerhandles.erase(it);</div><div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;            <span class="keywordflow">break</span>;</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;    }</div><div class="line"><a name="l00417"></a><span class="lineno">  417</span>&#160;    <span class="keyword">delete</span> handle;</div><div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160; }</div><div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;</div><div class="line"><a name="l00420"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#aaa20082e0a77721e99c4d7776421faac">  420</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#aaa20082e0a77721e99c4d7776421faac">CAmDbusWrapper::toggleTimeout</a>(DBusTimeout *timeout, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;{</div><div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;    mpReference = (<a class="code" href="classam_1_1CAmDbusWrapper.html">CAmDbusWrapper</a>*) userData;</div><div class="line"><a name="l00423"></a><span class="lineno">  423</span>&#160;    assert(mpReference!=0);</div><div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;    mpReference-&gt;toggleTimeoutDelegate(timeout, userData);</div><div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;}</div><div class="line"><a name="l00426"></a><span class="lineno">  426</span>&#160;</div><div class="line"><a name="l00427"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a54fb9b2cbc6ae2b8164388f7cc7affd1">  427</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#a54fb9b2cbc6ae2b8164388f7cc7affd1">am::CAmDbusWrapper::dbusDispatchCallback</a>(<span class="keyword">const</span> <a class="code" href="namespaceam.html#af782e2735b1adf1e43a9d530cee340aa">sh_pollHandle_t</a> handle, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;{</div><div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;    (void) handle;</div><div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;    (void) userData;</div><div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;    <span class="keywordtype">bool</span> returnVal = <span class="keyword">true</span>;</div><div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;    dbus_connection_ref(mpDbusConnection);</div><div class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;    <span class="keywordflow">if</span> (dbus_connection_dispatch(mpDbusConnection) == DBUS_DISPATCH_COMPLETE)</div><div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;        returnVal = <span class="keyword">false</span>;</div><div class="line"><a name="l00435"></a><span class="lineno">  435</span>&#160;    dbus_connection_unref(mpDbusConnection);</div><div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;    <span class="comment">//logInfo(&quot;DBusWrapper::dbusDispatchCallback was called&quot;);</span></div><div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;    <span class="keywordflow">return</span> (returnVal);</div><div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;}</div><div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;</div><div class="line"><a name="l00440"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#af25b51b4cdea2e33bddf7f9297ca02e2">  440</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#af25b51b4cdea2e33bddf7f9297ca02e2">am::CAmDbusWrapper::dbusCheckCallback</a>(<span class="keyword">const</span> <a class="code" href="namespaceam.html#af782e2735b1adf1e43a9d530cee340aa">sh_pollHandle_t</a> handle, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;{</div><div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;    (void) handle;</div><div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;    (void) userData;</div><div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;    <span class="keywordtype">bool</span> returnVal = <span class="keyword">false</span>;</div><div class="line"><a name="l00445"></a><span class="lineno">  445</span>&#160;    dbus_connection_ref(mpDbusConnection);</div><div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;    <span class="keywordflow">if</span> (dbus_connection_get_dispatch_status(mpDbusConnection) == DBUS_DISPATCH_DATA_REMAINS)</div><div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;        returnVal = <span class="keyword">true</span>;</div><div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;    dbus_connection_unref(mpDbusConnection);</div><div class="line"><a name="l00449"></a><span class="lineno">  449</span>&#160;    <span class="comment">//logInfo(&quot;DBusWrapper::dbusCheckCallback was called&quot;);</span></div><div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;    <span class="keywordflow">return</span> (returnVal);</div><div class="line"><a name="l00451"></a><span class="lineno">  451</span>&#160;}</div><div class="line"><a name="l00452"></a><span class="lineno">  452</span>&#160;</div><div class="line"><a name="l00453"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a5c75b210dac390a27f9b15b52536c7f0">  453</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#a5c75b210dac390a27f9b15b52536c7f0">am::CAmDbusWrapper::dbusFireCallback</a>(<span class="keyword">const</span> pollfd pollfd, <span class="keyword">const</span> <a class="code" href="namespaceam.html#af782e2735b1adf1e43a9d530cee340aa">sh_pollHandle_t</a> handle, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;{</div><div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;    (void) handle;</div><div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;    (void) userData;</div><div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;    assert(userData!=NULL);</div><div class="line"><a name="l00458"></a><span class="lineno">  458</span>&#160;    uint flags = 0;</div><div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;</div><div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;    <span class="keywordflow">if</span> (pollfd.revents &amp; POLLIN)</div><div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;        flags |= DBUS_WATCH_READABLE;</div><div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;    <span class="keywordflow">if</span> (pollfd.revents &amp; POLLOUT)</div><div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;        flags |= DBUS_WATCH_WRITABLE;</div><div class="line"><a name="l00464"></a><span class="lineno">  464</span>&#160;    <span class="keywordflow">if</span> (pollfd.revents &amp; POLLHUP)</div><div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;        flags |= DBUS_WATCH_HANGUP;</div><div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;    <span class="keywordflow">if</span> (pollfd.revents &amp; POLLERR)</div><div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;        flags |= DBUS_WATCH_ERROR;</div><div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;</div><div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;    DBusWatch *watch = (DBusWatch*) userData;</div><div class="line"><a name="l00470"></a><span class="lineno">  470</span>&#160;</div><div class="line"><a name="l00471"></a><span class="lineno">  471</span>&#160;    dbus_connection_ref(mpDbusConnection);</div><div class="line"><a name="l00472"></a><span class="lineno">  472</span>&#160;    dbus_watch_handle(watch, flags);</div><div class="line"><a name="l00473"></a><span class="lineno">  473</span>&#160;    dbus_connection_unref(mpDbusConnection);</div><div class="line"><a name="l00474"></a><span class="lineno">  474</span>&#160;    <span class="comment">//logInfo(&quot;DBusWrapper::dbusFireCallback was called&quot;);</span></div><div class="line"><a name="l00475"></a><span class="lineno">  475</span>&#160;}</div><div class="line"><a name="l00476"></a><span class="lineno">  476</span>&#160;</div><div class="line"><a name="l00477"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#a115584c27a48a673c165c25147c5900a">  477</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#a115584c27a48a673c165c25147c5900a">CAmDbusWrapper::dbusPrepareCallback</a>(<span class="keyword">const</span> <a class="code" href="namespaceam.html#af782e2735b1adf1e43a9d530cee340aa">sh_pollHandle_t</a> handle, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00478"></a><span class="lineno">  478</span>&#160;{</div><div class="line"><a name="l00479"></a><span class="lineno">  479</span>&#160;    (void) handle;</div><div class="line"><a name="l00480"></a><span class="lineno">  480</span>&#160;    (void) userData;</div><div class="line"><a name="l00481"></a><span class="lineno">  481</span>&#160;    dbus_connection_ref(mpDbusConnection);</div><div class="line"><a name="l00482"></a><span class="lineno">  482</span>&#160;    <span class="keywordflow">while</span> (dbus_connection_get_dispatch_status(mpDbusConnection) == DBUS_DISPATCH_DATA_REMAINS)</div><div class="line"><a name="l00483"></a><span class="lineno">  483</span>&#160;    {</div><div class="line"><a name="l00484"></a><span class="lineno">  484</span>&#160;       dbus_connection_dispatch(mpDbusConnection);</div><div class="line"><a name="l00485"></a><span class="lineno">  485</span>&#160;       <span class="comment">//logInfo(&quot;prepare was neccessary!&quot;);</span></div><div class="line"><a name="l00486"></a><span class="lineno">  486</span>&#160;    }</div><div class="line"><a name="l00487"></a><span class="lineno">  487</span>&#160;    dbus_connection_unref(mpDbusConnection);</div><div class="line"><a name="l00488"></a><span class="lineno">  488</span>&#160;}</div><div class="line"><a name="l00489"></a><span class="lineno">  489</span>&#160;</div><div class="line"><a name="l00490"></a><span class="lineno">  490</span>&#160;<span class="keywordtype">void</span> CAmDbusWrapper::toggleTimeoutDelegate(DBusTimeout *timeout, <span class="keywordtype">void</span>* userData)</div><div class="line"><a name="l00491"></a><span class="lineno">  491</span>&#160;{</div><div class="line"><a name="l00492"></a><span class="lineno">  492</span>&#160;    (void) userData;</div><div class="line"><a name="l00493"></a><span class="lineno">  493</span>&#160;    <span class="comment">//get the pointer to the handle and remove the timer</span></div><div class="line"><a name="l00494"></a><span class="lineno">  494</span>&#160;    <a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a>* handle = (<a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a>*) dbus_timeout_get_data(timeout);</div><div class="line"><a name="l00495"></a><span class="lineno">  495</span>&#160;</div><div class="line"><a name="l00496"></a><span class="lineno">  496</span>&#160;    <span class="comment">//stop or restart?</span></div><div class="line"><a name="l00497"></a><span class="lineno">  497</span>&#160;    <span class="keywordflow">if</span> (dbus_timeout_get_enabled(timeout))</div><div class="line"><a name="l00498"></a><span class="lineno">  498</span>&#160;    {</div><div class="line"><a name="l00499"></a><span class="lineno">  499</span>&#160;        <span class="comment">//calculate the timeout in timeval</span></div><div class="line"><a name="l00500"></a><span class="lineno">  500</span>&#160;        timespec pollTimeout;</div><div class="line"><a name="l00501"></a><span class="lineno">  501</span>&#160;        <span class="keywordtype">int</span> localTimeout = dbus_timeout_get_interval(timeout);</div><div class="line"><a name="l00502"></a><span class="lineno">  502</span>&#160;        pollTimeout.tv_sec = localTimeout / 1000;</div><div class="line"><a name="l00503"></a><span class="lineno">  503</span>&#160;        pollTimeout.tv_nsec = (localTimeout % 1000) * 1000000;</div><div class="line"><a name="l00504"></a><span class="lineno">  504</span>&#160;        mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a94dae6fb7f8f0b52fd048c51bb3aa8aa">updateTimer</a>(*handle, pollTimeout);</div><div class="line"><a name="l00505"></a><span class="lineno">  505</span>&#160;    }</div><div class="line"><a name="l00506"></a><span class="lineno">  506</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00507"></a><span class="lineno">  507</span>&#160;    {</div><div class="line"><a name="l00508"></a><span class="lineno">  508</span>&#160;        mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#af3b4d566129e9d9dc9dae13d5a51afdf">stopTimer</a>(*handle);</div><div class="line"><a name="l00509"></a><span class="lineno">  509</span>&#160;    }</div><div class="line"><a name="l00510"></a><span class="lineno">  510</span>&#160;}</div><div class="line"><a name="l00511"></a><span class="lineno">  511</span>&#160;</div><div class="line"><a name="l00512"></a><span class="lineno"><a class="line" href="classam_1_1CAmDbusWrapper.html#abf28f8004af1a97889713b24133506f1">  512</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classam_1_1CAmDbusWrapper.html#abf28f8004af1a97889713b24133506f1">CAmDbusWrapper::dbusTimerCallback</a>(<a class="code" href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">sh_timerHandle_t</a> handle, <span class="keywordtype">void</span> *userData)</div><div class="line"><a name="l00513"></a><span class="lineno">  513</span>&#160;{</div><div class="line"><a name="l00514"></a><span class="lineno">  514</span>&#160;    assert(userData!=NULL);</div><div class="line"><a name="l00515"></a><span class="lineno">  515</span>&#160;    <span class="keywordflow">for</span> (<span class="keyword">auto</span> &amp;&amp; timerHandle : mpListTimerhandles)</div><div class="line"><a name="l00516"></a><span class="lineno">  516</span>&#160;    {</div><div class="line"><a name="l00517"></a><span class="lineno">  517</span>&#160;        <span class="keywordflow">if</span> (*timerHandle == handle)</div><div class="line"><a name="l00518"></a><span class="lineno">  518</span>&#160;        {</div><div class="line"><a name="l00519"></a><span class="lineno">  519</span>&#160;            <span class="keywordflow">if</span> (dbus_timeout_get_enabled((DBusTimeout*) userData))</div><div class="line"><a name="l00520"></a><span class="lineno">  520</span>&#160;            {</div><div class="line"><a name="l00521"></a><span class="lineno">  521</span>&#160;                mpSocketHandler-&gt;<a class="code" href="classam_1_1CAmSocketHandler.html#a34f5a3d01d54f25eae224d5ca84f5a2a">restartTimer</a>(handle);</div><div class="line"><a name="l00522"></a><span class="lineno">  522</span>&#160;            }</div><div class="line"><a name="l00523"></a><span class="lineno">  523</span>&#160;            dbus_timeout_handle((DBusTimeout*) userData);</div><div class="line"><a name="l00524"></a><span class="lineno">  524</span>&#160;            <span class="keywordflow">return</span>;</div><div class="line"><a name="l00525"></a><span class="lineno">  525</span>&#160;        }</div><div class="line"><a name="l00526"></a><span class="lineno">  526</span>&#160;    }</div><div class="line"><a name="l00527"></a><span class="lineno">  527</span>&#160;    <a class="code" href="namespaceam.html#a8d6015cc712615bbe2fc1cd7d8b94d15">logWarning</a>(<span class="stringliteral">&quot;CAmDbusWrapper::dbusTimerCallback Unknown timer handle&quot;</span>);</div><div class="line"><a name="l00528"></a><span class="lineno">  528</span>&#160;}</div><div class="line"><a name="l00529"></a><span class="lineno">  529</span>&#160;}</div><div class="line"><a name="l00530"></a><span class="lineno">  530</span>&#160;</div><div class="ttc" id="namespaceam_html_a8d6015cc712615bbe2fc1cd7d8b94d15"><div class="ttname"><a href="namespaceam.html#a8d6015cc712615bbe2fc1cd7d8b94d15">am::logWarning</a></div><div class="ttdeci">void logWarning(T value, TArgs...args)</div><div class="ttdoc">logs given values with warninglevel with the default context </div><div class="ttdef"><b>Definition:</b> <a href="CAmDltWrapper_8h_source.html#l00442">CAmDltWrapper.h:442</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_ac01e0b26e3f9dc7528cd815d24c43bcb"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#ac01e0b26e3f9dc7528cd815d24c43bcb">am::CAmDbusWrapper::registerCallback</a></div><div class="ttdeci">void registerCallback(const DBusObjectPathVTable *vtable, const std::string &amp;path, void *userdata, const std::string &amp;prefix=DBUS_SERVICE_OBJECT_PATH)</div><div class="ttdoc">registers a callback that is entered as path below the main path. </div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00173">CAmDbusWrapper.cpp:173</a></div></div>
<div class="ttc" id="namespaceam_html"><div class="ttname"><a href="namespaceam.html">am</a></div><div class="ttdoc">A Common-API wrapper class, which loads the common-api runtime and instantiates all necessary objects...</div><div class="ttdef"><b>Definition:</b> <a href="CAmCommandReceiver_8h_source.html#l00029">CAmCommandReceiver.h:29</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a9960708bf636f4afbc60dbf7f8262c73"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a9960708bf636f4afbc60dbf7f8262c73">am::CAmDbusWrapper::pDbusTimerCallback</a></div><div class="ttdeci">TAmShTimerCallBack&lt; CAmDbusWrapper &gt; pDbusTimerCallback</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8h_source.html#l00069">CAmDbusWrapper.h:69</a></div></div>
<div class="ttc" id="namespaceam_html_aa3dcb70029da317d661b6f422de1b4ce"><div class="ttname"><a href="namespaceam.html#aa3dcb70029da317d661b6f422de1b4ce">am::am_Error_e</a></div><div class="ttdeci">am_Error_e</div><div class="ttdoc">the errors of the audiomanager. </div><div class="ttdef"><b>Definition:</b> <a href="audiomanagertypes_8h_source.html#l00337">audiomanagertypes.h:337</a></div></div>
<div class="ttc" id="namespaceam_html_a47d650dc91db97c1f9323b4ed5cf4fd6"><div class="ttname"><a href="namespaceam.html#a47d650dc91db97c1f9323b4ed5cf4fd6">am::logInfo</a></div><div class="ttdeci">void logInfo(T value, TArgs...args)</div><div class="ttdoc">logs given values with infolevel with the default context </div><div class="ttdef"><b>Definition:</b> <a href="CAmDltWrapper_8h_source.html#l00420">CAmDltWrapper.h:420</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a54fb9b2cbc6ae2b8164388f7cc7affd1"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a54fb9b2cbc6ae2b8164388f7cc7affd1">am::CAmDbusWrapper::dbusDispatchCallback</a></div><div class="ttdeci">bool dbusDispatchCallback(const sh_pollHandle_t handle, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00427">CAmDbusWrapper.cpp:427</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a34f5a3d01d54f25eae224d5ca84f5a2a"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a34f5a3d01d54f25eae224d5ca84f5a2a">am::CAmSocketHandler::restartTimer</a></div><div class="ttdeci">am_Error_e restartTimer(const sh_timerHandle_t handle)</div><div class="ttdoc">restarts a timer with the original value </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00720">CAmSocketHandler.cpp:720</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_abf28f8004af1a97889713b24133506f1"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#abf28f8004af1a97889713b24133506f1">am::CAmDbusWrapper::dbusTimerCallback</a></div><div class="ttdeci">void dbusTimerCallback(sh_timerHandle_t handle, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00512">CAmDbusWrapper.cpp:512</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_aa56bb4cb9372b1602eae4e2caf50d57a"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#aa56bb4cb9372b1602eae4e2caf50d57a">am::CAmDbusWrapper::pDbusFireCallback</a></div><div class="ttdeci">TAmShPollFired&lt; CAmDbusWrapper &gt; pDbusFireCallback</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8h_source.html#l00063">CAmDbusWrapper.h:63</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html">am::CAmSocketHandler</a></div><div class="ttdoc">The am::CAmSocketHandler implements a mainloop for the AudioManager. </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8h_source.html#l00216">CAmSocketHandler.h:216</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_aaa20082e0a77721e99c4d7776421faac"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#aaa20082e0a77721e99c4d7776421faac">am::CAmDbusWrapper::toggleTimeout</a></div><div class="ttdeci">static void toggleTimeout(DBusTimeout *timeout, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00420">CAmDbusWrapper.cpp:420</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a817fcd0bce4f833cadd5767e7b36a007"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a817fcd0bce4f833cadd5767e7b36a007">am::CAmDbusWrapper::pDbusPrepareCallback</a></div><div class="ttdeci">TAmShPollPrepare&lt; CAmDbusWrapper &gt; pDbusPrepareCallback</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8h_source.html#l00057">CAmDbusWrapper.h:57</a></div></div>
<div class="ttc" id="namespaceam_html_af782e2735b1adf1e43a9d530cee340aa"><div class="ttname"><a href="namespaceam.html#af782e2735b1adf1e43a9d530cee340aa">am::sh_pollHandle_t</a></div><div class="ttdeci">uint16_t sh_pollHandle_t</div><div class="ttdoc">this is a handle for a filedescriptor to be used with the SocketHandler </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8h_source.html#l00051">CAmSocketHandler.h:51</a></div></div>
<div class="ttc" id="CAmDltWrapper_8h_html"><div class="ttname"><a href="CAmDltWrapper_8h.html">CAmDltWrapper.h</a></div><div class="ttdoc">SPDX license identifier: MPL-2.0. </div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a57c40a25d4bff6f88ed4ce5e597a5712"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a57c40a25d4bff6f88ed4ce5e597a5712">am::CAmSocketHandler::removeFDPoll</a></div><div class="ttdeci">am_Error_e removeFDPoll(const sh_pollHandle_t handle)</div><div class="ttdoc">removes a filedescriptor from the poll loop </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00424">CAmSocketHandler.cpp:424</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a7627416d3b2fd93baa84599b52691bec"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a7627416d3b2fd93baa84599b52691bec">am::CAmSocketHandler::removeTimer</a></div><div class="ttdeci">am_Error_e removeTimer(const sh_timerHandle_t handle)</div><div class="ttdoc">removes a timer from the list of timers </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00596">CAmSocketHandler.cpp:596</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_af3b4d566129e9d9dc9dae13d5a51afdf"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#af3b4d566129e9d9dc9dae13d5a51afdf">am::CAmSocketHandler::stopTimer</a></div><div class="ttdeci">am_Error_e stopTimer(const sh_timerHandle_t handle)</div><div class="ttdoc">stops a timer </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00798">CAmSocketHandler.cpp:798</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_ab3a67b10c92bdb7b5f83e58fbd3cb6bc"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#ab3a67b10c92bdb7b5f83e58fbd3cb6bc">am::CAmDbusWrapper::toogleWatch</a></div><div class="ttdeci">static void toogleWatch(DBusWatch *watch, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00333">CAmDbusWrapper.cpp:333</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a94dae6fb7f8f0b52fd048c51bb3aa8aa"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a94dae6fb7f8f0b52fd048c51bb3aa8aa">am::CAmSocketHandler::updateTimer</a></div><div class="ttdeci">am_Error_e updateTimer(const sh_timerHandle_t handle, const timespec &amp;timeouts)</div><div class="ttdoc">restarts a timer and updates with a new interva </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00636">CAmSocketHandler.cpp:636</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a756a84420f9e599b1208acfdfc338457"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a756a84420f9e599b1208acfdfc338457">am::CAmDbusWrapper::CAmDbusWrapper</a></div><div class="ttdeci">CAmDbusWrapper(CAmSocketHandler *socketHandler, DBusBusType type=DBUS_BUS_SESSION, const std::string &amp;prefix=DBUS_SERVICE_PREFIX, const std::string &amp;objectPath=DBUS_SERVICE_OBJECT_PATH)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00052">CAmDbusWrapper.cpp:52</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_af065b5a6143c8566522528bc18ce1f42"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#af065b5a6143c8566522528bc18ce1f42">am::CAmSocketHandler::updateEventFlags</a></div><div class="ttdeci">am_Error_e updateEventFlags(const sh_pollHandle_t handle, const short events)</div><div class="ttdoc">updates the eventFlags of a poll </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00841">CAmSocketHandler.cpp:841</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_ab126075542a721f22592652fd6dfc2cb"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#ab126075542a721f22592652fd6dfc2cb">am::CAmDbusWrapper::registerSignalWatch</a></div><div class="ttdeci">void registerSignalWatch(DBusHandleMessageFunction handler, const std::string &amp;rule, void *userdata)</div><div class="ttdoc">register signal watch callback to matching rule </div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00194">CAmDbusWrapper.cpp:194</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a80c4d0c6e996bc19a161a24dd61ec951"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a80c4d0c6e996bc19a161a24dd61ec951">am::CAmDbusWrapper::pDbusDispatchCallback</a></div><div class="ttdeci">TAmShPollDispatch&lt; CAmDbusWrapper &gt; pDbusDispatchCallback</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8h_source.html#l00060">CAmDbusWrapper.h:60</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_a8ee49d4fbc44291bc6b99fa49fc0350a"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#a8ee49d4fbc44291bc6b99fa49fc0350a">am::CAmSocketHandler::addFDPoll</a></div><div class="ttdeci">am_Error_e addFDPoll(const int fd, const short event, std::function&lt; void(const sh_pollHandle_t handle, void *userData)&gt; prepare, std::function&lt; void(const pollfd pollfd, const sh_pollHandle_t handle, void *userData)&gt; fired, std::function&lt; bool(const sh_pollHandle_t handle, void *userData)&gt; check, std::function&lt; bool(const sh_pollHandle_t handle, void *userData)&gt; dispatch, void *userData, sh_pollHandle_t &amp;handle)</div><div class="ttdoc">Adds a filedescriptor to the polling loop. </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8cpp_source.html#l00353">CAmSocketHandler.cpp:353</a></div></div>
<div class="ttc" id="CAmSocketHandler_8h_html"><div class="ttname"><a href="CAmSocketHandler_8h.html">CAmSocketHandler.h</a></div><div class="ttdoc">SPDX license identifier: MPL-2.0. </div></div>
<div class="ttc" id="CAmDbusWrapper_8cpp_html_a6266fa85a7c0adb885300f68b797cea6"><div class="ttname"><a href="CAmDbusWrapper_8cpp.html#a6266fa85a7c0adb885300f68b797cea6">ROOT_INTROSPECT_XML</a></div><div class="ttdeci">#define ROOT_INTROSPECT_XML</div><div class="ttdoc">introspectio header </div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00041">CAmDbusWrapper.cpp:41</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_af25b51b4cdea2e33bddf7f9297ca02e2"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#af25b51b4cdea2e33bddf7f9297ca02e2">am::CAmDbusWrapper::dbusCheckCallback</a></div><div class="ttdeci">bool dbusCheckCallback(const sh_pollHandle_t handle, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00440">CAmDbusWrapper.cpp:440</a></div></div>
<div class="ttc" id="namespaceam_html_ab00ba22db19413e2040c2ab246f220c6"><div class="ttname"><a href="namespaceam.html#ab00ba22db19413e2040c2ab246f220c6">am::logError</a></div><div class="ttdeci">void logError(T value, TArgs...args)</div><div class="ttdoc">logs given values with errorlevel with the default context </div><div class="ttdef"><b>Definition:</b> <a href="CAmDltWrapper_8h_source.html#l00431">CAmDltWrapper.h:431</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a414b6c967b20f518753ad7f4afa8f811"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a414b6c967b20f518753ad7f4afa8f811">am::CAmDbusWrapper::~CAmDbusWrapper</a></div><div class="ttdeci">virtual ~CAmDbusWrapper()</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00151">CAmDbusWrapper.cpp:151</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a6a23dde3899b82a406fd1d888c677333"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a6a23dde3899b82a406fd1d888c677333">am::CAmDbusWrapper::removeWatch</a></div><div class="ttdeci">static void removeWatch(DBusWatch *watch, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00309">CAmDbusWrapper.cpp:309</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html">am::CAmDbusWrapper</a></div><div class="ttdoc">This wraps dbus and provides everything needed to anyone who wants to use dbus (including plugins)...</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8h_source.html#l00037">CAmDbusWrapper.h:37</a></div></div>
<div class="ttc" id="namespaceam_html_aa3dcb70029da317d661b6f422de1b4cea796d4cc86cd1605f4307478c128eee36"><div class="ttname"><a href="namespaceam.html#aa3dcb70029da317d661b6f422de1b4cea796d4cc86cd1605f4307478c128eee36">am::E_OK</a></div><div class="ttdoc">no error - positive reply </div><div class="ttdef"><b>Definition:</b> <a href="audiomanagertypes_8h_source.html#l00342">audiomanagertypes.h:342</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_adb082d9ab4b3cf9247204bda11b425f6"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#adb082d9ab4b3cf9247204bda11b425f6">am::CAmDbusWrapper::addTimeout</a></div><div class="ttdeci">static dbus_bool_t addTimeout(DBusTimeout *timeout, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00360">CAmDbusWrapper.cpp:360</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a9f761311f2c1697af7f4656740a1a704"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a9f761311f2c1697af7f4656740a1a704">am::CAmDbusWrapper::addWatch</a></div><div class="ttdeci">static dbus_bool_t addWatch(DBusWatch *watch, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00273">CAmDbusWrapper.cpp:273</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a5c75b210dac390a27f9b15b52536c7f0"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a5c75b210dac390a27f9b15b52536c7f0">am::CAmDbusWrapper::dbusFireCallback</a></div><div class="ttdeci">void dbusFireCallback(const pollfd pollfd, const sh_pollHandle_t handle, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00453">CAmDbusWrapper.cpp:453</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a18b2719ca3cee290dfef996252b74c18"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a18b2719ca3cee290dfef996252b74c18">am::CAmDbusWrapper::removeTimeout</a></div><div class="ttdeci">static void removeTimeout(DBusTimeout *timeout, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00393">CAmDbusWrapper.cpp:393</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_aae349240016dc3e557d2e83e1437c7eb"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#aae349240016dc3e557d2e83e1437c7eb">am::CAmDbusWrapper::getDBusConnection</a></div><div class="ttdeci">void getDBusConnection(DBusConnection *&amp;connection) const </div><div class="ttdoc">returns the dbus connection </div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00268">CAmDbusWrapper.cpp:268</a></div></div>
<div class="ttc" id="CAmDbusWrapper_8h_html"><div class="ttname"><a href="CAmDbusWrapper_8h.html">CAmDbusWrapper.h</a></div><div class="ttdoc">SPDX license identifier: MPL-2.0. </div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_af1abb258907275c66d8c41ba91a82e2f"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#af1abb258907275c66d8c41ba91a82e2f">am::CAmDbusWrapper::pDbusCheckCallback</a></div><div class="ttdeci">TAmShPollCheck&lt; CAmDbusWrapper &gt; pDbusCheckCallback</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8h_source.html#l00066">CAmDbusWrapper.h:66</a></div></div>
<div class="ttc" id="classam_1_1CAmDbusWrapper_html_a115584c27a48a673c165c25147c5900a"><div class="ttname"><a href="classam_1_1CAmDbusWrapper.html#a115584c27a48a673c165c25147c5900a">am::CAmDbusWrapper::dbusPrepareCallback</a></div><div class="ttdeci">void dbusPrepareCallback(const sh_pollHandle_t handle, void *userData)</div><div class="ttdef"><b>Definition:</b> <a href="CAmDbusWrapper_8cpp_source.html#l00477">CAmDbusWrapper.cpp:477</a></div></div>
<div class="ttc" id="namespaceam_html_a47991fcc6785a5c97037b611e7f7e1a8"><div class="ttname"><a href="namespaceam.html#a47991fcc6785a5c97037b611e7f7e1a8">am::sh_timerHandle_t</a></div><div class="ttdeci">sh_pollHandle_t sh_timerHandle_t</div><div class="ttdoc">this is a handle for a timer to be used with the SocketHandler </div><div class="ttdef"><b>Definition:</b> <a href="CAmSocketHandler_8h_source.html#l00052">CAmSocketHandler.h:52</a></div></div>
<div class="ttc" id="classam_1_1CAmSocketHandler_html_afe4e4806d91f9a4b3b1eb8a278f64cc9"><div class="ttname"><a href="classam_1_1CAmSocketHandler.html#afe4e4806d91f9a4b3b1eb8a278f64cc9">am::CAmSocketHandler::addTimer</a></div><div class="ttdeci">am_Error_e addTimer(const timespec &amp;timeouts, IAmShTimerCallBack *callback, sh_timerHandle_t &amp;handle, void *userData, const bool __attribute__((__unused__)) repeats=false)</div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  <ul>
    <li class="navelem"><a class="el" href="dir_789817cd9c9d85c1fb6b4cda55b71a5f.html">AudioManagerUtilities</a></li><li class="navelem"><a class="el" href="dir_2902e59c3e43e5b119a71402dd0eee5d.html">src</a></li><li class="navelem"><a class="el" href="CAmDbusWrapper_8cpp.html">CAmDbusWrapper.cpp</a></li>
    <li class="footer">Generated on Fri Feb 9 2018 14:50:29 for AudioManager by
    <a href="http://www.doxygen.org/index.html">
    <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.11 </li>
  </ul>
</div>
</body>
</html>