Frameworks/libpurple.framework/Versions/0.6.2/Headers/group.h
author Zachary West <zacw@adium.im>
Fri Aug 21 13:25:11 2009 -0700 (2009-08-21)
changeset 2592 e8d15275025e
parent 1739 Frameworks/libpurple.framework/Versions/0.6.0/Headers/group.h@8b0daad9656c
permissions -rw-r--r--
im.pidgin.adium.1-4 at 267c6165e02e34318a1823960bd04c0639952f73
Evan@653
     1
/**
Evan@653
     2
 * @file group.h Group functions
Evan@653
     3
 *
Evan@653
     4
 * purple
Evan@653
     5
 *
Evan@653
     6
 * Purple is the legal property of its developers, whose names are too numerous
Evan@653
     7
 * to list here.  Please refer to the COPYRIGHT file distributed with this
Evan@653
     8
 * source distribution.
Evan@653
     9
 *
Evan@653
    10
 * This program is free software; you can redistribute it and/or modify
Evan@653
    11
 * it under the terms of the GNU General Public License as published by
Evan@653
    12
 * the Free Software Foundation; either version 2 of the License, or
Evan@653
    13
 * (at your option) any later version.
Evan@653
    14
 *
Evan@653
    15
 * This program is distributed in the hope that it will be useful,
Evan@653
    16
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Evan@653
    17
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Evan@653
    18
 * GNU General Public License for more details.
Evan@653
    19
 *
Evan@653
    20
 * You should have received a copy of the GNU General Public License
Evan@653
    21
 * along with this program; if not, write to the Free Software
Evan@653
    22
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
Evan@653
    23
 */
Evan@653
    24
#ifndef _MSN_GROUP_H_
Evan@653
    25
#define _MSN_GROUP_H_
Evan@653
    26
Evan@653
    27
typedef struct _MsnGroup  MsnGroup;
Evan@653
    28
Evan@653
    29
#include <stdio.h>
Evan@653
    30
Evan@653
    31
#include "session.h"
Evan@653
    32
#include "user.h"
Evan@653
    33
#include "userlist.h"
Evan@653
    34
Evan@653
    35
#define MSN_INDIVIDUALS_GROUP_ID	"1983"
Evan@653
    36
#define MSN_INDIVIDUALS_GROUP_NAME	_("Other Contacts")
Evan@653
    37
Evan@653
    38
#define MSN_NON_IM_GROUP_ID		"email"
Evan@653
    39
#define MSN_NON_IM_GROUP_NAME	_("Non-IM Contacts")
Evan@653
    40
Evan@653
    41
/**
Evan@653
    42
 * A group.
Evan@653
    43
 */
Evan@653
    44
struct _MsnGroup
Evan@653
    45
{
Evan@653
    46
	MsnSession *session;    /**< The MSN session.           */
Evan@653
    47
Evan@653
    48
	char *id;                 /**< The group ID.              */
Evan@653
    49
	char *name;             /**< The name of the group.     */
Evan@653
    50
};
Evan@653
    51
Evan@653
    52
/**************************************************************************
Evan@653
    53
 ** @name Group API                                                       *
Evan@653
    54
 **************************************************************************/
Evan@653
    55
/*@{*/
Evan@653
    56
Evan@653
    57
/**
Evan@653
    58
 * Creates a new group structure.
Evan@653
    59
 *
Evan@653
    60
 * @param session The MSN session.
Evan@653
    61
 * @param id      The group ID.
Evan@653
    62
 * @param name    The name of the group.
Evan@653
    63
 *
Evan@653
    64
 * @return A new group structure.
Evan@653
    65
 */
Evan@653
    66
MsnGroup *msn_group_new(MsnUserList *userlist, const char *id, const char *name);
Evan@653
    67
Evan@653
    68
/**
Evan@653
    69
 * Destroys a group structure.
Evan@653
    70
 *
Evan@653
    71
 * @param group The group to destroy.
Evan@653
    72
 */
Evan@653
    73
void msn_group_destroy(MsnGroup *group);
Evan@653
    74
Evan@653
    75
/**
Evan@653
    76
 * Sets the ID for a group.
Evan@653
    77
 *
Evan@653
    78
 * @param group The group.
Evan@653
    79
 * @param id    The ID.
Evan@653
    80
 */
Evan@653
    81
void msn_group_set_id(MsnGroup *group, const char *id);
Evan@653
    82
Evan@653
    83
/**
Evan@653
    84
 * Sets the name for a group.
Evan@653
    85
 *
Evan@653
    86
 * @param group The group.
Evan@653
    87
 * @param name  The name.
Evan@653
    88
 */
Evan@653
    89
void msn_group_set_name(MsnGroup *group, const char *name);
Evan@653
    90
Evan@653
    91
/**
Evan@653
    92
 * Returns the ID for a group.
Evan@653
    93
 *
Evan@653
    94
 * @param group The group.
Evan@653
    95
 *
Evan@653
    96
 * @return The ID.
Evan@653
    97
 */
Evan@653
    98
char* msn_group_get_id(const MsnGroup *group);
Evan@653
    99
Evan@653
   100
/**
Evan@653
   101
 * Returns the name for a group.
Evan@653
   102
 *
Evan@653
   103
 * @param group The group.
Evan@653
   104
 *
Evan@653
   105
 * @return The name.
Evan@653
   106
 */
Evan@653
   107
const char *msn_group_get_name(const MsnGroup *group);
Evan@653
   108
Evan@653
   109
#endif /* _MSN_GROUP_H_ */
Evan@653
   110