/*
 * The Evolution addressbook client object.
 *
 * Author:
 *   Nat Friedman (nat@helixcode.com)
 *
 * Copyright 1999, Helix Code, Inc.
 */

#include <ebook/e-book.h>

/**
 * e_book_new:
 * @uri: A URI string describing the location of the backend
 * which the new #EBook will use.
 *
 * Returns: A new #EBook object, bound to the backend specified
 * by @uri, or %NULL if an error occurs.
 */
EBook *
e_book_new (const char *uri)
{
	e_book_get_card (
}

/**
 * e_book_get_type:
 *
 * Returns: The #GtkType for #EBook.
 */
GtkType
e_book_get_type (void)
{
}

/**
 * e_book_get_card:
 * @book: An #EBook object.
 * @id: A unique ID which specified a card stored inside
 * @book's backend store.
 *
 * This function fetches the card specified by @id from @book's
 * backend, parses it into a new #ECard object, and returns it.
 *
 * Returns: A newly created #ECard, filled with the card data
 * specified by @id.  The #EBook may maintain an internal card cache,
 * and will therefore hold a reference to each #ECard itself.  The
 * reference count on the returned #ECard will be incremented when the
 * card is returned.  When the client wishes to destroy the returned
 * #ECard, he should just dereference it.
 */
ECard *
e_book_get_card (EBook *book, const char *id)
{
}

/**
 * e_book_get_cards:
 * @book: An #EBook object.
 *
 * Returns: A #GList of all the #ECards stored in @book's backend.
 * The #GList is newly-allocated for the client and must be freed by
 * him.  The #ECard objects in the #GList are each referenced, and
 * must be unreferenced when the client is done using them.
 */
GList *
e_book_get_cards (EBook *book)
{
}

/**
 * e_book_get_ids:
 * @book: An #EBook object.
 *
 * Returns: A #GList of all the unique card ID strings stored in
 * @book's backend.  The #GList is newly-allocated, as are all of the
 * #ECard objects stored in it.  The client must free the #GList and
 * unreference all fo the cards when he is done with them.
 */
GList *
e_book_get_ids (EBook *book)
{
}

/**
 * e_book_sync_card:
 * @book: An #EBook object.
 * @card: A dirty #ECard object.
 *
 * Writes all the changes in @card into @book's card store.
 */
void
e_book_sync_card (EBook *book)
{
}

/**
 * e_book_update_card:
 * @book: An #EBook object.
 * @card: An #ECard object which has become out-of-date
 * and no longer contains the most current card data
 * in @book's card store.
 *
 * Updates @card with any changes which may have occured in its
 * corresponding backend data.
 */
void
e_book_update_card (EBook *book, ECard *card)
{
}

/**
 * e_book_add_card:
 * @book: An #EBook object.
 * @card: A newly-created ECard object.
 *
 * Adds @card to @book's card store.  Creates a unique ID for @card
 * and sets @card's ID field.  This action will cause a #card_added
 * signal to be raised on @book.
 *
 * Returns: The newly-created unique ID for @card.  The copy
 * returned is the same copy which is stored in @card.  The #EBook
 * may reference @card and keep a handle to it.
 */
const char *
e_book_add_card (EBook *book, ECard *card)
{
}

/**
 * e_book_remove_card:
 * @book: An #EBook object.
 * @id: A unique ID for a card stored in @book.
 *
 * Removes the card specified by @id from @book's card store.  If the
 * client has kept around an old #ECard object for the card being
 * removed, he will have to remove it himself.  The #ECard will not
 * receive a #card_removed signals.  A #card_removed signal will be
 * raised on @book, the card will be removed from the #EBook card
 * cache, and the corresponding #ECard's reference count will be
 * decremented.
 */
void
e_book_remove_card (EBook *book, const char *id)
{
}

/**
 * e_book_complete:
 * @book: An #EBook object.
 * @str: A string.
 *
 * The purpose of this function is to provide an easy way for the
 * client application to to implement typing completion in its address
 * entry dialogs.  The #EBook will compute a list of cards which
 * potentially complete @str.  The basis for the completion (address,
 * nickname, etc) is implementation-dependent, and I may add some
 * configurability to this later.
 * 
 * Returns: A list of #ECard objects which are potentially what the
 * user was getting at when he typed @str.  The list is sorted in
 * descending order of likelihood.  The returned #GList must be freed
 * by the client.  The #ECard objects in the #GList may have come from
 * @book's cache, and the client may already hold other references to
 * them.  For this reason, the reference count on each #ECard object
 * is incremented when the object is returned.
 */
GList *
e_book_complete (EBook *book, const char *str)
{
}       

/**
 * e_book_get_name:
 * @book: An #EBook object.
 *
 * Returns: The name of the card store to which @book is bound.
 * The returned string must be freed by the client.
 */
char *
e_book_get_name (EBook *book)
{
}

/**
 * e_book_set_name:
 * @book: An #EBook object.
 * @name: A string containing a new name for @book.
 *
 * Sets @book's name to @name.
 */
char *
e_book_set_name (EBook *book, const char *namen)
{
}