pidgin 2.14.14dev
status.h File Reference

Status API. More...

#include "account.h"
#include "blist.h"
#include "conversation.h"
#include "value.h"
Include dependency graph for status.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  _PurpleMood
 

Macros

#define PURPLE_TUNE_ARTIST   "tune_artist"
 
#define PURPLE_TUNE_TITLE   "tune_title"
 
#define PURPLE_TUNE_ALBUM   "tune_album"
 
#define PURPLE_TUNE_GENRE   "tune_genre"
 
#define PURPLE_TUNE_COMMENT   "tune_comment"
 
#define PURPLE_TUNE_TRACK   "tune_track"
 
#define PURPLE_TUNE_TIME   "tune_time"
 
#define PURPLE_TUNE_YEAR   "tune_year"
 
#define PURPLE_TUNE_URL   "tune_url"
 
#define PURPLE_TUNE_FULL   "tune_full"
 
#define PURPLE_MOOD_NAME   "mood"
 
#define PURPLE_MOOD_COMMENT   "moodtext"
 

Typedefs

typedef struct _PurpleStatusType PurpleStatusType
 PurpleStatusType's are created by each PRPL. More...
 
typedef struct _PurpleStatusAttr PurpleStatusAttr
 
typedef struct _PurplePresence PurplePresence
 
typedef struct _PurpleStatus PurpleStatus
 
typedef struct _PurpleMood PurpleMood
 

Enumerations

enum  PurplePresenceContext { PURPLE_PRESENCE_CONTEXT_UNSET = 0 , PURPLE_PRESENCE_CONTEXT_ACCOUNT , PURPLE_PRESENCE_CONTEXT_CONV , PURPLE_PRESENCE_CONTEXT_BUDDY }
 A context for a presence. More...
 
enum  PurpleStatusPrimitive {
  PURPLE_STATUS_UNSET = 0 , PURPLE_STATUS_OFFLINE , PURPLE_STATUS_AVAILABLE , PURPLE_STATUS_UNAVAILABLE ,
  PURPLE_STATUS_INVISIBLE , PURPLE_STATUS_AWAY , PURPLE_STATUS_EXTENDED_AWAY , PURPLE_STATUS_MOBILE ,
  PURPLE_STATUS_TUNE , PURPLE_STATUS_MOOD , PURPLE_STATUS_NUM_PRIMITIVES
}
 A primitive defining the basic structure of a status type. More...
 

Functions

PurpleStatusPrimitive API <br>
const char * purple_primitive_get_id_from_type (PurpleStatusPrimitive type)
 Lookup the id of a primitive status type based on the type. More...
 
const char * purple_primitive_get_name_from_type (PurpleStatusPrimitive type)
 Lookup the name of a primitive status type based on the type. More...
 
PurpleStatusPrimitive purple_primitive_get_type_from_id (const char *id)
 Lookup the value of a primitive status type based on the id. More...
 
PurpleStatusType API <br>
PurpleStatusTypepurple_status_type_new_full (PurpleStatusPrimitive primitive, const char *id, const char *name, gboolean saveable, gboolean user_settable, gboolean independent)
 Creates a new status type. More...
 
PurpleStatusTypepurple_status_type_new (PurpleStatusPrimitive primitive, const char *id, const char *name, gboolean user_settable)
 Creates a new status type with some default values ( saveable and not independent). More...
 
PurpleStatusTypepurple_status_type_new_with_attrs (PurpleStatusPrimitive primitive, const char *id, const char *name, gboolean saveable, gboolean user_settable, gboolean independent, const char *attr_id, const char *attr_name, PurpleValue *attr_value,...) G_GNUC_NULL_TERMINATED
 Creates a new status type with attributes. More...
 
void purple_status_type_destroy (PurpleStatusType *status_type)
 Destroys a status type. More...
 
void purple_status_type_set_primary_attr (PurpleStatusType *status_type, const char *attr_id)
 Sets a status type's primary attribute. More...
 
void purple_status_type_add_attr (PurpleStatusType *status_type, const char *id, const char *name, PurpleValue *value)
 Adds an attribute to a status type. More...
 
void purple_status_type_add_attrs (PurpleStatusType *status_type, const char *id, const char *name, PurpleValue *value,...) G_GNUC_NULL_TERMINATED
 Adds multiple attributes to a status type. More...
 
void purple_status_type_add_attrs_vargs (PurpleStatusType *status_type, va_list args)
 Adds multiple attributes to a status type using a va_list. More...
 
PurpleStatusPrimitive purple_status_type_get_primitive (const PurpleStatusType *status_type)
 Returns the primitive type of a status type. More...
 
const char * purple_status_type_get_id (const PurpleStatusType *status_type)
 Returns the ID of a status type. More...
 
const char * purple_status_type_get_name (const PurpleStatusType *status_type)
 Returns the name of a status type. More...
 
gboolean purple_status_type_is_saveable (const PurpleStatusType *status_type)
 Returns whether or not the status type is saveable. More...
 
gboolean purple_status_type_is_user_settable (const PurpleStatusType *status_type)
 Returns whether or not the status type can be set or modified by the user. More...
 
gboolean purple_status_type_is_independent (const PurpleStatusType *status_type)
 Returns whether or not the status type is independent. More...
 
