File: //usr/share/devhelp/books/dbus/api/dbus-list_8c-source.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>D-Bus: dbus-list.c Source File</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.4.7 -->
<div class="tabs">
<ul>
<li><a href="index.html"><span>Main Page</span></a></li>
<li><a href="modules.html"><span>Modules</span></a></li>
<li><a href="annotated.html"><span>Data Structures</span></a></li>
<li id="current"><a href="files.html"><span>Files</span></a></li>
<li><a href="pages.html"><span>Related Pages</span></a></li>
</ul></div>
<h1>dbus-list.c</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */</span>
<a name="l00002"></a>00002 <span class="comment">/* dbus-list.c Generic linked list utility (internal to D-Bus implementation)</span>
<a name="l00003"></a>00003 <span class="comment"> * </span>
<a name="l00004"></a>00004 <span class="comment"> * Copyright (C) 2002 Red Hat, Inc.</span>
<a name="l00005"></a>00005 <span class="comment"> *</span>
<a name="l00006"></a>00006 <span class="comment"> * Licensed under the Academic Free License version 2.1</span>
<a name="l00007"></a>00007 <span class="comment"> * </span>
<a name="l00008"></a>00008 <span class="comment"> * This program is free software; you can redistribute it and/or modify</span>
<a name="l00009"></a>00009 <span class="comment"> * it under the terms of the GNU General Public License as published by</span>
<a name="l00010"></a>00010 <span class="comment"> * the Free Software Foundation; either version 2 of the License, or</span>
<a name="l00011"></a>00011 <span class="comment"> * (at your option) any later version.</span>
<a name="l00012"></a>00012 <span class="comment"> *</span>
<a name="l00013"></a>00013 <span class="comment"> * This program is distributed in the hope that it will be useful,</span>
<a name="l00014"></a>00014 <span class="comment"> * but WITHOUT ANY WARRANTY; without even the implied warranty of</span>
<a name="l00015"></a>00015 <span class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the</span>
<a name="l00016"></a>00016 <span class="comment"> * GNU General Public License for more details.</span>
<a name="l00017"></a>00017 <span class="comment"> * </span>
<a name="l00018"></a>00018 <span class="comment"> * You should have received a copy of the GNU General Public License</span>
<a name="l00019"></a>00019 <span class="comment"> * along with this program; if not, write to the Free Software</span>
<a name="l00020"></a>00020 <span class="comment"> * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA</span>
<a name="l00021"></a>00021 <span class="comment"> *</span>
<a name="l00022"></a>00022 <span class="comment"> */</span>
<a name="l00023"></a>00023
<a name="l00024"></a>00024 <span class="preprocessor">#include "dbus-internals.h"</span>
<a name="l00025"></a>00025 <span class="preprocessor">#include "dbus-list.h"</span>
<a name="l00026"></a>00026 <span class="preprocessor">#include "dbus-mempool.h"</span>
<a name="l00027"></a>00027 <span class="preprocessor">#include "dbus-threads-internal.h"</span>
<a name="l00028"></a>00028
<a name="l00037"></a>00037 <span class="keyword">static</span> <a class="code" href="structDBusMemPool.html">DBusMemPool</a> *list_pool;
<a name="l00038"></a>00038 <a class="code" href="group__DBusInternalsUtils.html#gc8d22e9846ecc2845959082076de899b">_DBUS_DEFINE_GLOBAL_LOCK</a> (list);
<a name="l00039"></a>00039
<a name="l00050"></a>00050 <span class="comment">/* the mem pool is probably a speed hit, with the thread</span>
<a name="l00051"></a>00051 <span class="comment"> * lock, though it does still save memory - unknown.</span>
<a name="l00052"></a>00052 <span class="comment"> */</span>
<a name="l00053"></a>00053 <span class="keyword">static</span> <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00054"></a>00054 alloc_link (<span class="keywordtype">void</span> *data)
<a name="l00055"></a>00055 {
<a name="l00056"></a>00056 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00057"></a>00057
<a name="l00058"></a>00058 <a class="code" href="group__DBusInternalsUtils.html#g3b56fdb9df58277ee69d9f56a73bf383">_DBUS_LOCK</a> (list);
<a name="l00059"></a>00059
<a name="l00060"></a>00060 <span class="keywordflow">if</span> (list_pool == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00061"></a>00061 {
<a name="l00062"></a>00062 list_pool = <a class="code" href="group__DBusMemPool.html#gf1bae02bc5fcb879f77ff2c13ca03ac8">_dbus_mem_pool_new</a> (<span class="keyword">sizeof</span> (<a class="code" href="structDBusList.html">DBusList</a>), <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>);
<a name="l00063"></a>00063
<a name="l00064"></a>00064 <span class="keywordflow">if</span> (list_pool == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00065"></a>00065 {
<a name="l00066"></a>00066 <a class="code" href="group__DBusInternalsUtils.html#g1b7db80a2ea11235768ec8aa698df0a5">_DBUS_UNLOCK</a> (list);
<a name="l00067"></a>00067 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00068"></a>00068 }
<a name="l00069"></a>00069
<a name="l00070"></a>00070 link = <a class="code" href="group__DBusMemPool.html#g0946d54f767b4f55238f5a39c8543df1">_dbus_mem_pool_alloc</a> (list_pool);
<a name="l00071"></a>00071 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00072"></a>00072 {
<a name="l00073"></a>00073 <a class="code" href="group__DBusMemPool.html#g58e4f3def46410d5bb138a2b8f366b1a">_dbus_mem_pool_free</a> (list_pool);
<a name="l00074"></a>00074 list_pool = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00075"></a>00075 <a class="code" href="group__DBusInternalsUtils.html#g1b7db80a2ea11235768ec8aa698df0a5">_DBUS_UNLOCK</a> (list);
<a name="l00076"></a>00076 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00077"></a>00077 }
<a name="l00078"></a>00078 }
<a name="l00079"></a>00079 <span class="keywordflow">else</span>
<a name="l00080"></a>00080 {
<a name="l00081"></a>00081 link = <a class="code" href="group__DBusMemPool.html#g0946d54f767b4f55238f5a39c8543df1">_dbus_mem_pool_alloc</a> (list_pool);
<a name="l00082"></a>00082 }
<a name="l00083"></a>00083
<a name="l00084"></a>00084 <span class="keywordflow">if</span> (link)
<a name="l00085"></a>00085 link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a> = data;
<a name="l00086"></a>00086
<a name="l00087"></a>00087 <a class="code" href="group__DBusInternalsUtils.html#g1b7db80a2ea11235768ec8aa698df0a5">_DBUS_UNLOCK</a> (list);
<a name="l00088"></a>00088
<a name="l00089"></a>00089 <span class="keywordflow">return</span> link;
<a name="l00090"></a>00090 }
<a name="l00091"></a>00091
<a name="l00092"></a>00092 <span class="keyword">static</span> <span class="keywordtype">void</span>
<a name="l00093"></a>00093 free_link (<a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00094"></a>00094 {
<a name="l00095"></a>00095 <a class="code" href="group__DBusInternalsUtils.html#g3b56fdb9df58277ee69d9f56a73bf383">_DBUS_LOCK</a> (list);
<a name="l00096"></a>00096 <span class="keywordflow">if</span> (<a class="code" href="group__DBusMemPool.html#g4e2feaefee7384ed940059e6c7b0a9d5">_dbus_mem_pool_dealloc</a> (list_pool, link))
<a name="l00097"></a>00097 {
<a name="l00098"></a>00098 <a class="code" href="group__DBusMemPool.html#g58e4f3def46410d5bb138a2b8f366b1a">_dbus_mem_pool_free</a> (list_pool);
<a name="l00099"></a>00099 list_pool = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00100"></a>00100 }
<a name="l00101"></a>00101
<a name="l00102"></a>00102 <a class="code" href="group__DBusInternalsUtils.html#g1b7db80a2ea11235768ec8aa698df0a5">_DBUS_UNLOCK</a> (list);
<a name="l00103"></a>00103 }
<a name="l00104"></a>00104
<a name="l00105"></a>00105 <span class="keyword">static</span> <span class="keywordtype">void</span>
<a name="l00106"></a>00106 link_before (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00107"></a>00107 <a class="code" href="structDBusList.html">DBusList</a> *before_this_link,
<a name="l00108"></a>00108 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00109"></a>00109 {
<a name="l00110"></a>00110 <span class="keywordflow">if</span> (*list == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00111"></a>00111 {
<a name="l00112"></a>00112 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00113"></a>00113 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link;
<a name="l00114"></a>00114 *list = link;
<a name="l00115"></a>00115 }
<a name="l00116"></a>00116 <span class="keywordflow">else</span>
<a name="l00117"></a>00117 {
<a name="l00118"></a>00118 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = before_this_link;
<a name="l00119"></a>00119 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = before_this_link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>;
<a name="l00120"></a>00120 before_this_link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00121"></a>00121 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link;
<a name="l00122"></a>00122
<a name="l00123"></a>00123 <span class="keywordflow">if</span> (before_this_link == *list)
<a name="l00124"></a>00124 *list = link;
<a name="l00125"></a>00125 }
<a name="l00126"></a>00126 }
<a name="l00127"></a>00127
<a name="l00128"></a>00128 <span class="keyword">static</span> <span class="keywordtype">void</span>
<a name="l00129"></a>00129 link_after (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00130"></a>00130 <a class="code" href="structDBusList.html">DBusList</a> *after_this_link,
<a name="l00131"></a>00131 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00132"></a>00132 {
<a name="l00133"></a>00133 <span class="keywordflow">if</span> (*list == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00134"></a>00134 {
<a name="l00135"></a>00135 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00136"></a>00136 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link;
<a name="l00137"></a>00137 *list = link;
<a name="l00138"></a>00138 }
<a name="l00139"></a>00139 <span class="keywordflow">else</span>
<a name="l00140"></a>00140 {
<a name="l00141"></a>00141 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = after_this_link;
<a name="l00142"></a>00142 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = after_this_link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00143"></a>00143 after_this_link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link;
<a name="l00144"></a>00144 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00145"></a>00145 }
<a name="l00146"></a>00146 }
<a name="l00147"></a>00147
<a name="l00217"></a>00217 <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00218"></a><a class="code" href="group__DBusList.html#gc20b9981531cef590d49a59240344cd8">00218</a> <a class="code" href="group__DBusList.html#gc20b9981531cef590d49a59240344cd8">_dbus_list_alloc_link</a> (<span class="keywordtype">void</span> *data)
<a name="l00219"></a>00219 {
<a name="l00220"></a>00220 <span class="keywordflow">return</span> alloc_link (data);
<a name="l00221"></a>00221 }
<a name="l00222"></a>00222
<a name="l00229"></a>00229 <span class="keywordtype">void</span>
<a name="l00230"></a><a class="code" href="group__DBusList.html#g6e824f717125ce40c549d5402e32610f">00230</a> <a class="code" href="group__DBusList.html#g6e824f717125ce40c549d5402e32610f">_dbus_list_free_link</a> (<a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00231"></a>00231 {
<a name="l00232"></a>00232 free_link (link);
<a name="l00233"></a>00233 }
<a name="l00234"></a>00234
<a name="l00235"></a>00235
<a name="l00245"></a>00245 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00246"></a><a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">00246</a> <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00247"></a>00247 <span class="keywordtype">void</span> *data)
<a name="l00248"></a>00248 {
<a name="l00249"></a>00249 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (list, data))
<a name="l00250"></a>00250 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00251"></a>00251
<a name="l00252"></a>00252 <span class="comment">/* Now cycle the list forward one so the prepended node is the tail */</span>
<a name="l00253"></a>00253 *list = (*list)->next;
<a name="l00254"></a>00254
<a name="l00255"></a>00255 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00256"></a>00256 }
<a name="l00257"></a>00257
<a name="l00267"></a>00267 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00268"></a><a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">00268</a> <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00269"></a>00269 <span class="keywordtype">void</span> *data)
<a name="l00270"></a>00270 {
<a name="l00271"></a>00271 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00272"></a>00272
<a name="l00273"></a>00273 link = alloc_link (data);
<a name="l00274"></a>00274 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00275"></a>00275 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00276"></a>00276
<a name="l00277"></a>00277 link_before (list, *list, link);
<a name="l00278"></a>00278
<a name="l00279"></a>00279 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00280"></a>00280 }
<a name="l00281"></a>00281
<a name="l00290"></a>00290 <span class="keywordtype">void</span>
<a name="l00291"></a><a class="code" href="group__DBusList.html#g20e549175e2b8f450f907592dc39d953">00291</a> <a class="code" href="group__DBusList.html#g20e549175e2b8f450f907592dc39d953">_dbus_list_append_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00292"></a>00292 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00293"></a>00293 {
<a name="l00294"></a>00294 <a class="code" href="group__DBusList.html#gb3dd068e3bd8a319c0d12150785050a7">_dbus_list_prepend_link</a> (list, link);
<a name="l00295"></a>00295
<a name="l00296"></a>00296 <span class="comment">/* Now cycle the list forward one so the prepended node is the tail */</span>
<a name="l00297"></a>00297 *list = (*list)-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00298"></a>00298 }
<a name="l00299"></a>00299
<a name="l00308"></a>00308 <span class="keywordtype">void</span>
<a name="l00309"></a><a class="code" href="group__DBusList.html#gb3dd068e3bd8a319c0d12150785050a7">00309</a> <a class="code" href="group__DBusList.html#gb3dd068e3bd8a319c0d12150785050a7">_dbus_list_prepend_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00310"></a>00310 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00311"></a>00311 {
<a name="l00312"></a>00312 link_before (list, *list, link);
<a name="l00313"></a>00313 }
<a name="l00314"></a>00314
<a name="l00315"></a>00315 <span class="preprocessor">#ifdef DBUS_BUILD_TESTS</span>
<a name="l00316"></a>00316 <span class="preprocessor"></span>
<a name="l00324"></a>00324 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00325"></a>00325 _dbus_list_insert_before (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00326"></a>00326 <a class="code" href="structDBusList.html">DBusList</a> *before_this_link,
<a name="l00327"></a>00327 <span class="keywordtype">void</span> *data)
<a name="l00328"></a>00328 {
<a name="l00329"></a>00329 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00330"></a>00330
<a name="l00331"></a>00331 <span class="keywordflow">if</span> (before_this_link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00332"></a>00332 <span class="keywordflow">return</span> <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (list, data);
<a name="l00333"></a>00333 <span class="keywordflow">else</span>
<a name="l00334"></a>00334 {
<a name="l00335"></a>00335 link = alloc_link (data);
<a name="l00336"></a>00336 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00337"></a>00337 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00338"></a>00338
<a name="l00339"></a>00339 link_before (list, before_this_link, link);
<a name="l00340"></a>00340 }
<a name="l00341"></a>00341
<a name="l00342"></a>00342 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00343"></a>00343 }
<a name="l00344"></a>00344 <span class="preprocessor">#endif </span><span class="comment">/* DBUS_BUILD_TESTS */</span>
<a name="l00345"></a>00345
<a name="l00354"></a>00354 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00355"></a><a class="code" href="group__DBusList.html#g2dacb82db59f0012951d8245017473c9">00355</a> <a class="code" href="group__DBusList.html#g2dacb82db59f0012951d8245017473c9">_dbus_list_insert_after</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00356"></a>00356 <a class="code" href="structDBusList.html">DBusList</a> *after_this_link,
<a name="l00357"></a>00357 <span class="keywordtype">void</span> *data)
<a name="l00358"></a>00358 {
<a name="l00359"></a>00359 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00360"></a>00360
<a name="l00361"></a>00361 <span class="keywordflow">if</span> (after_this_link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00362"></a>00362 <span class="keywordflow">return</span> <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (list, data);
<a name="l00363"></a>00363 <span class="keywordflow">else</span>
<a name="l00364"></a>00364 {
<a name="l00365"></a>00365 link = alloc_link (data);
<a name="l00366"></a>00366 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00367"></a>00367 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00368"></a>00368
<a name="l00369"></a>00369 link_after (list, after_this_link, link);
<a name="l00370"></a>00370 }
<a name="l00371"></a>00371
<a name="l00372"></a>00372 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00373"></a>00373 }
<a name="l00374"></a>00374
<a name="l00382"></a>00382 <span class="keywordtype">void</span>
<a name="l00383"></a><a class="code" href="group__DBusList.html#g0d1fde0acf1330cb41a9c290c7ae87b5">00383</a> <a class="code" href="group__DBusList.html#g0d1fde0acf1330cb41a9c290c7ae87b5">_dbus_list_insert_before_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00384"></a>00384 <a class="code" href="structDBusList.html">DBusList</a> *before_this_link,
<a name="l00385"></a>00385 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00386"></a>00386 {
<a name="l00387"></a>00387 <span class="keywordflow">if</span> (before_this_link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00388"></a>00388 <a class="code" href="group__DBusList.html#g20e549175e2b8f450f907592dc39d953">_dbus_list_append_link</a> (list, link);
<a name="l00389"></a>00389 <span class="keywordflow">else</span>
<a name="l00390"></a>00390 link_before (list, before_this_link, link);
<a name="l00391"></a>00391 }
<a name="l00392"></a>00392
<a name="l00400"></a>00400 <span class="keywordtype">void</span>
<a name="l00401"></a><a class="code" href="group__DBusList.html#g20f6b11dd53979b94b6c4822ff6c1141">00401</a> <a class="code" href="group__DBusList.html#g20f6b11dd53979b94b6c4822ff6c1141">_dbus_list_insert_after_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00402"></a>00402 <a class="code" href="structDBusList.html">DBusList</a> *after_this_link,
<a name="l00403"></a>00403 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00404"></a>00404 {
<a name="l00405"></a>00405 <span class="keywordflow">if</span> (after_this_link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00406"></a>00406 <a class="code" href="group__DBusList.html#gb3dd068e3bd8a319c0d12150785050a7">_dbus_list_prepend_link</a> (list, link);
<a name="l00407"></a>00407 <span class="keywordflow">else</span>
<a name="l00408"></a>00408 link_after (list, after_this_link, link);
<a name="l00409"></a>00409 }
<a name="l00410"></a>00410
<a name="l00421"></a>00421 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00422"></a><a class="code" href="group__DBusList.html#g202e6ac8ad3e4a9d4413e0248ffcf3e3">00422</a> <a class="code" href="group__DBusList.html#g202e6ac8ad3e4a9d4413e0248ffcf3e3">_dbus_list_remove</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00423"></a>00423 <span class="keywordtype">void</span> *data)
<a name="l00424"></a>00424 {
<a name="l00425"></a>00425 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00426"></a>00426
<a name="l00427"></a>00427 link = *list;
<a name="l00428"></a>00428 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00429"></a>00429 {
<a name="l00430"></a>00430 <span class="keywordflow">if</span> (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a> == data)
<a name="l00431"></a>00431 {
<a name="l00432"></a>00432 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (list, link);
<a name="l00433"></a>00433 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00434"></a>00434 }
<a name="l00435"></a>00435
<a name="l00436"></a>00436 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00437"></a>00437 }
<a name="l00438"></a>00438
<a name="l00439"></a>00439 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00440"></a>00440 }
<a name="l00441"></a>00441
<a name="l00452"></a>00452 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00453"></a><a class="code" href="group__DBusList.html#gd93f1fc853914144e94fc7a7dc0945aa">00453</a> <a class="code" href="group__DBusList.html#gd93f1fc853914144e94fc7a7dc0945aa">_dbus_list_remove_last</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00454"></a>00454 <span class="keywordtype">void</span> *data)
<a name="l00455"></a>00455 {
<a name="l00456"></a>00456 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00457"></a>00457
<a name="l00458"></a>00458 link = <a class="code" href="group__DBusList.html#g5929ad5253d2f538158e513e9df3002b">_dbus_list_find_last</a> (list, data);
<a name="l00459"></a>00459 <span class="keywordflow">if</span> (link)
<a name="l00460"></a>00460 {
<a name="l00461"></a>00461 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (list, link);
<a name="l00462"></a>00462 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00463"></a>00463 }
<a name="l00464"></a>00464 <span class="keywordflow">else</span>
<a name="l00465"></a>00465 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00466"></a>00466 }
<a name="l00467"></a>00467
<a name="l00478"></a>00478 <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00479"></a><a class="code" href="group__DBusList.html#g5929ad5253d2f538158e513e9df3002b">00479</a> <a class="code" href="group__DBusList.html#g5929ad5253d2f538158e513e9df3002b">_dbus_list_find_last</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00480"></a>00480 <span class="keywordtype">void</span> *data)
<a name="l00481"></a>00481 {
<a name="l00482"></a>00482 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00483"></a>00483
<a name="l00484"></a>00484 link = <a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">_dbus_list_get_last_link</a> (list);
<a name="l00485"></a>00485
<a name="l00486"></a>00486 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00487"></a>00487 {
<a name="l00488"></a>00488 <span class="keywordflow">if</span> (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a> == data)
<a name="l00489"></a>00489 <span class="keywordflow">return</span> link;
<a name="l00490"></a>00490
<a name="l00491"></a>00491 link = <a class="code" href="group__DBusList.html#g6637493bf5fc09bddb44ac295c475cae">_dbus_list_get_prev_link</a> (list, link);
<a name="l00492"></a>00492 }
<a name="l00493"></a>00493
<a name="l00494"></a>00494 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00495"></a>00495 }
<a name="l00496"></a>00496
<a name="l00505"></a>00505 <span class="keywordtype">void</span>
<a name="l00506"></a><a class="code" href="group__DBusList.html#g57f1fc73dc1a4f8a7bf9860e000b1703">00506</a> <a class="code" href="group__DBusList.html#g57f1fc73dc1a4f8a7bf9860e000b1703">_dbus_list_unlink</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00507"></a>00507 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00508"></a>00508 {
<a name="l00509"></a>00509 <span class="keywordflow">if</span> (link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> == link)
<a name="l00510"></a>00510 {
<a name="l00511"></a>00511 <span class="comment">/* one-element list */</span>
<a name="l00512"></a>00512 *list = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00513"></a>00513 }
<a name="l00514"></a>00514 <span class="keywordflow">else</span>
<a name="l00515"></a>00515 {
<a name="l00516"></a>00516 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00517"></a>00517 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>;
<a name="l00518"></a>00518
<a name="l00519"></a>00519 <span class="keywordflow">if</span> (*list == link)
<a name="l00520"></a>00520 *list = link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00521"></a>00521 }
<a name="l00522"></a>00522
<a name="l00523"></a>00523 link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00524"></a>00524 link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00525"></a>00525 }
<a name="l00526"></a>00526
<a name="l00533"></a>00533 <span class="keywordtype">void</span>
<a name="l00534"></a><a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">00534</a> <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00535"></a>00535 <a class="code" href="structDBusList.html">DBusList</a> *link)
<a name="l00536"></a>00536 {
<a name="l00537"></a>00537 <a class="code" href="group__DBusList.html#g57f1fc73dc1a4f8a7bf9860e000b1703">_dbus_list_unlink</a> (list, link);
<a name="l00538"></a>00538 free_link (link);
<a name="l00539"></a>00539 }
<a name="l00540"></a>00540
<a name="l00548"></a>00548 <span class="keywordtype">void</span>
<a name="l00549"></a><a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">00549</a> <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00550"></a>00550 {
<a name="l00551"></a>00551 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00552"></a>00552
<a name="l00553"></a>00553 link = *list;
<a name="l00554"></a>00554 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00555"></a>00555 {
<a name="l00556"></a>00556 <a class="code" href="structDBusList.html">DBusList</a> *next = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00557"></a>00557
<a name="l00558"></a>00558 free_link (link);
<a name="l00559"></a>00559
<a name="l00560"></a>00560 link = next;
<a name="l00561"></a>00561 }
<a name="l00562"></a>00562
<a name="l00563"></a>00563 *list = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00564"></a>00564 }
<a name="l00565"></a>00565
<a name="l00573"></a>00573 <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00574"></a><a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">00574</a> <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00575"></a>00575 {
<a name="l00576"></a>00576 <span class="keywordflow">return</span> *list;
<a name="l00577"></a>00577 }
<a name="l00578"></a>00578
<a name="l00586"></a>00586 <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00587"></a><a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">00587</a> <a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">_dbus_list_get_last_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00588"></a>00588 {
<a name="l00589"></a>00589 <span class="keywordflow">if</span> (*list == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00590"></a>00590 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00591"></a>00591 <span class="keywordflow">else</span>
<a name="l00592"></a>00592 <span class="keywordflow">return</span> (*list)->prev;
<a name="l00593"></a>00593 }
<a name="l00594"></a>00594
<a name="l00602"></a>00602 <span class="keywordtype">void</span>*
<a name="l00603"></a><a class="code" href="group__DBusList.html#g18afc36fff1636a71295bcc7a75dc4f6">00603</a> <a class="code" href="group__DBusList.html#g18afc36fff1636a71295bcc7a75dc4f6">_dbus_list_get_last</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00604"></a>00604 {
<a name="l00605"></a>00605 <span class="keywordflow">if</span> (*list == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00606"></a>00606 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00607"></a>00607 <span class="keywordflow">else</span>
<a name="l00608"></a>00608 <span class="keywordflow">return</span> (*list)->prev->data;
<a name="l00609"></a>00609 }
<a name="l00610"></a>00610
<a name="l00618"></a>00618 <span class="keywordtype">void</span>*
<a name="l00619"></a><a class="code" href="group__DBusList.html#g254e18f698f5fc518bde031e723e67c6">00619</a> <a class="code" href="group__DBusList.html#g254e18f698f5fc518bde031e723e67c6">_dbus_list_get_first</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00620"></a>00620 {
<a name="l00621"></a>00621 <span class="keywordflow">if</span> (*list == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00622"></a>00622 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00623"></a>00623 <span class="keywordflow">else</span>
<a name="l00624"></a>00624 <span class="keywordflow">return</span> (*list)->data;
<a name="l00625"></a>00625 }
<a name="l00626"></a>00626
<a name="l00634"></a>00634 <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00635"></a><a class="code" href="group__DBusList.html#gab9a957eca9bf5466bbf377a23b4b25c">00635</a> <a class="code" href="group__DBusList.html#gab9a957eca9bf5466bbf377a23b4b25c">_dbus_list_pop_first_link</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00636"></a>00636 {
<a name="l00637"></a>00637 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00638"></a>00638
<a name="l00639"></a>00639 link = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list);
<a name="l00640"></a>00640 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00641"></a>00641 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00642"></a>00642
<a name="l00643"></a>00643 <a class="code" href="group__DBusList.html#g57f1fc73dc1a4f8a7bf9860e000b1703">_dbus_list_unlink</a> (list, link);
<a name="l00644"></a>00644
<a name="l00645"></a>00645 <span class="keywordflow">return</span> link;
<a name="l00646"></a>00646 }
<a name="l00647"></a>00647
<a name="l00655"></a>00655 <span class="keywordtype">void</span>*
<a name="l00656"></a><a class="code" href="group__DBusList.html#gcb96c9d3e9a869e63b8db4f8913a5a60">00656</a> <a class="code" href="group__DBusList.html#gcb96c9d3e9a869e63b8db4f8913a5a60">_dbus_list_pop_first</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00657"></a>00657 {
<a name="l00658"></a>00658 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00659"></a>00659 <span class="keywordtype">void</span> *data;
<a name="l00660"></a>00660
<a name="l00661"></a>00661 link = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list);
<a name="l00662"></a>00662 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00663"></a>00663 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00664"></a>00664
<a name="l00665"></a>00665 data = link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>;
<a name="l00666"></a>00666 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (list, link);
<a name="l00667"></a>00667
<a name="l00668"></a>00668 <span class="keywordflow">return</span> data;
<a name="l00669"></a>00669 }
<a name="l00670"></a>00670
<a name="l00678"></a>00678 <span class="keywordtype">void</span>*
<a name="l00679"></a><a class="code" href="group__DBusList.html#gad2ba56c77f2bba8e1e8dcb4b24542a6">00679</a> <a class="code" href="group__DBusList.html#gad2ba56c77f2bba8e1e8dcb4b24542a6">_dbus_list_pop_last</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00680"></a>00680 {
<a name="l00681"></a>00681 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00682"></a>00682 <span class="keywordtype">void</span> *data;
<a name="l00683"></a>00683
<a name="l00684"></a>00684 link = <a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">_dbus_list_get_last_link</a> (list);
<a name="l00685"></a>00685 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00686"></a>00686 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00687"></a>00687
<a name="l00688"></a>00688 data = link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>;
<a name="l00689"></a>00689 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (list, link);
<a name="l00690"></a>00690
<a name="l00691"></a>00691 <span class="keywordflow">return</span> data;
<a name="l00692"></a>00692 }
<a name="l00693"></a>00693
<a name="l00694"></a>00694 <span class="preprocessor">#ifdef DBUS_BUILD_TESTS</span>
<a name="l00695"></a>00695 <span class="preprocessor"></span>
<a name="l00702"></a>00702 <a class="code" href="structDBusList.html">DBusList</a>*
<a name="l00703"></a>00703 _dbus_list_pop_last_link (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00704"></a>00704 {
<a name="l00705"></a>00705 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00706"></a>00706
<a name="l00707"></a>00707 link = <a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">_dbus_list_get_last_link</a> (list);
<a name="l00708"></a>00708 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00709"></a>00709 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00710"></a>00710
<a name="l00711"></a>00711 <a class="code" href="group__DBusList.html#g57f1fc73dc1a4f8a7bf9860e000b1703">_dbus_list_unlink</a> (list, link);
<a name="l00712"></a>00712
<a name="l00713"></a>00713 <span class="keywordflow">return</span> link;
<a name="l00714"></a>00714 }
<a name="l00715"></a>00715 <span class="preprocessor">#endif </span><span class="comment">/* DBUS_BUILD_TESTS */</span>
<a name="l00716"></a>00716
<a name="l00726"></a>00726 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00727"></a><a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">00727</a> <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00728"></a>00728 <a class="code" href="structDBusList.html">DBusList</a> **dest)
<a name="l00729"></a>00729 {
<a name="l00730"></a>00730 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00731"></a>00731
<a name="l00732"></a>00732 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (list != dest);
<a name="l00733"></a>00733
<a name="l00734"></a>00734 *dest = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00735"></a>00735
<a name="l00736"></a>00736 link = *list;
<a name="l00737"></a>00737 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00738"></a>00738 {
<a name="l00739"></a>00739 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (dest, link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>))
<a name="l00740"></a>00740 {
<a name="l00741"></a>00741 <span class="comment">/* free what we have so far */</span>
<a name="l00742"></a>00742 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (dest);
<a name="l00743"></a>00743 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00744"></a>00744 }
<a name="l00745"></a>00745
<a name="l00746"></a>00746 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00747"></a>00747 }
<a name="l00748"></a>00748
<a name="l00749"></a>00749 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00750"></a>00750 }
<a name="l00751"></a>00751
<a name="l00759"></a>00759 <span class="keywordtype">int</span>
<a name="l00760"></a><a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">00760</a> <a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">_dbus_list_get_length</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00761"></a>00761 {
<a name="l00762"></a>00762 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00763"></a>00763 <span class="keywordtype">int</span> length;
<a name="l00764"></a>00764
<a name="l00765"></a>00765 length = 0;
<a name="l00766"></a>00766
<a name="l00767"></a>00767 link = *list;
<a name="l00768"></a>00768 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00769"></a>00769 {
<a name="l00770"></a>00770 ++length;
<a name="l00771"></a>00771
<a name="l00772"></a>00772 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00773"></a>00773 }
<a name="l00774"></a>00774
<a name="l00775"></a>00775 <span class="keywordflow">return</span> length;
<a name="l00776"></a>00776 }
<a name="l00777"></a>00777
<a name="l00788"></a>00788 <span class="keywordtype">void</span>
<a name="l00789"></a><a class="code" href="group__DBusList.html#g8dd69084b53361803a765e6d53d5b9d1">00789</a> <a class="code" href="group__DBusList.html#g8dd69084b53361803a765e6d53d5b9d1">_dbus_list_foreach</a> (<a class="code" href="structDBusList.html">DBusList</a> **list,
<a name="l00790"></a>00790 <a class="code" href="group__DBusInternalsUtils.html#gadf9d45082dd1c9f59d8420d13492669">DBusForeachFunction</a> function,
<a name="l00791"></a>00791 <span class="keywordtype">void</span> *data)
<a name="l00792"></a>00792 {
<a name="l00793"></a>00793 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00794"></a>00794
<a name="l00795"></a>00795 link = *list;
<a name="l00796"></a>00796 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00797"></a>00797 {
<a name="l00798"></a>00798 <a class="code" href="structDBusList.html">DBusList</a> *next = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00799"></a>00799
<a name="l00800"></a>00800 (* function) (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>, data);
<a name="l00801"></a>00801
<a name="l00802"></a>00802 link = next;
<a name="l00803"></a>00803 }
<a name="l00804"></a>00804 }
<a name="l00805"></a>00805
<a name="l00812"></a>00812 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00813"></a><a class="code" href="group__DBusList.html#g1d0e850f8e151630fa94d3b05e6038d9">00813</a> <a class="code" href="group__DBusList.html#g1d0e850f8e151630fa94d3b05e6038d9">_dbus_list_length_is_one</a> (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00814"></a>00814 {
<a name="l00815"></a>00815 <span class="keywordflow">return</span> (*list != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a> &&
<a name="l00816"></a>00816 (*list)->next == *list);
<a name="l00817"></a>00817 }
<a name="l00818"></a>00818
<a name="l00821"></a>00821 <span class="preprocessor">#ifdef DBUS_BUILD_TESTS</span>
<a name="l00822"></a>00822 <span class="preprocessor"></span><span class="preprocessor">#include "dbus-test.h"</span>
<a name="l00823"></a>00823 <span class="preprocessor">#include <stdio.h></span>
<a name="l00824"></a>00824
<a name="l00825"></a>00825 <span class="keyword">static</span> <span class="keywordtype">void</span>
<a name="l00826"></a>00826 verify_list (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00827"></a>00827 {
<a name="l00828"></a>00828 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00829"></a>00829 <span class="keywordtype">int</span> length;
<a name="l00830"></a>00830
<a name="l00831"></a>00831 link = *list;
<a name="l00832"></a>00832
<a name="l00833"></a>00833 <span class="keywordflow">if</span> (link == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00834"></a>00834 <span class="keywordflow">return</span>;
<a name="l00835"></a>00835
<a name="l00836"></a>00836 <span class="keywordflow">if</span> (link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> == link)
<a name="l00837"></a>00837 {
<a name="l00838"></a>00838 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> == link);
<a name="l00839"></a>00839 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (*list == link);
<a name="l00840"></a>00840 <span class="keywordflow">return</span>;
<a name="l00841"></a>00841 }
<a name="l00842"></a>00842
<a name="l00843"></a>00843 length = 0;
<a name="l00844"></a>00844 <span class="keywordflow">do</span>
<a name="l00845"></a>00845 {
<a name="l00846"></a>00846 length += 1;
<a name="l00847"></a>00847 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (link-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> == link);
<a name="l00848"></a>00848 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>-><a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> == link);
<a name="l00849"></a>00849 link = link-><a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00850"></a>00850 }
<a name="l00851"></a>00851 <span class="keywordflow">while</span> (link != *list);
<a name="l00852"></a>00852
<a name="l00853"></a>00853 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (length == <a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">_dbus_list_get_length</a> (list));
<a name="l00854"></a>00854
<a name="l00855"></a>00855 <span class="keywordflow">if</span> (length == 1)
<a name="l00856"></a>00856 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusList.html#g1d0e850f8e151630fa94d3b05e6038d9">_dbus_list_length_is_one</a> (list));
<a name="l00857"></a>00857 <span class="keywordflow">else</span>
<a name="l00858"></a>00858 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (!<a class="code" href="group__DBusList.html#g1d0e850f8e151630fa94d3b05e6038d9">_dbus_list_length_is_one</a> (list));
<a name="l00859"></a>00859 }
<a name="l00860"></a>00860
<a name="l00861"></a>00861 <span class="keyword">static</span> <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00862"></a>00862 is_ascending_sequence (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00863"></a>00863 {
<a name="l00864"></a>00864 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00865"></a>00865 <span class="keywordtype">int</span> prev;
<a name="l00866"></a>00866
<a name="l00867"></a>00867 prev = <a class="code" href="group__DBusInternalsUtils.html#g3bf800f1b6cc23f80006861d7417c8c8">_DBUS_INT_MIN</a>;
<a name="l00868"></a>00868
<a name="l00869"></a>00869 link = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list);
<a name="l00870"></a>00870 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00871"></a>00871 {
<a name="l00872"></a>00872 <span class="keywordtype">int</span> v = <a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>);
<a name="l00873"></a>00873
<a name="l00874"></a>00874 <span class="keywordflow">if</span> (v <= prev)
<a name="l00875"></a>00875 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00876"></a>00876
<a name="l00877"></a>00877 prev = v;
<a name="l00878"></a>00878
<a name="l00879"></a>00879 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00880"></a>00880 }
<a name="l00881"></a>00881
<a name="l00882"></a>00882 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00883"></a>00883 }
<a name="l00884"></a>00884
<a name="l00885"></a>00885 <span class="keyword">static</span> <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00886"></a>00886 is_descending_sequence (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00887"></a>00887 {
<a name="l00888"></a>00888 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00889"></a>00889 <span class="keywordtype">int</span> prev;
<a name="l00890"></a>00890
<a name="l00891"></a>00891 prev = <a class="code" href="group__DBusInternalsUtils.html#g5627db5e165848477e620846f6414db1">_DBUS_INT_MAX</a>;
<a name="l00892"></a>00892
<a name="l00893"></a>00893 link = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list);
<a name="l00894"></a>00894 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00895"></a>00895 {
<a name="l00896"></a>00896 <span class="keywordtype">int</span> v = <a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>);
<a name="l00897"></a>00897
<a name="l00898"></a>00898 <span class="keywordflow">if</span> (v >= prev)
<a name="l00899"></a>00899 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00900"></a>00900
<a name="l00901"></a>00901 prev = v;
<a name="l00902"></a>00902
<a name="l00903"></a>00903 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00904"></a>00904 }
<a name="l00905"></a>00905
<a name="l00906"></a>00906 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00907"></a>00907 }
<a name="l00908"></a>00908
<a name="l00909"></a>00909 <span class="keyword">static</span> <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00910"></a>00910 all_even_values (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00911"></a>00911 {
<a name="l00912"></a>00912 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00913"></a>00913
<a name="l00914"></a>00914 link = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list);
<a name="l00915"></a>00915 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00916"></a>00916 {
<a name="l00917"></a>00917 <span class="keywordtype">int</span> v = <a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>);
<a name="l00918"></a>00918
<a name="l00919"></a>00919 <span class="keywordflow">if</span> ((v % 2) != 0)
<a name="l00920"></a>00920 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00921"></a>00921
<a name="l00922"></a>00922 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00923"></a>00923 }
<a name="l00924"></a>00924
<a name="l00925"></a>00925 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00926"></a>00926 }
<a name="l00927"></a>00927
<a name="l00928"></a>00928 <span class="keyword">static</span> <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00929"></a>00929 all_odd_values (<a class="code" href="structDBusList.html">DBusList</a> **list)
<a name="l00930"></a>00930 {
<a name="l00931"></a>00931 <a class="code" href="structDBusList.html">DBusList</a> *link;
<a name="l00932"></a>00932
<a name="l00933"></a>00933 link = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list);
<a name="l00934"></a>00934 <span class="keywordflow">while</span> (link != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l00935"></a>00935 {
<a name="l00936"></a>00936 <span class="keywordtype">int</span> v = <a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>);
<a name="l00937"></a>00937
<a name="l00938"></a>00938 <span class="keywordflow">if</span> ((v % 2) == 0)
<a name="l00939"></a>00939 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00940"></a>00940
<a name="l00941"></a>00941 link = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list, link);
<a name="l00942"></a>00942 }
<a name="l00943"></a>00943
<a name="l00944"></a>00944 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00945"></a>00945 }
<a name="l00946"></a>00946
<a name="l00947"></a>00947 <span class="keyword">static</span> <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00948"></a>00948 lists_equal (<a class="code" href="structDBusList.html">DBusList</a> **list1,
<a name="l00949"></a>00949 <a class="code" href="structDBusList.html">DBusList</a> **list2)
<a name="l00950"></a>00950 {
<a name="l00951"></a>00951 <a class="code" href="structDBusList.html">DBusList</a> *link1;
<a name="l00952"></a>00952 <a class="code" href="structDBusList.html">DBusList</a> *link2;
<a name="l00953"></a>00953
<a name="l00954"></a>00954 link1 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list1);
<a name="l00955"></a>00955 link2 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (list2);
<a name="l00956"></a>00956 <span class="keywordflow">while</span> (link1 && link2)
<a name="l00957"></a>00957 {
<a name="l00958"></a>00958 <span class="keywordflow">if</span> (link1-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a> != link2-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>)
<a name="l00959"></a>00959 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00960"></a>00960
<a name="l00961"></a>00961 link1 = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list1, link1);
<a name="l00962"></a>00962 link2 = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (list2, link2);
<a name="l00963"></a>00963 }
<a name="l00964"></a>00964
<a name="l00965"></a>00965 <span class="keywordflow">if</span> (link1 || link2)
<a name="l00966"></a>00966 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga93f0eb578d23995850d61f7d61c55c1">FALSE</a>;
<a name="l00967"></a>00967
<a name="l00968"></a>00968 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l00969"></a>00969 }
<a name="l00970"></a>00970
<a name="l00976"></a>00976 <a class="code" href="group__DBusTypes.html#g39c9cb0f3a2a8ad6f55cc4855d035349">dbus_bool_t</a>
<a name="l00977"></a>00977 _dbus_list_test (<span class="keywordtype">void</span>)
<a name="l00978"></a>00978 {
<a name="l00979"></a>00979 <a class="code" href="structDBusList.html">DBusList</a> *list1;
<a name="l00980"></a>00980 <a class="code" href="structDBusList.html">DBusList</a> *list2;
<a name="l00981"></a>00981 <a class="code" href="structDBusList.html">DBusList</a> *link1;
<a name="l00982"></a>00982 <a class="code" href="structDBusList.html">DBusList</a> *link2;
<a name="l00983"></a>00983 <a class="code" href="structDBusList.html">DBusList</a> *copy1;
<a name="l00984"></a>00984 <a class="code" href="structDBusList.html">DBusList</a> *copy2;
<a name="l00985"></a>00985 <span class="keywordtype">int</span> i;
<a name="l00986"></a>00986
<a name="l00987"></a>00987 list1 = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00988"></a>00988 list2 = <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>;
<a name="l00989"></a>00989
<a name="l00990"></a>00990 <span class="comment">/* Test append and prepend */</span>
<a name="l00991"></a>00991
<a name="l00992"></a>00992 i = 0;
<a name="l00993"></a>00993 <span class="keywordflow">while</span> (i < 10)
<a name="l00994"></a>00994 {
<a name="l00995"></a>00995 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i)))
<a name="l00996"></a>00996 <a class="code" href="group__DBusInternalsUtils.html#g0c4961ec784874f1b1f3aeccea8d3da1">_dbus_assert_not_reached</a> (<span class="stringliteral">"could not allocate for append"</span>);
<a name="l00997"></a>00997
<a name="l00998"></a>00998 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i)))
<a name="l00999"></a>00999 <a class="code" href="group__DBusInternalsUtils.html#g0c4961ec784874f1b1f3aeccea8d3da1">_dbus_assert_not_reached</a> (<span class="stringliteral">"count not allocate for prepend"</span>);
<a name="l01000"></a>01000 ++i;
<a name="l01001"></a>01001
<a name="l01002"></a>01002 verify_list (&list1);
<a name="l01003"></a>01003 verify_list (&list2);
<a name="l01004"></a>01004
<a name="l01005"></a>01005 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">_dbus_list_get_length</a> (&list1) == i);
<a name="l01006"></a>01006 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">_dbus_list_get_length</a> (&list2) == i);
<a name="l01007"></a>01007 }
<a name="l01008"></a>01008
<a name="l01009"></a>01009 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01010"></a>01010 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list2));
<a name="l01011"></a>01011
<a name="l01012"></a>01012 <span class="comment">/* Test list clear */</span>
<a name="l01013"></a>01013 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01014"></a>01014 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list2);
<a name="l01015"></a>01015
<a name="l01016"></a>01016 verify_list (&list1);
<a name="l01017"></a>01017 verify_list (&list2);
<a name="l01018"></a>01018
<a name="l01019"></a>01019 <span class="comment">/* Test get_first, get_last, pop_first, pop_last */</span>
<a name="l01020"></a>01020
<a name="l01021"></a>01021 i = 0;
<a name="l01022"></a>01022 <span class="keywordflow">while</span> (i < 10)
<a name="l01023"></a>01023 {
<a name="l01024"></a>01024 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01025"></a>01025 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01026"></a>01026 ++i;
<a name="l01027"></a>01027 }
<a name="l01028"></a>01028
<a name="l01029"></a>01029 --i;
<a name="l01030"></a>01030 <span class="keywordflow">while</span> (i >= 0)
<a name="l01031"></a>01031 {
<a name="l01032"></a>01032 <span class="keywordtype">void</span> *got_data1;
<a name="l01033"></a>01033 <span class="keywordtype">void</span> *got_data2;
<a name="l01034"></a>01034
<a name="l01035"></a>01035 <span class="keywordtype">void</span> *data1;
<a name="l01036"></a>01036 <span class="keywordtype">void</span> *data2;
<a name="l01037"></a>01037
<a name="l01038"></a>01038 got_data1 = <a class="code" href="group__DBusList.html#g18afc36fff1636a71295bcc7a75dc4f6">_dbus_list_get_last</a> (&list1);
<a name="l01039"></a>01039 got_data2 = <a class="code" href="group__DBusList.html#g254e18f698f5fc518bde031e723e67c6">_dbus_list_get_first</a> (&list2);
<a name="l01040"></a>01040
<a name="l01041"></a>01041 data1 = <a class="code" href="group__DBusList.html#gad2ba56c77f2bba8e1e8dcb4b24542a6">_dbus_list_pop_last</a> (&list1);
<a name="l01042"></a>01042 data2 = <a class="code" href="group__DBusList.html#gcb96c9d3e9a869e63b8db4f8913a5a60">_dbus_list_pop_first</a> (&list2);
<a name="l01043"></a>01043
<a name="l01044"></a>01044 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (got_data1 == data1);
<a name="l01045"></a>01045 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (got_data2 == data2);
<a name="l01046"></a>01046
<a name="l01047"></a>01047 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (data1) == i);
<a name="l01048"></a>01048 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (data2) == i);
<a name="l01049"></a>01049
<a name="l01050"></a>01050 verify_list (&list1);
<a name="l01051"></a>01051 verify_list (&list2);
<a name="l01052"></a>01052
<a name="l01053"></a>01053 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01054"></a>01054 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list2));
<a name="l01055"></a>01055
<a name="l01056"></a>01056 --i;
<a name="l01057"></a>01057 }
<a name="l01058"></a>01058
<a name="l01059"></a>01059 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (list1 == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>);
<a name="l01060"></a>01060 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (list2 == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>);
<a name="l01061"></a>01061
<a name="l01062"></a>01062 <span class="comment">/* Test get_first_link, get_last_link, pop_first_link, pop_last_link */</span>
<a name="l01063"></a>01063
<a name="l01064"></a>01064 i = 0;
<a name="l01065"></a>01065 <span class="keywordflow">while</span> (i < 10)
<a name="l01066"></a>01066 {
<a name="l01067"></a>01067 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01068"></a>01068 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01069"></a>01069 ++i;
<a name="l01070"></a>01070 }
<a name="l01071"></a>01071
<a name="l01072"></a>01072 --i;
<a name="l01073"></a>01073 <span class="keywordflow">while</span> (i >= 0)
<a name="l01074"></a>01074 {
<a name="l01075"></a>01075 <a class="code" href="structDBusList.html">DBusList</a> *got_link1;
<a name="l01076"></a>01076 <a class="code" href="structDBusList.html">DBusList</a> *got_link2;
<a name="l01077"></a>01077
<a name="l01078"></a>01078 <a class="code" href="structDBusList.html">DBusList</a> *link1;
<a name="l01079"></a>01079 <a class="code" href="structDBusList.html">DBusList</a> *link2;
<a name="l01080"></a>01080
<a name="l01081"></a>01081 <span class="keywordtype">void</span> *data1;
<a name="l01082"></a>01082 <span class="keywordtype">void</span> *data2;
<a name="l01083"></a>01083
<a name="l01084"></a>01084 got_link1 = <a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">_dbus_list_get_last_link</a> (&list1);
<a name="l01085"></a>01085 got_link2 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (&list2);
<a name="l01086"></a>01086
<a name="l01087"></a>01087 link1 = _dbus_list_pop_last_link (&list1);
<a name="l01088"></a>01088 link2 = <a class="code" href="group__DBusList.html#gab9a957eca9bf5466bbf377a23b4b25c">_dbus_list_pop_first_link</a> (&list2);
<a name="l01089"></a>01089
<a name="l01090"></a>01090 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (got_link1 == link1);
<a name="l01091"></a>01091 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (got_link2 == link2);
<a name="l01092"></a>01092
<a name="l01093"></a>01093 data1 = link1-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>;
<a name="l01094"></a>01094 data2 = link2-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>;
<a name="l01095"></a>01095
<a name="l01096"></a>01096 <a class="code" href="group__DBusList.html#g6e824f717125ce40c549d5402e32610f">_dbus_list_free_link</a> (link1);
<a name="l01097"></a>01097 <a class="code" href="group__DBusList.html#g6e824f717125ce40c549d5402e32610f">_dbus_list_free_link</a> (link2);
<a name="l01098"></a>01098
<a name="l01099"></a>01099 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (data1) == i);
<a name="l01100"></a>01100 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (data2) == i);
<a name="l01101"></a>01101
<a name="l01102"></a>01102 verify_list (&list1);
<a name="l01103"></a>01103 verify_list (&list2);
<a name="l01104"></a>01104
<a name="l01105"></a>01105 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01106"></a>01106 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list2));
<a name="l01107"></a>01107
<a name="l01108"></a>01108 --i;
<a name="l01109"></a>01109 }
<a name="l01110"></a>01110
<a name="l01111"></a>01111 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (list1 == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>);
<a name="l01112"></a>01112 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (list2 == <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>);
<a name="l01113"></a>01113
<a name="l01114"></a>01114 <span class="comment">/* Test iteration */</span>
<a name="l01115"></a>01115
<a name="l01116"></a>01116 i = 0;
<a name="l01117"></a>01117 <span class="keywordflow">while</span> (i < 10)
<a name="l01118"></a>01118 {
<a name="l01119"></a>01119 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01120"></a>01120 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01121"></a>01121 ++i;
<a name="l01122"></a>01122
<a name="l01123"></a>01123 verify_list (&list1);
<a name="l01124"></a>01124 verify_list (&list2);
<a name="l01125"></a>01125
<a name="l01126"></a>01126 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">_dbus_list_get_length</a> (&list1) == i);
<a name="l01127"></a>01127 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusList.html#ga2144a5489bb35b16b2b671488ad597c">_dbus_list_get_length</a> (&list2) == i);
<a name="l01128"></a>01128 }
<a name="l01129"></a>01129
<a name="l01130"></a>01130 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01131"></a>01131 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list2));
<a name="l01132"></a>01132
<a name="l01133"></a>01133 --i;
<a name="l01134"></a>01134 link2 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (&list2);
<a name="l01135"></a>01135 <span class="keywordflow">while</span> (link2 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01136"></a>01136 {
<a name="l01137"></a>01137 verify_list (&link2); <span class="comment">/* pretend this link is the head */</span>
<a name="l01138"></a>01138
<a name="l01139"></a>01139 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link2-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>) == i);
<a name="l01140"></a>01140
<a name="l01141"></a>01141 link2 = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (&list2, link2);
<a name="l01142"></a>01142 --i;
<a name="l01143"></a>01143 }
<a name="l01144"></a>01144
<a name="l01145"></a>01145 i = 0;
<a name="l01146"></a>01146 link1 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (&list1);
<a name="l01147"></a>01147 <span class="keywordflow">while</span> (link1 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01148"></a>01148 {
<a name="l01149"></a>01149 verify_list (&link1); <span class="comment">/* pretend this link is the head */</span>
<a name="l01150"></a>01150
<a name="l01151"></a>01151 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link1-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>) == i);
<a name="l01152"></a>01152
<a name="l01153"></a>01153 link1 = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (&list1, link1);
<a name="l01154"></a>01154 ++i;
<a name="l01155"></a>01155 }
<a name="l01156"></a>01156
<a name="l01157"></a>01157 --i;
<a name="l01158"></a>01158 link1 = <a class="code" href="group__DBusList.html#g42736fb02458bfffed948a509962c059">_dbus_list_get_last_link</a> (&list1);
<a name="l01159"></a>01159 <span class="keywordflow">while</span> (link1 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01160"></a>01160 {
<a name="l01161"></a>01161 verify_list (&link1); <span class="comment">/* pretend this link is the head */</span>
<a name="l01162"></a>01162
<a name="l01163"></a>01163 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link1-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>) == i);
<a name="l01164"></a>01164
<a name="l01165"></a>01165 link1 = <a class="code" href="group__DBusList.html#g6637493bf5fc09bddb44ac295c475cae">_dbus_list_get_prev_link</a> (&list1, link1);
<a name="l01166"></a>01166 --i;
<a name="l01167"></a>01167 }
<a name="l01168"></a>01168
<a name="l01169"></a>01169 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01170"></a>01170 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list2);
<a name="l01171"></a>01171
<a name="l01172"></a>01172 <span class="comment">/* Test remove */</span>
<a name="l01173"></a>01173
<a name="l01174"></a>01174 i = 0;
<a name="l01175"></a>01175 <span class="keywordflow">while</span> (i < 10)
<a name="l01176"></a>01176 {
<a name="l01177"></a>01177 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01178"></a>01178 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01179"></a>01179 ++i;
<a name="l01180"></a>01180 }
<a name="l01181"></a>01181
<a name="l01182"></a>01182 --i;
<a name="l01183"></a>01183 <span class="keywordflow">while</span> (i >= 0)
<a name="l01184"></a>01184 {
<a name="l01185"></a>01185 <span class="keywordflow">if</span> ((i % 2) == 0)
<a name="l01186"></a>01186 {
<a name="l01187"></a>01187 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#g202e6ac8ad3e4a9d4413e0248ffcf3e3">_dbus_list_remove</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i)))
<a name="l01188"></a>01188 <a class="code" href="group__DBusInternalsUtils.html#g0c4961ec784874f1b1f3aeccea8d3da1">_dbus_assert_not_reached</a> (<span class="stringliteral">"element should have been in list"</span>);
<a name="l01189"></a>01189 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#g202e6ac8ad3e4a9d4413e0248ffcf3e3">_dbus_list_remove</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i)))
<a name="l01190"></a>01190 <a class="code" href="group__DBusInternalsUtils.html#g0c4961ec784874f1b1f3aeccea8d3da1">_dbus_assert_not_reached</a> (<span class="stringliteral">"element should have been in list"</span>);
<a name="l01191"></a>01191
<a name="l01192"></a>01192 verify_list (&list1);
<a name="l01193"></a>01193 verify_list (&list2);
<a name="l01194"></a>01194 }
<a name="l01195"></a>01195 --i;
<a name="l01196"></a>01196 }
<a name="l01197"></a>01197
<a name="l01198"></a>01198 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_odd_values (&list1));
<a name="l01199"></a>01199 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_odd_values (&list2));
<a name="l01200"></a>01200
<a name="l01201"></a>01201 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01202"></a>01202 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list2);
<a name="l01203"></a>01203
<a name="l01204"></a>01204 <span class="comment">/* test removing the other half of the elements */</span>
<a name="l01205"></a>01205
<a name="l01206"></a>01206 i = 0;
<a name="l01207"></a>01207 <span class="keywordflow">while</span> (i < 10)
<a name="l01208"></a>01208 {
<a name="l01209"></a>01209 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01210"></a>01210 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01211"></a>01211 ++i;
<a name="l01212"></a>01212 }
<a name="l01213"></a>01213
<a name="l01214"></a>01214 --i;
<a name="l01215"></a>01215 <span class="keywordflow">while</span> (i >= 0)
<a name="l01216"></a>01216 {
<a name="l01217"></a>01217 <span class="keywordflow">if</span> ((i % 2) != 0)
<a name="l01218"></a>01218 {
<a name="l01219"></a>01219 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#g202e6ac8ad3e4a9d4413e0248ffcf3e3">_dbus_list_remove</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i)))
<a name="l01220"></a>01220 <a class="code" href="group__DBusInternalsUtils.html#g0c4961ec784874f1b1f3aeccea8d3da1">_dbus_assert_not_reached</a> (<span class="stringliteral">"element should have been in list"</span>);
<a name="l01221"></a>01221 <span class="keywordflow">if</span> (!<a class="code" href="group__DBusList.html#g202e6ac8ad3e4a9d4413e0248ffcf3e3">_dbus_list_remove</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i)))
<a name="l01222"></a>01222 <a class="code" href="group__DBusInternalsUtils.html#g0c4961ec784874f1b1f3aeccea8d3da1">_dbus_assert_not_reached</a> (<span class="stringliteral">"element should have been in list"</span>);
<a name="l01223"></a>01223
<a name="l01224"></a>01224 verify_list (&list1);
<a name="l01225"></a>01225 verify_list (&list2);
<a name="l01226"></a>01226 }
<a name="l01227"></a>01227 --i;
<a name="l01228"></a>01228 }
<a name="l01229"></a>01229
<a name="l01230"></a>01230 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_even_values (&list1));
<a name="l01231"></a>01231 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_even_values (&list2));
<a name="l01232"></a>01232
<a name="l01233"></a>01233 <span class="comment">/* clear list using remove_link */</span>
<a name="l01234"></a>01234 <span class="keywordflow">while</span> (list1 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01235"></a>01235 {
<a name="l01236"></a>01236 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (&list1, list1);
<a name="l01237"></a>01237 verify_list (&list1);
<a name="l01238"></a>01238 }
<a name="l01239"></a>01239 <span class="keywordflow">while</span> (list2 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01240"></a>01240 {
<a name="l01241"></a>01241 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (&list2, list2);
<a name="l01242"></a>01242 verify_list (&list2);
<a name="l01243"></a>01243 }
<a name="l01244"></a>01244
<a name="l01245"></a>01245 <span class="comment">/* Test remove link more generally */</span>
<a name="l01246"></a>01246 i = 0;
<a name="l01247"></a>01247 <span class="keywordflow">while</span> (i < 10)
<a name="l01248"></a>01248 {
<a name="l01249"></a>01249 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01250"></a>01250 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01251"></a>01251 ++i;
<a name="l01252"></a>01252 }
<a name="l01253"></a>01253
<a name="l01254"></a>01254 --i;
<a name="l01255"></a>01255 link2 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (&list2);
<a name="l01256"></a>01256 <span class="keywordflow">while</span> (link2 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01257"></a>01257 {
<a name="l01258"></a>01258 <a class="code" href="structDBusList.html">DBusList</a> *next = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (&list2, link2);
<a name="l01259"></a>01259
<a name="l01260"></a>01260 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link2-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>) == i);
<a name="l01261"></a>01261
<a name="l01262"></a>01262 <span class="keywordflow">if</span> ((i % 2) == 0)
<a name="l01263"></a>01263 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (&list2, link2);
<a name="l01264"></a>01264
<a name="l01265"></a>01265 verify_list (&list2);
<a name="l01266"></a>01266
<a name="l01267"></a>01267 link2 = next;
<a name="l01268"></a>01268 --i;
<a name="l01269"></a>01269 }
<a name="l01270"></a>01270
<a name="l01271"></a>01271 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_odd_values (&list2));
<a name="l01272"></a>01272 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list2);
<a name="l01273"></a>01273
<a name="l01274"></a>01274 i = 0;
<a name="l01275"></a>01275 link1 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (&list1);
<a name="l01276"></a>01276 <span class="keywordflow">while</span> (link1 != <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>)
<a name="l01277"></a>01277 {
<a name="l01278"></a>01278 <a class="code" href="structDBusList.html">DBusList</a> *next = <a class="code" href="group__DBusList.html#gede4ace46d5ee497d75074bfec4490a2">_dbus_list_get_next_link</a> (&list1, link1);
<a name="l01279"></a>01279
<a name="l01280"></a>01280 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (<a class="code" href="group__DBusInternalsUtils.html#gbbd3526a2ecd65da80b9f74ac286273d">_DBUS_POINTER_TO_INT</a> (link1-><a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>) == i);
<a name="l01281"></a>01281
<a name="l01282"></a>01282 <span class="keywordflow">if</span> ((i % 2) != 0)
<a name="l01283"></a>01283 <a class="code" href="group__DBusList.html#g40abea762d9cb44e5ec6b31b1769dc2e">_dbus_list_remove_link</a> (&list1, link1);
<a name="l01284"></a>01284
<a name="l01285"></a>01285 verify_list (&list1);
<a name="l01286"></a>01286
<a name="l01287"></a>01287 link1 = next;
<a name="l01288"></a>01288 ++i;
<a name="l01289"></a>01289 }
<a name="l01290"></a>01290
<a name="l01291"></a>01291 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_even_values (&list1));
<a name="l01292"></a>01292 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01293"></a>01293
<a name="l01294"></a>01294 <span class="comment">/* Test copying a list */</span>
<a name="l01295"></a>01295 i = 0;
<a name="l01296"></a>01296 <span class="keywordflow">while</span> (i < 10)
<a name="l01297"></a>01297 {
<a name="l01298"></a>01298 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01299"></a>01299 <a class="code" href="group__DBusList.html#gb4aa60e0466ac7075f3d1751909d6a52">_dbus_list_prepend</a> (&list2, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (i));
<a name="l01300"></a>01300 ++i;
<a name="l01301"></a>01301 }
<a name="l01302"></a>01302
<a name="l01303"></a>01303 <span class="comment">/* bad pointers, because they are allowed in the copy dest */</span>
<a name="l01304"></a>01304 copy1 = <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (0x342234);
<a name="l01305"></a>01305 copy2 = <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (23);
<a name="l01306"></a>01306
<a name="l01307"></a>01307 <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (&list1, &copy1);
<a name="l01308"></a>01308 verify_list (&list1);
<a name="l01309"></a>01309 verify_list (&copy1);
<a name="l01310"></a>01310 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&list1, &copy1));
<a name="l01311"></a>01311
<a name="l01312"></a>01312 <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (&list2, &copy2);
<a name="l01313"></a>01313 verify_list (&list2);
<a name="l01314"></a>01314 verify_list (&copy2);
<a name="l01315"></a>01315 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&list2, &copy2));
<a name="l01316"></a>01316
<a name="l01317"></a>01317 <span class="comment">/* Now test copying empty lists */</span>
<a name="l01318"></a>01318 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01319"></a>01319 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list2);
<a name="l01320"></a>01320 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&copy1);
<a name="l01321"></a>01321 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&copy2);
<a name="l01322"></a>01322
<a name="l01323"></a>01323 <span class="comment">/* bad pointers, because they are allowed in the copy dest */</span>
<a name="l01324"></a>01324 copy1 = <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (0x342234);
<a name="l01325"></a>01325 copy2 = <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (23);
<a name="l01326"></a>01326
<a name="l01327"></a>01327 <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (&list1, &copy1);
<a name="l01328"></a>01328 verify_list (&list1);
<a name="l01329"></a>01329 verify_list (&copy1);
<a name="l01330"></a>01330 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&list1, &copy1));
<a name="l01331"></a>01331
<a name="l01332"></a>01332 <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (&list2, &copy2);
<a name="l01333"></a>01333 verify_list (&list2);
<a name="l01334"></a>01334 verify_list (&copy2);
<a name="l01335"></a>01335 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&list2, &copy2));
<a name="l01336"></a>01336
<a name="l01337"></a>01337 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01338"></a>01338 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list2);
<a name="l01339"></a>01339
<a name="l01340"></a>01340 <span class="comment">/* insert_before on empty list */</span>
<a name="l01341"></a>01341 _dbus_list_insert_before (&list1, <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>,
<a name="l01342"></a>01342 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (0));
<a name="l01343"></a>01343 verify_list (&list1);
<a name="l01344"></a>01344
<a name="l01345"></a>01345 <span class="comment">/* inserting before first element */</span>
<a name="l01346"></a>01346 _dbus_list_insert_before (&list1, list1,
<a name="l01347"></a>01347 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (2));
<a name="l01348"></a>01348 verify_list (&list1);
<a name="l01349"></a>01349 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list1));
<a name="l01350"></a>01350
<a name="l01351"></a>01351 <span class="comment">/* inserting in the middle */</span>
<a name="l01352"></a>01352 _dbus_list_insert_before (&list1, list1->next,
<a name="l01353"></a>01353 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (1));
<a name="l01354"></a>01354 verify_list (&list1);
<a name="l01355"></a>01355 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list1));
<a name="l01356"></a>01356
<a name="l01357"></a>01357 <span class="comment">/* using insert_before to append */</span>
<a name="l01358"></a>01358 _dbus_list_insert_before (&list1, <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>,
<a name="l01359"></a>01359 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (-1));
<a name="l01360"></a>01360 verify_list (&list1);
<a name="l01361"></a>01361 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&list1));
<a name="l01362"></a>01362
<a name="l01363"></a>01363 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01364"></a>01364
<a name="l01365"></a>01365 <span class="comment">/* insert_after on empty list */</span>
<a name="l01366"></a>01366 <a class="code" href="group__DBusList.html#g2dacb82db59f0012951d8245017473c9">_dbus_list_insert_after</a> (&list1, <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>,
<a name="l01367"></a>01367 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (0));
<a name="l01368"></a>01368 verify_list (&list1);
<a name="l01369"></a>01369
<a name="l01370"></a>01370 <span class="comment">/* inserting after first element */</span>
<a name="l01371"></a>01371 <a class="code" href="group__DBusList.html#g2dacb82db59f0012951d8245017473c9">_dbus_list_insert_after</a> (&list1, list1,
<a name="l01372"></a>01372 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (1));
<a name="l01373"></a>01373 verify_list (&list1);
<a name="l01374"></a>01374 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01375"></a>01375
<a name="l01376"></a>01376 <span class="comment">/* inserting at the end */</span>
<a name="l01377"></a>01377 <a class="code" href="group__DBusList.html#g2dacb82db59f0012951d8245017473c9">_dbus_list_insert_after</a> (&list1, list1->next,
<a name="l01378"></a>01378 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (2));
<a name="l01379"></a>01379 verify_list (&list1);
<a name="l01380"></a>01380 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01381"></a>01381
<a name="l01382"></a>01382 <span class="comment">/* using insert_after to prepend */</span>
<a name="l01383"></a>01383 <a class="code" href="group__DBusList.html#g2dacb82db59f0012951d8245017473c9">_dbus_list_insert_after</a> (&list1, <a class="code" href="group__DBusMacros.html#g070d2ce7b6bb7e5c05602aa8c308d0c4">NULL</a>,
<a name="l01384"></a>01384 <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (-1));
<a name="l01385"></a>01385 verify_list (&list1);
<a name="l01386"></a>01386 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01387"></a>01387
<a name="l01388"></a>01388 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01389"></a>01389
<a name="l01390"></a>01390 <span class="comment">/* using remove_last */</span>
<a name="l01391"></a>01391 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (2));
<a name="l01392"></a>01392 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (1));
<a name="l01393"></a>01393 <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (3));
<a name="l01394"></a>01394
<a name="l01395"></a>01395 <a class="code" href="group__DBusList.html#gd93f1fc853914144e94fc7a7dc0945aa">_dbus_list_remove_last</a> (&list1, <a class="code" href="group__DBusInternalsUtils.html#g05e902d8504a8a0e0b183fd2e20e329f">_DBUS_INT_TO_POINTER</a> (2));
<a name="l01396"></a>01396
<a name="l01397"></a>01397 verify_list (&list1);
<a name="l01398"></a>01398 <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&list1));
<a name="l01399"></a>01399
<a name="l01400"></a>01400 <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&list1);
<a name="l01401"></a>01401
<a name="l01402"></a>01402 <span class="keywordflow">return</span> <a class="code" href="group__DBusMacros.html#ga8cecfc5c5c054d2875c03e77b7be15d">TRUE</a>;
<a name="l01403"></a>01403 }
<a name="l01404"></a>01404
<a name="l01405"></a>01405 <span class="preprocessor">#endif</span>
</pre></div><hr size="1"><address style="align: right;"><small>Generated on Mon Dec 14 22:26:11 2009 for D-Bus by
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.4.7 </small></address>
</body>
</html>