MOON
Server: Apache/2.2.31 (Unix) mod_ssl/2.2.31 OpenSSL/0.9.8e-fips-rhel5 mod_bwlimited/1.4
System: Linux csr818.wilogic.com 2.6.18-419.el5xen #1 SMP Fri Feb 24 22:50:37 UTC 2017 x86_64
User: digitals (531)
PHP: 5.4.45
Disabled: NONE
Upload Files
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&nbsp;Page</span></a></li>
    <li><a href="modules.html"><span>Modules</span></a></li>
    <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
    <li id="current"><a href="files.html"><span>Files</span></a></li>
    <li><a href="pages.html"><span>Related&nbsp;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-&gt;<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-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00113"></a>00113       link-&gt;<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-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = before_this_link;
<a name="l00119"></a>00119       link-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = before_this_link-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>;
<a name="l00120"></a>00120       before_this_link-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00121"></a>00121       link-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>-&gt;<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-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link;
<a name="l00136"></a>00136       link-&gt;<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-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = after_this_link;
<a name="l00142"></a>00142       link-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = after_this_link-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00143"></a>00143       after_this_link-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link;
<a name="l00144"></a>00144       link-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>-&gt;<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)-&gt;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)-&gt;<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-&gt;<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-&gt;<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-&gt;<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-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a> = link-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>;
<a name="l00517"></a>00517       link-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> = link-&gt;<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-&gt;<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-&gt;<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-&gt;<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)-&gt;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)-&gt;prev-&gt;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)-&gt;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-&gt;<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-&gt;<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-&gt;<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-&gt;<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> &amp;&amp;
<a name="l00816"></a>00816           (*list)-&gt;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 &lt;stdio.h&gt;</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-&gt;<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-&gt;<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-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a>-&gt;<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-&gt;<a class="code" href="structDBusList.html#83180142180c856b2a02778e155cb044">next</a>-&gt;<a class="code" href="structDBusList.html#aeb8ce69b141da1f04621ae81eed3388">prev</a> == link);
<a name="l00849"></a>00849       link = link-&gt;<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-&gt;<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 &lt;= 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-&gt;<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 &gt;= 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-&gt;<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-&gt;<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 &amp;&amp; link2)
<a name="l00957"></a>00957     {
<a name="l00958"></a>00958       <span class="keywordflow">if</span> (link1-&gt;<a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a> != link2-&gt;<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 &lt; 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> (&amp;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> (&amp;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 (&amp;list1);
<a name="l01003"></a>01003       verify_list (&amp;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> (&amp;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> (&amp;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 (&amp;list1));
<a name="l01010"></a>01010   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;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> (&amp;list1);
<a name="l01014"></a>01014   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;list2);
<a name="l01015"></a>01015 
<a name="l01016"></a>01016   verify_list (&amp;list1);
<a name="l01017"></a>01017   verify_list (&amp;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 &lt; 10)
<a name="l01023"></a>01023     {
<a name="l01024"></a>01024       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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 &gt;= 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> (&amp;list1);
<a name="l01039"></a>01039       got_data2 = <a class="code" href="group__DBusList.html#g254e18f698f5fc518bde031e723e67c6">_dbus_list_get_first</a> (&amp;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> (&amp;list1);
<a name="l01042"></a>01042       data2 = <a class="code" href="group__DBusList.html#gcb96c9d3e9a869e63b8db4f8913a5a60">_dbus_list_pop_first</a> (&amp;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 (&amp;list1);
<a name="l01051"></a>01051       verify_list (&amp;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 (&amp;list1));
<a name="l01054"></a>01054       <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;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 &lt; 10)
<a name="l01066"></a>01066     {
<a name="l01067"></a>01067       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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 &gt;= 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> (&amp;list1);
<a name="l01085"></a>01085       got_link2 = <a class="code" href="group__DBusList.html#g1e26ce4fb4acb50593bd5ed2f4eeb3ae">_dbus_list_get_first_link</a> (&amp;list2);
<a name="l01086"></a>01086       
<a name="l01087"></a>01087       link1 = _dbus_list_pop_last_link (&amp;list1);
<a name="l01088"></a>01088       link2 = <a class="code" href="group__DBusList.html#gab9a957eca9bf5466bbf377a23b4b25c">_dbus_list_pop_first_link</a> (&amp;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-&gt;<a class="code" href="structDBusList.html#29ab457bcf9092252bb0c4282c727055">data</a>;
<a name="l01094"></a>01094       data2 = link2-&gt;<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 (&amp;list1);
<a name="l01103"></a>01103       verify_list (&amp;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 (&amp;list1));
<a name="l01106"></a>01106       <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;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 &lt; 10)
<a name="l01118"></a>01118     {
<a name="l01119"></a>01119       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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 (&amp;list1);
<a name="l01124"></a>01124       verify_list (&amp;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> (&amp;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> (&amp;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 (&amp;list1));
<a name="l01131"></a>01131   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;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> (&amp;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 (&amp;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-&gt;<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> (&amp;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> (&amp;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 (&amp;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-&gt;<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> (&amp;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> (&amp;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 (&amp;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-&gt;<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> (&amp;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> (&amp;list1);
<a name="l01170"></a>01170   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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 &lt; 10)
<a name="l01176"></a>01176     {
<a name="l01177"></a>01177       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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 &gt;= 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> (&amp;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> (&amp;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 (&amp;list1);
<a name="l01193"></a>01193           verify_list (&amp;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 (&amp;list1));
<a name="l01199"></a>01199   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_odd_values (&amp;list2));
<a name="l01200"></a>01200 
<a name="l01201"></a>01201   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;list1);
<a name="l01202"></a>01202   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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 &lt; 10)
<a name="l01208"></a>01208     {
<a name="l01209"></a>01209       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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 &gt;= 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> (&amp;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> (&amp;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 (&amp;list1);
<a name="l01225"></a>01225           verify_list (&amp;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 (&amp;list1));
<a name="l01231"></a>01231   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (all_even_values (&amp;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> (&amp;list1, list1);
<a name="l01237"></a>01237       verify_list (&amp;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> (&amp;list2, list2);
<a name="l01242"></a>01242       verify_list (&amp;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 &lt; 10)
<a name="l01248"></a>01248     {
<a name="l01249"></a>01249       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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> (&amp;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> (&amp;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-&gt;<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> (&amp;list2, link2);
<a name="l01264"></a>01264 
<a name="l01265"></a>01265       verify_list (&amp;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 (&amp;list2));  
<a name="l01272"></a>01272   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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> (&amp;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> (&amp;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-&gt;<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> (&amp;list1, link1);
<a name="l01284"></a>01284 
<a name="l01285"></a>01285       verify_list (&amp;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 (&amp;list1));
<a name="l01292"></a>01292   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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 &lt; 10)
<a name="l01297"></a>01297     {
<a name="l01298"></a>01298       <a class="code" href="group__DBusList.html#gd99045e79db46159babe69718f343053">_dbus_list_append</a> (&amp;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> (&amp;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> (&amp;list1, &amp;copy1);
<a name="l01308"></a>01308   verify_list (&amp;list1);
<a name="l01309"></a>01309   verify_list (&amp;copy1);
<a name="l01310"></a>01310   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&amp;list1, &amp;copy1));
<a name="l01311"></a>01311   
<a name="l01312"></a>01312   <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (&amp;list2, &amp;copy2);
<a name="l01313"></a>01313   verify_list (&amp;list2);
<a name="l01314"></a>01314   verify_list (&amp;copy2);
<a name="l01315"></a>01315   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&amp;list2, &amp;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> (&amp;list1);
<a name="l01319"></a>01319   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;list2);
<a name="l01320"></a>01320   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;copy1);
<a name="l01321"></a>01321   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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> (&amp;list1, &amp;copy1);
<a name="l01328"></a>01328   verify_list (&amp;list1);
<a name="l01329"></a>01329   verify_list (&amp;copy1);
<a name="l01330"></a>01330   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&amp;list1, &amp;copy1));
<a name="l01331"></a>01331   
<a name="l01332"></a>01332   <a class="code" href="group__DBusList.html#g1a85785891866750c9438bc10ad0350a">_dbus_list_copy</a> (&amp;list2, &amp;copy2);
<a name="l01333"></a>01333   verify_list (&amp;list2);
<a name="l01334"></a>01334   verify_list (&amp;copy2);
<a name="l01335"></a>01335   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (lists_equal (&amp;list2, &amp;copy2));
<a name="l01336"></a>01336 
<a name="l01337"></a>01337   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;list1);
<a name="l01338"></a>01338   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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 (&amp;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 (&amp;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 (&amp;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 (&amp;list1);
<a name="l01349"></a>01349   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;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 (&amp;list1, list1-&gt;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 (&amp;list1);
<a name="l01355"></a>01355   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;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 (&amp;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 (&amp;list1);
<a name="l01361"></a>01361   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_descending_sequence (&amp;list1));
<a name="l01362"></a>01362   
<a name="l01363"></a>01363   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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> (&amp;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 (&amp;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> (&amp;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 (&amp;list1);
<a name="l01374"></a>01374   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&amp;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> (&amp;list1, list1-&gt;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 (&amp;list1);
<a name="l01380"></a>01380   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&amp;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> (&amp;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 (&amp;list1);
<a name="l01386"></a>01386   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&amp;list1));
<a name="l01387"></a>01387   
<a name="l01388"></a>01388   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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> (&amp;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> (&amp;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> (&amp;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> (&amp;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 (&amp;list1);
<a name="l01398"></a>01398   <a class="code" href="group__DBusInternalsUtils.html#g129c6c03f011cdc171934d5d386cc797">_dbus_assert</a> (is_ascending_sequence (&amp;list1));
<a name="l01399"></a>01399   
<a name="l01400"></a>01400   <a class="code" href="group__DBusList.html#ga36d13444a050a923941c53650b72f9d">_dbus_list_clear</a> (&amp;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&nbsp;
<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>