+ def __get_alias(self):
+ '''Returns the buddy's alias
+
+ @return Buddy alias(if set) or None
+ '''
+
+ cdef char *c_alias = NULL
+ c_alias = <char *> blist.purple_buddy_get_alias_only( \
+ self._get_structure())
+ if c_alias:
+ return unicode(c_alias, 'utf-8')
+ else:
+ return None
+ alias = property(__get_alias)
+
+ def __get_account(self):
+ '''Returns the buddy's account.
+
+ @return The account(if buddy exists) or None.
+ '''
+
+ if self.__exists:
+ return self.__account
+ else:
+ return None
+ account = property(__get_account)
+
+ def __get_group(self):
+ '''Returns the buddy's group.
+
+ @return The group or None if buddy is not in a group.
+ '''
+
+ cdef blist.PurpleGroup *c_group = NULL
+ if self.__exists:
+ c_group = blist.purple_buddy_get_group(self._get_structure())
+ return <char *> blist.purple_group_get_name(c_group)
+ else:
+ return None
+ group = property(__get_group)
+
+ def __get_server_alias(self):
+ '''Gets the server alias of the buddy.
+
+ @return The server alias, or None if it is not set.
+ '''
+
+ cdef char *c_server_alias = NULL
+ c_server_alias = <char *> blist.purple_buddy_get_server_alias( \
+ self._get_structure())
+ if c_server_alias:
+ return c_server_alias
+ else:
+ return None
+ server_alias = property(__get_server_alias)
+
+ def __get_contact_alias(self):
+ '''Returns the correct name to display for a buddy, taking the contact
+ alias into account. In order of precedence: the buddy's alias;
+ the buddy's contact alias; the buddy's server alias; the buddy's
+ user name.
+
+ @return The appropriate name or alias, or None.
+ '''
+
+ cdef char *c_contact_alias = NULL
+ c_contact_alias = <char *> blist.purple_buddy_get_contact_alias( \
+ self._get_structure())
+ if c_contact_alias:
+ return c_contact_alias
+ else:
+ return None
+ contact_alias = property(__get_contact_alias)
+
+ def __get_local_alias(self):
+ '''Returns the correct alias for this user, ignoring server aliases.
+ Used when a user-recognizable name is required. In order: buddy's
+ alias; buddy's contact alias; buddy's user name.
+
+ @return The appropriate name or alias, or None.
+ '''
+
+ cdef char *c_local_alias = NULL
+ c_local_alias = <char *> blist.purple_buddy_get_local_alias( \
+ self._get_structure())
+ if c_local_alias:
+ return c_local_alias
+ else:
+ return None
+ local_alias = property(__get_local_alias)
+
+ def __get_available(self):
+ '''Returns whether or not buddy's presence is available.
+ Available presences are online and possibly invisible, but not away or idle.
+
+ @return True if the buddy's presence is available, or False otherwise.
+ '''
+
+ if self.__exists:
+ return status.purple_presence_is_available( \
+ blist.purple_buddy_get_presence(self._get_structure()))
+ else:
+ return False
+ available = property(__get_available)
+