gboolean purple_status_type_is_exclusive (const PurpleStatusType *status_type)
 Returns whether the status type is exclusive. More...
 
gboolean purple_status_type_is_available (const PurpleStatusType *status_type)
 Returns whether or not a status type is available. More...
 
const char * purple_status_type_get_primary_attr (const PurpleStatusType *type)
 Returns a status type's primary attribute ID. More...
 
PurpleStatusAttr * purple_status_type_get_attr (const PurpleStatusType *status_type, const char *id)
 Returns the attribute with the specified ID. More...
 
GList * purple_status_type_get_attrs (const PurpleStatusType *status_type)
 Returns a list of all attributes in a status type. More...
 
const PurpleStatusTypepurple_status_type_find_with_id (GList *status_types, const char *id)
 Find the PurpleStatusType with the given id. More...
 
PurpleStatusAttr API <br>
PurpleStatusAttr * purple_status_attr_new (const char *id, const char *name, PurpleValue *value_type)
 Creates a new status attribute. More...
 
void purple_status_attr_destroy (PurpleStatusAttr *attr)
 Destroys a status attribute. More...
 
const char * purple_status_attr_get_id (const PurpleStatusAttr *attr)
 Returns the ID of a status attribute. More...
 
const char * purple_status_attr_get_name (const PurpleStatusAttr *attr)
 Returns the name of a status attribute. More...
 
PurpleValuepurple_status_attr_get_value (const PurpleStatusAttr *attr)
 Returns the value of a status attribute. More...
 
PurpleStatus API <br>
PurpleStatus * purple_status_new (PurpleStatusType *status_type, PurplePresence *presence)
 Creates a new status. More...
 
void purple_status_destroy (PurpleStatus *status)
 Destroys a status. More...
 
void purple_status_set_active (PurpleStatus *status, gboolean active)
 Sets whether or not a status is active. More...
 
void purple_status_set_active_with_attrs (PurpleStatus *status, gboolean active, va_list args)
 Sets whether or not a status is active. More...
 
void purple_status_set_active_with_attrs_list (PurpleStatus *status, gboolean active, GList *attrs)
 Sets whether or not a status is active. More...
 
void purple_status_set_attr_boolean (PurpleStatus *status, const char *id, gboolean value)
 Sets the boolean value of an attribute in a status with the specified ID. More...
 
void purple_status_set_attr_int (PurpleStatus *status, const char *id, int value)
 Sets the integer value of an attribute in a status with the specified ID. More...
 
void purple_status_set_attr_string (PurpleStatus *status, const char *id, const char *value)
 Sets the string value of an attribute in a status with the specified ID. More...
 
PurpleStatusTypepurple_status_get_type (const PurpleStatus *status)
 Returns the status's type. More...
 
PurplePresence * purple_status_get_presence (const PurpleStatus *status)
 Returns the status's presence. More...
 
const char * purple_status_get_id (const PurpleStatus *status)
 Returns the status's type ID. More...
 
const char * purple_status_get_name (const PurpleStatus *status)
 Returns the status's name. More...
 
gboolean purple_status_is_independent (const PurpleStatus *status)
 Returns whether or not a status is independent. More...
 
gboolean purple_status_is_exclusive (const PurpleStatus *status)
 Returns whether or not a status is exclusive. More...
 
gboolean purple_status_is_available (const PurpleStatus *status)
 Returns whether or not a status is available. More...
 
gboolean purple_status_is_active (const PurpleStatus *status)
 Returns the active state of a status. More...
 
gboolean purple_status_is_online (const PurpleStatus *status)
 Returns whether or not a status is considered 'online'. More...
 
PurpleValuepurple_status_get_attr_value (const PurpleStatus *status, const char *id)
 Returns the value of an attribute in a status with the specified ID. More...
 
gboolean purple_status_get_attr_boolean (const PurpleStatus *status, const char *id)
 Returns the boolean value of an attribute in a status with the specified ID. More...
 
int purple_status_get_attr_int (const PurpleStatus *status, const char *id)
 Returns the integer value of an attribute in a status with the specified ID. More...
 
const char * purple_status_get_attr_string (const PurpleStatus *status, const char *id)
 Returns the string value of an attribute in a status with the specified ID. More...
 
gint purple_status_compare (const PurpleStatus *status1, const PurpleStatus *status2)
 Compares two statuses for availability. More...
 
PurplePresence API <br>
PurplePresence * purple_presence_new (PurplePresenceContext context)
 Creates a new presence. More...
 
PurplePresence * purple_presence_new_for_account (PurpleAccount *account)
 Creates a presence for an account. More...
 
PurplePresence * purple_presence_new_for_conv (PurpleConversation *conv)
 Creates a presence for a conversation. More...
 
PurplePresence * purple_presence_new_for_buddy (PurpleBuddy *buddy)
 Creates a presence for a buddy. More...
 
void purple_presence_destroy (PurplePresence *presence)
 Destroys a presence. More...
 
void purple_presence_add_status (PurplePresence *presence, PurpleStatus *status)
 Adds a status to a presence. More...
 
void purple_presence_add_list (PurplePresence *presence, GList *source_list)
 Adds a list of statuses to the presence. More...
 
