aboutsummaryrefslogblamecommitdiffstats
path: root/camel/camel-address.c
blob: 515e86cc02119d914081ba5afa00577566e1c222 (plain) (tree)























                                                                       
                                                        
 
                                              
 

                                                   
                                                                                           







                                           
                                         
                                                      
                                                                 
 
 














                                                                                                










                                           
                                                                                      

                   




























                                                                                       














                                                          
                                                                                













                                                           
                                                                           

   










































































                                                                                    











                                                                
                                                                                           
                
                                                                                   
         
/*
 *  Copyright (C) 2000 Helix Code Inc.
 *
 *  Authors: Michael Zucchi <notzed@helixcode.com>
 *
 *  This program is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Library General Public License
 *  as published by the Free Software Foundation; either version 2 of
 *  the License, or (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Library General Public License for more details.
 *
 *  You should have received a copy of the GNU Library General Public
 *  License along with this program; if not, write to the Free Software
 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */

#include "camel-address.h"


static void camel_address_class_init (CamelAddressClass *klass);
static void camel_address_init       (CamelAddress *obj);
static void camel_address_finalize   (CamelObject *obj);

static CamelObjectClass *camel_address_parent;

static void
camel_address_class_init (CamelAddressClass *klass)
{
    camel_address_parent = camel_type_get_global_classfuncs (camel_object_get_type ());
}

static void
camel_address_init (CamelAddress *obj)
{
    obj->addresses = g_ptr_array_new();
}

static void
camel_address_finalize (CamelObject *obj)
{
    camel_address_remove((CamelAddress *)obj, -1);
    g_ptr_array_free(((CamelAddress *)obj)->addresses, TRUE);
}

CamelType
camel_address_get_type (void)
{
    static CamelType type = CAMEL_INVALID_TYPE;
    
    if (type == CAMEL_INVALID_TYPE) {
        type = camel_type_register (camel_object_get_type (), "CamelAddress",
                        sizeof (CamelAddress),
                        sizeof (CamelAddressClass),
                        (CamelObjectClassInitFunc) camel_address_class_init,
                        NULL,
                        (CamelObjectInitFunc) camel_address_init,
                        (CamelObjectFinalizeFunc) camel_address_finalize);
    }
    
    return type;
}

/**
 * camel_address_new:
 *
 * Create a new CamelAddress object.
 * 
 * Return value: A new CamelAddress widget.
 **/
CamelAddress *
camel_address_new (void)
{
    CamelAddress *new = CAMEL_ADDRESS(camel_object_new(camel_address_get_type()));
    return new;
}

/**
 * camel_address_new_clone:
 * @in: 
 * 
 * Clone an existing address type.
 * 
 * Return value: 
 **/
CamelAddress *
camel_address_new_clone(const CamelAddress *in)
{
    CamelAddress *new = CAMEL_ADDRESS(camel_object_new(CAMEL_OBJECT_GET_TYPE(in)));

    camel_address_cat(new, in);
    return new;
}

/**
 * camel_address_length:
 * @a: 
 * 
 * Return the number of addresses stored in the address @a.
 * 
 * Return value: 
 **/
int
camel_address_length(CamelAddress *a)
{
    return a->addresses->len;
}

/**
 * camel_address_decode:
 * @a: An address.
 * @raw: Raw address description.
 * 
 * Construct a new address from a raw address field.
 * 
 * Return value: Returns the number of addresses found,
 * or -1 if the addresses could not be parsed fully.
 **/
int
camel_address_decode    (CamelAddress *a, const char *raw)
{
    g_return_val_if_fail(IS_CAMEL_ADDRESS(a), -1);

    return CAMEL_ADDRESS_CLASS (CAMEL_OBJECT_GET_CLASS (a))->decode(a, raw);
}

/**
 * camel_address_encode:
 * @a: 
 * 
 * Encode an address in a format suitable for a raw header.
 * 
 * Return value: The encoded address.
 **/
char *
camel_address_encode    (CamelAddress *a)
{
    g_return_val_if_fail(IS_CAMEL_ADDRESS(a), NULL);

    return CAMEL_ADDRESS_CLASS (CAMEL_OBJECT_GET_CLASS (a))->encode(a);
}

/**
 * camel_address_unformat:
 * @a: 
 * @raw: 
 * 
 * Attempt to convert a previously formatted and/or edited
 * address back into internal form.
 * 
 * Return value: -1 if it could not be parsed, or the number
 * of valid addresses found.
 **/
int
camel_address_unformat(CamelAddress *a, const char *raw)
{
    g_return_val_if_fail(IS_CAMEL_ADDRESS(a), -1);

    return CAMEL_ADDRESS_CLASS (CAMEL_OBJECT_GET_CLASS (a))->unformat(a, raw);
}

/**
 * camel_address_format:
 * @a: 
 * 
 * Format an address in a format suitable for display.
 * 
 * Return value: The formatted address.
 **/
char *
camel_address_format    (CamelAddress *a)
{
    if (a == NULL)
        return NULL;

    g_return_val_if_fail(IS_CAMEL_ADDRESS(a), NULL);

    return CAMEL_ADDRESS_CLASS (CAMEL_OBJECT_GET_CLASS (a))->format(a);
}

/**
 * camel_address_cat:
 * @dest: 
 * @source: 
 * 
 * Concatenate one address onto another.  The addresses must
 * be of the same type.
 * 
 * Return value: 
 **/
int
camel_address_cat   (CamelAddress *dest, const CamelAddress *source)
{
    g_return_val_if_fail(IS_CAMEL_ADDRESS(dest), -1);
    g_return_val_if_fail(IS_CAMEL_ADDRESS(source), -1);

    return CAMEL_ADDRESS_CLASS(CAMEL_OBJECT_GET_CLASS(dest))->cat(dest, source);
}

/**
 * camel_address_copy:
 * @dest: 
 * @source: 
 * 
 * Copy an address contents.
 * 
 * Return value: 
 **/
int
camel_address_copy  (CamelAddress *dest, const CamelAddress *source)
{
    g_return_val_if_fail(IS_CAMEL_ADDRESS(dest), -1);
    g_return_val_if_fail(IS_CAMEL_ADDRESS(source), -1);

    camel_address_remove(dest, -1);
    return camel_address_cat(dest, source);
}

/**
 * camel_address_remove:
 * @a: 
 * @index: The address to remove, use -1 to remove all address.
 * 
 * Remove an address by index, or all addresses.
 **/
void
camel_address_remove    (CamelAddress *a, int index)
{
    g_return_if_fail(IS_CAMEL_ADDRESS(a));

    if (index == -1) {
        for (index=a->addresses->len; index>-1; index--)
            CAMEL_ADDRESS_CLASS (CAMEL_OBJECT_GET_CLASS (a))->remove(a, index);
    } else {
        CAMEL_ADDRESS_CLASS (CAMEL_OBJECT_GET_CLASS (a))->remove(a, index);
    }
}