25f14ca37f745e13913889bba1b553da08184174
[modest] / src / modest-pair.c
1 /* Copyright (c) 2006, Nokia Corporation
2  * All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  *   notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  *   notice, this list of conditions and the following disclaimer in the
12  *   documentation and/or other materials provided with the distribution.
13  * * Neither the name of the Nokia Corporation nor the names of its
14  *   contributors may be used to endorse or promote products derived from
15  *   this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
18  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
20  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
21  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  */
29
30 #include "modest-pair.h"
31
32 ModestPair*
33 modest_pair_new     (gpointer first, gpointer second, gboolean own)
34 {
35         ModestPair *pair;
36
37         pair = g_slice_new (ModestPair);
38
39         pair->first  = first;
40         pair->second = second;
41         pair->own    = own;
42         
43         return pair;
44 }
45
46
47 void
48 modest_pair_free (ModestPair *pair)
49 {
50         if (!pair)
51                 return;
52
53         if (pair->own) {
54                 g_free (pair->first);
55                 g_free (pair->second);
56         }
57         
58         g_slice_free (ModestPair, pair);
59 }
60
61
62
63 void
64 modest_pair_list_free (ModestPairList *pairs)
65 {
66         ModestPairList *cursor = pairs;
67         while (cursor) {
68                 modest_pair_free ((ModestPair*)cursor->data);
69                 cursor = cursor->next;
70         }
71         g_slist_free (pairs);
72 }