void purple_presence_set_status_active (PurplePresence *presence, const char *status_id, gboolean active)
 Sets the active state of a status in a presence. More...
 
void purple_presence_switch_status (PurplePresence *presence, const char *status_id)
 Switches the active status in a presence. More...
 
void purple_presence_set_idle (PurplePresence *presence, gboolean idle, time_t idle_time)
 Sets the idle state and time on a presence. More...
 
void purple_presence_set_login_time (PurplePresence *presence, time_t login_time)
 Sets the login time on a presence. More...
 
PurplePresenceContext purple_presence_get_context (const PurplePresence *presence)
 Returns the presence's context. More...
 
PurpleAccountpurple_presence_get_account (const PurplePresence *presence)
 Returns a presence's account. More...
 
PurpleConversationpurple_presence_get_conversation (const PurplePresence *presence)
 Returns a presence's conversation. More...
 
const char * purple_presence_get_chat_user (const PurplePresence *presence)
 Returns a presence's chat user. More...
 
PurpleBuddypurple_presence_get_buddy (const PurplePresence *presence)
 Returns the presence's buddy. More...
 
GList * purple_presence_get_statuses (const PurplePresence *presence)
 Returns all the statuses in a presence. More...
 
PurpleStatus * purple_presence_get_status (const PurplePresence *presence, const char *status_id)
 Returns the status with the specified ID from a presence. More...
 
PurpleStatus * purple_presence_get_active_status (const PurplePresence *presence)
 Returns the active exclusive status from a presence. More...
 
gboolean purple_presence_is_available (const PurplePresence *presence)
 Returns whether or not a presence is available. More...
 
gboolean purple_presence_is_online (const PurplePresence *presence)
 Returns whether or not a presence is online. More...
 
gboolean purple_presence_is_status_active (const PurplePresence *presence, const char *status_id)
 Returns whether or not a status in a presence is active. More...
 
gboolean purple_presence_is_status_primitive_active (const PurplePresence *presence, PurpleStatusPrimitive primitive)
 Returns whether or not a status with the specified primitive type in a presence is active. More...
 
gboolean purple_presence_is_idle (const PurplePresence *presence)
 Returns whether or not a presence is idle. More...
 
time_t purple_presence_get_idle_time (const PurplePresence *presence)
 Returns the presence's idle time. More...
 
time_t purple_presence_get_login_time (const PurplePresence *presence)
 Returns the presence's login time. More...
 
gint purple_presence_compare (const PurplePresence *presence1, const PurplePresence *presence2)
 Compares two presences for availability. More...
 
Status subsystem <br>
void * purple_status_get_handle (void)
 Get the handle for the status subsystem. More...
 
void purple_status_init (void)
 Initializes the status subsystem.
 
void purple_status_uninit (void)
 Uninitializes the status subsystem.
 

Detailed Description

Status API.

A brief explanation of the status API:

PurpleStatusType's are created by each PRPL. They outline the available statuses of the protocol. AIM, for example, supports an available state with an optional available message, an away state with a mandatory message, and an invisible state (which is technically "independent" of the other two, but we'll get into that later). PurpleStatusTypes are very permanent. They are hardcoded in each PRPL and will not change often. And because they are hardcoded, they do not need to be saved to any XML file.

A PurpleStatus can be thought of as an "instance" of a PurpleStatusType. If you're familiar with object-oriented programming languages then this should be immediately clear. Say, for example, that one of your AIM buddies has set himself as "away." You have a PurpleBuddy node for this person in your buddy list. Purple wants to mark this buddy as "away," so it creates a new PurpleStatus. The PurpleStatus has its PurpleStatusType set to the "away" state for the oscar PRPL. The PurpleStatus also contains the buddy's away message. PurpleStatuses are sometimes saved, depending on the context. The current PurpleStatuses associated with each of your accounts are saved so that the next time you start Purple, your accounts will be set to their last known statuses. There is also a list of saved statuses that are written to the status.xml file. Also, each PurpleStatus has a "saveable" boolean. If "saveable" is set to FALSE then the status is NEVER saved. All PurpleStatuses should be inside a PurplePresence.

A PurpleStatus is either "independent" or "exclusive." Independent statuses can be active or inactive and they don't affect anything else. However, you can only have one exclusive status per PurplePresence. If you activate one exclusive status, then the previous exclusive status is automatically deactivated.

A PurplePresence is like a collection of PurpleStatuses (plus some other random info). For any buddy, or for any one of your accounts, or for any person with which you're chatting, you may know various amounts of information. This information is all contained in one PurplePresence. If one of your buddies is away and idle, then the presence contains the PurpleStatus for their awayness, and it contains their current idle time. PurplePresences are never saved to disk. The information they contain is only relevant for the current PurpleSession.

Definition in file status.h.

Macro Definition Documentation

◆ PURPLE_MOOD_COMMENT

#define PURPLE_MOOD_COMMENT   "moodtext"

Definition at line 149 of file status.h.

◆ PURPLE_MOOD_NAME

#define PURPLE_MOOD_NAME   "mood"

Definition at line 148 of file status.h.

◆ PURPLE_TUNE_ALBUM

#define PURPLE_TUNE_ALBUM   "tune_album"

Definition at line 139 of file status.h.

◆ PURPLE_TUNE_ARTIST

#define PURPLE_TUNE_ARTIST   "tune_artist"

Definition at line 137 of file status.h.

◆ PURPLE_TUNE_COMMENT

#define PURPLE_TUNE_COMMENT   "tune_comment"

Definition at line 141 of file status.h.

◆ PURPLE_TUNE_FULL

#define PURPLE_TUNE_FULL   "tune_full"

Definition at line 146 of file status.h.

◆ PURPLE_TUNE_GENRE

#define PURPLE_TUNE_GENRE   "tune_genre"

Definition at line 140 of file status.h.

◆ PURPLE_TUNE_TIME

#define PURPLE_TUNE_TIME   "tune_time"

Definition at line 143 of file status.h.

◆ PURPLE_TUNE_TITLE

#define PURPLE_TUNE_TITLE   "tune_title"

Definition at line 138 of file status.h.

◆ PURPLE_TUNE_TRACK

#define PURPLE_TUNE_TRACK   "tune_track"

Definition at line 142 of file status.h.

◆ PURPLE_TUNE_URL

#define PURPLE_TUNE_URL   "tune_url"

Definition at line 145 of file status.h.

◆ PURPLE_TUNE_YEAR

#define PURPLE_TUNE_YEAR   "tune_year"

Definition at line 144 of file status.h.

Typedef Documentation

◆ PurplePresence

typedef struct _PurplePresence PurplePresence

Definition at line 87 of file status.h.

◆ PurpleStatus

typedef struct _PurpleStatus PurpleStatus

Definition at line 88 of file status.h.

◆ PurpleStatusAttr

typedef struct _PurpleStatusAttr PurpleStatusAttr

Definition at line 86 of file status.h.

◆ PurpleStatusType

typedef struct _PurpleStatusType PurpleStatusType

PurpleStatusType's are created by each PRPL.

They outline the available statuses of the protocol. AIM, for example, supports an available state with an optional available message, an away state with a mandatory message, and an invisible state (which is technically "independent" of the other two, but we'll get into that later). PurpleStatusTypes are very permanent. They are hardcoded in each PRPL and will not change often. And because they are hardcoded, they do not need to be saved to any XML file.

Definition at line 85 of file status.h.

Enumeration Type Documentation

◆ PurplePresenceContext

A context for a presence.

The context indicates to what the presence applies.

Definition at line 101 of file status.h.

◆ PurpleStatusPrimitive

A primitive defining the basic structure of a status type.

Definition at line 117 of file status.h.

Function Documentation

◆ purple_presence_add_list()

void purple_presence_add_list ( PurplePresence *  presence,
GList *  source_list 
)

Adds a list of statuses to the presence.

Parameters
presenceThe presence.
source_listThe source list of statuses to add, which is not modified or freed by this function.
Deprecated:
This function isn't used and should be removed in 3.0.0.

◆ purple_presence_add_status()

void purple_presence_add_status ( PurplePresence *  presence,
PurpleStatus *  status 
)

Adds a status to a presence.

Parameters
presenceThe presence.
statusThe status to add.
Deprecated:
This function is only used by purple_presence_add_list, and both should be removed in 3.0.0.

◆ purple_presence_compare()

gint purple_presence_compare ( const PurplePresence *  presence1,
const PurplePresence *  presence2 
)

Compares two presences for availability.

Parameters
presence1The first presence.
presence2The second presence.
Returns
-1 if presence1 is more available than presence2. 0 if presence1 is equal to presence2. 1 if presence1 is less available than presence2.

◆ purple_presence_destroy()

void purple_presence_destroy ( PurplePresence *  presence)

Destroys a presence.

All statuses added to this list will be destroyed along with the presence.

Parameters
presenceThe presence to destroy.

◆ purple_presence_get_account()

PurpleAccount * purple_presence_get_account ( const PurplePresence *  presence)

Returns a presence's account.

Parameters
presenceThe presence.
Returns
The presence's account.

◆ purple_presence_get_active_status()

PurpleStatus * purple_presence_get_active_status ( const PurplePresence *  presence)

Returns the active exclusive status from a presence.

Parameters
presenceThe presence.
Returns
The active exclusive status.

◆ purple_presence_get_buddy()

PurpleBuddy * purple_presence_get_buddy ( const PurplePresence *  presence)

Returns the presence's buddy.

Parameters
presenceThe presence.
Returns
The presence's buddy.

◆ purple_presence_get_chat_user()

const char * purple_presence_get_chat_user ( const PurplePresence *  presence)

Returns a presence's chat user.

Parameters
presenceThe presence.
Returns
The chat's user.

◆ purple_presence_get_context()

PurplePresenceContext purple_presence_get_context ( const PurplePresence *  presence)

Returns the presence's context.

Parameters
presenceThe presence.
Returns
The presence's context.

◆ purple_presence_get_conversation()

PurpleConversation * purple_presence_get_conversation ( const PurplePresence *  presence)

Returns a presence's conversation.

Parameters
presenceThe presence.
Returns
The presence's conversation.

◆ purple_presence_get_idle_time()

time_t purple_presence_get_idle_time ( const PurplePresence *  presence)

Returns the presence's idle time.

Parameters
presenceThe presence.
Returns
The presence's idle time.

◆ purple_presence_get_login_time()

time_t purple_presence_get_login_time ( const PurplePresence *  presence)

Returns the presence's login time.

Parameters
presenceThe presence.
Returns
The presence's login time.

◆ purple_presence_get_status()

PurpleStatus * purple_presence_get_status ( const PurplePresence *  presence,
const char *  status_id 
)

Returns the status with the specified ID from a presence.

Parameters
presenceThe presence.
status_idThe ID of the status.
Returns
The status if found, or NULL.

◆ purple_presence_get_statuses()

GList * purple_presence_get_statuses ( const PurplePresence *  presence)

Returns all the statuses in a presence.

Parameters
presenceThe presence.
Note
The return value of this function must not be modified or freed.
Returns
The statuses.

◆ purple_presence_is_available()

gboolean purple_presence_is_available ( const PurplePresence *  presence)

Returns whether or not a presence is available.

Available presences are online and possibly invisible, but not away or idle.

Parameters
presenceThe presence.
Returns
TRUE if the presence is available, or FALSE otherwise.

◆ purple_presence_is_idle()

gboolean purple_presence_is_idle ( const PurplePresence *  presence)

Returns whether or not a presence is idle.

Parameters
presenceThe presence.
Returns
TRUE if the presence is idle, or FALSE otherwise. If the presence is offline (purple_presence_is_online() returns FALSE) then FALSE is returned.

◆ purple_presence_is_online()

gboolean purple_presence_is_online ( const PurplePresence *  presence)

Returns whether or not a presence is online.

Parameters
presenceThe presence.
Returns
TRUE if the presence is online, or FALSE otherwise.

◆ purple_presence_is_status_active()

gboolean purple_presence_is_status_active ( const PurplePresence *  presence,
const char *  status_id 
)

Returns whether or not a status in a presence is active.

A status is active if itself or any of its sub-statuses are active.

Parameters
presenceThe presence.
status_idThe ID of the status.
Returns
TRUE if the status is active, or FALSE.

◆ purple_presence_is_status_primitive_active()

gboolean purple_presence_is_status_primitive_active ( const PurplePresence *  presence,
PurpleStatusPrimitive  primitive 
)

Returns whether or not a status with the specified primitive type in a presence is active.

A status is active if itself or any of its sub-statuses are active.

Parameters
presenceThe presence.
primitiveThe status primitive.
Returns
TRUE if the status is active, or FALSE.

◆ purple_presence_new()

PurplePresence * purple_presence_new ( PurplePresenceContext  context)

Creates a new presence.

Parameters
contextThe presence context.
Returns
A new presence.

◆ purple_presence_new_for_account()

PurplePresence * purple_presence_new_for_account ( PurpleAccount account)

Creates a presence for an account.

Parameters
accountThe account.
Returns
The new presence.

◆ purple_presence_new_for_buddy()

PurplePresence * purple_presence_new_for_buddy ( PurpleBuddy buddy)

Creates a presence for a buddy.

Parameters
buddyThe buddy.
Returns
The new presence.

◆ purple_presence_new_for_conv()

PurplePresence * purple_presence_new_for_conv ( PurpleConversation conv)

Creates a presence for a conversation.

Parameters
convThe conversation.
Returns
The new presence.

◆ purple_presence_set_idle()

void purple_presence_set_idle ( PurplePresence *  presence,
gboolean  idle,
time_t  idle_time 
)

Sets the idle state and time on a presence.

Parameters
presenceThe presence.
idleThe idle state.
idle_timeThe idle time, if idle is TRUE. This is the time at which the user became idle, in seconds since the epoch. If this value is unknown then 0 should be used.

◆ purple_presence_set_login_time()

void purple_presence_set_login_time ( PurplePresence *  presence,
time_t  login_time 
)

Sets the login time on a presence.

Parameters
presenceThe presence.
login_timeThe login time.

◆ purple_presence_set_status_active()

void purple_presence_set_status_active ( PurplePresence *  presence,
const char *  status_id,
gboolean  active 
)

Sets the active state of a status in a presence.

Only independent statuses can be set unactive. Normal statuses can only be set active, so if you wish to disable a status, set another non-independent status to active, or use purple_presence_switch_status().

Parameters
presenceThe presence.
status_idThe ID of the status.
activeThe active state.

◆ purple_presence_switch_status()

void purple_presence_switch_status ( PurplePresence *  presence,
const char *  status_id 
)

Switches the active status in a presence.

This is similar to purple_presence_set_status_active(), except it won't activate independent statuses.

Parameters
presenceThe presence.
status_idThe status ID to switch to.

◆ purple_primitive_get_id_from_type()

const char * purple_primitive_get_id_from_type ( PurpleStatusPrimitive  type)

Lookup the id of a primitive status type based on the type.

This ID is a unique plain-text name of the status, without spaces.

Parameters
typeA primitive status type.
Returns
The unique ID for this type.

◆ purple_primitive_get_name_from_type()

const char * purple_primitive_get_name_from_type ( PurpleStatusPrimitive  type)

Lookup the name of a primitive status type based on the type.

This name is the plain-English name of the status type. It is usually one or two words.

Parameters
typeA primitive status type.
Returns
The name of this type, suitable for users to see.

◆ purple_primitive_get_type_from_id()

PurpleStatusPrimitive purple_primitive_get_type_from_id ( const char *  id)

Lookup the value of a primitive status type based on the id.

The ID is a unique plain-text name of the status, without spaces.

Parameters
idThe unique ID of a primitive status type.
Returns
The PurpleStatusPrimitive value.

◆ purple_status_attr_destroy()

void purple_status_attr_destroy ( PurpleStatusAttr *  attr)

Destroys a status attribute.

Parameters
attrThe status attribute to destroy.

◆ purple_status_attr_get_id()

const char * purple_status_attr_get_id ( const PurpleStatusAttr *  attr)

Returns the ID of a status attribute.

Parameters
attrThe status attribute.
Returns
The status attribute's ID.

◆ purple_status_attr_get_name()

const char * purple_status_attr_get_name ( const PurpleStatusAttr *  attr)

Returns the name of a status attribute.

Parameters
attrThe status attribute.
Returns
The status attribute's name.

◆ purple_status_attr_get_value()

PurpleValue * purple_status_attr_get_value ( const PurpleStatusAttr *  attr)

Returns the value of a status attribute.

Parameters
attrThe status attribute.
Returns
The status attribute's value.

◆ purple_status_attr_new()

PurpleStatusAttr * purple_status_attr_new ( const char *  id,
const char *  name,
PurpleValue value_type 
)

Creates a new status attribute.

Parameters
idThe ID of the attribute.
nameThe name presented to the user.
value_typeThe type of data contained in the attribute.
Returns
A new status attribute.

◆ purple_status_compare()

gint purple_status_compare ( const PurpleStatus *  status1,
const PurpleStatus *  status2 
)

Compares two statuses for availability.

Parameters
status1The first status.
status2The second status.
Returns
-1 if status1 is more available than status2. 0 if status1 is equal to status2. 1 if status2 is more available than status1.

◆ purple_status_destroy()

void purple_status_destroy ( PurpleStatus *  status)

Destroys a status.

Parameters
statusThe status to destroy.

◆ purple_status_get_attr_boolean()

gboolean purple_status_get_attr_boolean ( const PurpleStatus *  status,
const char *  id 
)

Returns the boolean value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
Returns
The boolean value of the attribute.

◆ purple_status_get_attr_int()

int purple_status_get_attr_int ( const PurpleStatus *  status,
const char *  id 
)

Returns the integer value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
Returns
The integer value of the attribute.

◆ purple_status_get_attr_string()

const char * purple_status_get_attr_string ( const PurpleStatus *  status,
const char *  id 
)

Returns the string value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
Returns
The string value of the attribute.

◆ purple_status_get_attr_value()

PurpleValue * purple_status_get_attr_value ( const PurpleStatus *  status,
const char *  id 
)

Returns the value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
Returns
The value of the attribute.

◆ purple_status_get_handle()

void * purple_status_get_handle ( void  )

Get the handle for the status subsystem.

Returns
the handle to the status subsystem

◆ purple_status_get_id()

const char * purple_status_get_id ( const PurpleStatus *  status)

Returns the status's type ID.

This is a convenience method for purple_status_type_get_id(purple_status_get_type(status)).

Parameters
statusThe status.
Returns
The status's ID.

◆ purple_status_get_name()

const char * purple_status_get_name ( const PurpleStatus *  status)

Returns the status's name.

This is a convenience method for purple_status_type_get_name(purple_status_get_type(status)).

Parameters
statusThe status.
Returns
The status's name.

◆ purple_status_get_presence()

PurplePresence * purple_status_get_presence ( const PurpleStatus *  status)

Returns the status's presence.

Parameters
statusThe status.
Returns
The status's presence.

◆ purple_status_get_type()

PurpleStatusType * purple_status_get_type ( const PurpleStatus *  status)

Returns the status's type.

Parameters
statusThe status.
Returns
The status's type.

◆ purple_status_is_active()

gboolean purple_status_is_active ( const PurpleStatus *  status)

Returns the active state of a status.

Parameters
statusThe status.
Returns
The active state of the status.

◆ purple_status_is_available()

gboolean purple_status_is_available ( const PurpleStatus *  status)

Returns whether or not a status is available.

Available statuses are online and possibly invisible, but not away or idle.

This is a convenience method for purple_status_type_is_available(purple_status_get_type(status)).

Parameters
statusThe status.
Returns
TRUE if the status is available, or FALSE otherwise.

◆ purple_status_is_exclusive()

gboolean purple_status_is_exclusive ( const PurpleStatus *  status)

Returns whether or not a status is exclusive.

This is a convenience method for purple_status_type_is_exclusive(purple_status_get_type(status)).

Parameters
statusThe status.
Returns
TRUE if the status is exclusive, FALSE otherwise.

◆ purple_status_is_independent()

gboolean purple_status_is_independent ( const PurpleStatus *  status)

Returns whether or not a status is independent.

This is a convenience method for purple_status_type_is_independent(purple_status_get_type(status)).

Parameters
statusThe status.
Returns
TRUE if the status is independent, or FALSE otherwise.

◆ purple_status_is_online()

gboolean purple_status_is_online ( const PurpleStatus *  status)

Returns whether or not a status is considered 'online'.

Parameters
statusThe status.
Returns
TRUE if the status is considered online, FALSE otherwise

◆ purple_status_new()

PurpleStatus * purple_status_new ( PurpleStatusType status_type,
PurplePresence *  presence 
)

Creates a new status.

Parameters
status_typeThe type of status.
presenceThe parent presence.
Returns
The new status.

◆ purple_status_set_active()

void purple_status_set_active ( PurpleStatus *  status,
gboolean  active 
)

Sets whether or not a status is active.

This should only be called by the account, conversation, and buddy APIs.

Parameters
statusThe status.
activeThe active state.

◆ purple_status_set_active_with_attrs()

void purple_status_set_active_with_attrs ( PurpleStatus *  status,
gboolean  active,
va_list  args 
)

Sets whether or not a status is active.

This should only be called by the account, conversation, and buddy APIs.

Parameters
statusThe status.
activeThe active state.
argsA list of attributes to set on the status. This list is composed of key/value pairs, where each key is a valid attribute name for this PurpleStatusType. The list should be NULL terminated.

◆ purple_status_set_active_with_attrs_list()

void purple_status_set_active_with_attrs_list ( PurpleStatus *  status,
gboolean  active,
GList *  attrs 
)

Sets whether or not a status is active.

This should only be called by the account, conversation, and buddy APIs.

Parameters
statusThe status.
activeThe active state.
attrsA list of attributes to set on the status. This list is composed of key/value pairs, where each key is a valid attribute name for this PurpleStatusType. The list is not modified or freed by this function.

◆ purple_status_set_attr_boolean()

void purple_status_set_attr_boolean ( PurpleStatus *  status,
const char *  id,
gboolean  value 
)

Sets the boolean value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
valueThe boolean value.
Deprecated:
This function is only used by status.c and should be made static in 3.0.0.

◆ purple_status_set_attr_int()

void purple_status_set_attr_int ( PurpleStatus *  status,
const char *  id,
int  value 
)

Sets the integer value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
valueThe integer value.
Deprecated:
This function is only used by status.c and should be made static in 3.0.0.

◆ purple_status_set_attr_string()

void purple_status_set_attr_string ( PurpleStatus *  status,
const char *  id,
const char *  value 
)

Sets the string value of an attribute in a status with the specified ID.

Parameters
statusThe status.
idThe attribute ID.
valueThe string value.
Deprecated:
This function is only used by status.c and should be made static in 3.0.0.

◆ purple_status_type_add_attr()

void purple_status_type_add_attr ( PurpleStatusType status_type,
const char *  id,
const char *  name,
PurpleValue value 
)

Adds an attribute to a status type.

Parameters
status_typeThe status type to add the attribute to.
idThe ID of the attribute.
nameThe name presented to the user.
valueThe value type of this attribute.
Deprecated:
This function isn't needed and should be removed in 3.0.0. Status type attributes should be set when the status type is created, in the call to purple_status_type_new_with_attrs.

◆ purple_status_type_add_attrs()

void purple_status_type_add_attrs ( PurpleStatusType status_type,
const char *  id,
const char *  name,
PurpleValue value,
  ... 
)

Adds multiple attributes to a status type.

Parameters
status_typeThe status type to add the attribute to.
idThe ID of the first attribute.
nameThe description of the first attribute.
valueThe value type of the first attribute attribute.
...Additional attribute information.
Deprecated:
This function isn't needed and should be removed in 3.0.0. Status type attributes should be set when the status type is created, in the call to purple_status_type_new_with_attrs.

◆ purple_status_type_add_attrs_vargs()

void purple_status_type_add_attrs_vargs ( PurpleStatusType status_type,
va_list  args 
)

Adds multiple attributes to a status type using a va_list.

Parameters
status_typeThe status type to add the attribute to.
argsThe va_list of attributes.
Deprecated:
This function isn't needed and should be removed in 3.0.0. Status type attributes should be set when the status type is created, in the call to purple_status_type_new_with_attrs.

◆ purple_status_type_destroy()

void purple_status_type_destroy ( PurpleStatusType status_type)

Destroys a status type.

Parameters
status_typeThe status type to destroy.

◆ purple_status_type_find_with_id()

const PurpleStatusType * purple_status_type_find_with_id ( GList *  status_types,
const char *  id 
)

Find the PurpleStatusType with the given id.

Parameters
status_typesA list of status types. Often account->status_types.
idThe unique ID of the status type you wish to find.
Returns
The status type with the given ID, or NULL if one could not be found.

◆ purple_status_type_get_attr()

PurpleStatusAttr * purple_status_type_get_attr ( const PurpleStatusType status_type,
const char *  id 
)

Returns the attribute with the specified ID.

Parameters
status_typeThe status type containing the attribute.
idThe ID of the desired attribute.
Returns
The attribute, if found. NULL otherwise.

◆ purple_status_type_get_attrs()

GList * purple_status_type_get_attrs ( const PurpleStatusType status_type)

Returns a list of all attributes in a status type.

Parameters
status_typeThe status type.
Note
The return value of this function must not be modified or freed.
Returns
The list of attributes.

◆ purple_status_type_get_id()

const char * purple_status_type_get_id ( const PurpleStatusType status_type)

Returns the ID of a status type.

Parameters
status_typeThe status type.
Returns
The ID of the status type.

◆ purple_status_type_get_name()

const char * purple_status_type_get_name ( const PurpleStatusType status_type)

Returns the name of a status type.

Parameters
status_typeThe status type.
Returns
The name of the status type.

◆ purple_status_type_get_primary_attr()

const char * purple_status_type_get_primary_attr ( const PurpleStatusType type)

Returns a status type's primary attribute ID.

Parameters
typeThe status type.
Returns
The primary attribute's ID.
Deprecated:
This function isn't used and should be removed in 3.0.0.

◆ purple_status_type_get_primitive()

PurpleStatusPrimitive purple_status_type_get_primitive ( const PurpleStatusType status_type)

Returns the primitive type of a status type.

Parameters
status_typeThe status type.
Returns
The primitive type of the status type.

◆ purple_status_type_is_available()

gboolean purple_status_type_is_available ( const PurpleStatusType status_type)

Returns whether or not a status type is available.

Available status types are online and possibly invisible, but not away.

Parameters
status_typeThe status type.
Returns
TRUE if the status is available, or FALSE otherwise.

◆ purple_status_type_is_exclusive()

gboolean purple_status_type_is_exclusive ( const PurpleStatusType status_type)

Returns whether the status type is exclusive.

Parameters
status_typeThe status type.
Returns
TRUE if the status type is exclusive, FALSE otherwise.

◆ purple_status_type_is_independent()

gboolean purple_status_type_is_independent ( const PurpleStatusType status_type)

Returns whether or not the status type is independent.

Independent status types are non-exclusive. If other status types on the same hierarchy level are set, this one will not be affected.

Parameters
status_typeThe status type.
Returns
TRUE if the status type is independent, or FALSE otherwise.

◆ purple_status_type_is_saveable()

gboolean purple_status_type_is_saveable ( const PurpleStatusType status_type)

Returns whether or not the status type is saveable.

Parameters
status_typeThe status type.
Returns
TRUE if user-defined statuses based off this type are saveable. FALSE otherwise.

◆ purple_status_type_is_user_settable()

gboolean purple_status_type_is_user_settable ( const PurpleStatusType status_type)

Returns whether or not the status type can be set or modified by the user.

Parameters
status_typeThe status type.
Returns
TRUE if the status type can be set or modified by the user. FALSE if it's a protocol-set setting.

◆ purple_status_type_new()

PurpleStatusType * purple_status_type_new ( PurpleStatusPrimitive  primitive,
const char *  id,
const char *  name,
gboolean  user_settable 
)

Creates a new status type with some default values ( saveable and not independent).

Parameters
primitiveThe primitive status type.
idThe ID of the status type, or NULL to use the id of the primitive status type.
nameThe name presented to the user, or NULL to use the name of the primitive status type.
user_settableTRUE if this is a status the user can manually set.
Returns
A new status type.

◆ purple_status_type_new_full()

PurpleStatusType * purple_status_type_new_full ( PurpleStatusPrimitive  primitive,
const char *  id,
const char *  name,
gboolean  saveable,
gboolean  user_settable,
gboolean  independent 
)

Creates a new status type.

Parameters
primitiveThe primitive status type.
idThe ID of the status type, or NULL to use the id of the primitive status type.
nameThe name presented to the user, or NULL to use the name of the primitive status type.
saveableTRUE if the information set for this status by the user can be saved for future sessions.
user_settableTRUE if this is a status the user can manually set.
independentTRUE if this is an independent (non-exclusive) status type.
Returns
A new status type.

◆ purple_status_type_new_with_attrs()

PurpleStatusType * purple_status_type_new_with_attrs ( PurpleStatusPrimitive  primitive,
const char *  id,
const char *  name,
gboolean  saveable,
gboolean  user_settable,
gboolean  independent,
const char *  attr_id,
const char *  attr_name,
PurpleValue attr_value,
  ... 
)

Creates a new status type with attributes.

Parameters
primitiveThe primitive status type.
idThe ID of the status type, or NULL to use the id of the primitive status type.
nameThe name presented to the user, or NULL to use the name of the primitive status type.
saveableTRUE if the information set for this status by the user can be saved for future sessions.
user_settableTRUE if this is a status the user can manually set.
independentTRUE if this is an independent (non-exclusive) status type.
attr_idThe ID of the first attribute.
attr_nameThe name of the first attribute.
attr_valueThe value type of the first attribute attribute.
...Additional attribute information.
Returns
A new status type.

◆ purple_status_type_set_primary_attr()

void purple_status_type_set_primary_attr ( PurpleStatusType status_type,
const char *  attr_id 
)

Sets a status type's primary attribute.

The value for the primary attribute is used as the description for the particular status type. An example is an away message. The message would be the primary attribute.

Parameters
status_typeThe status type.
attr_idThe ID of the primary attribute.
Deprecated:
This function isn't used and should be removed in 3.0.0.