Mercurial > pidgin.yaz
view src/protocols/novell/nmuserrecord.h @ 10789:0caa9827edf5
[gaim-migrate @ 12431]
" The following log snippets should explain it: " --rlaager
(20:24:00) rlaager: Regarding the signal handling
conversation the other day... I've written a patch to stop
calling signal handlers and return as soon as we find one
signal handler that returns TRUE to indicate that it's
handled the signal. Is this the right approach?
(20:24:22) Ethan Blanton (Paco-Paco): the trouble is that it's
documented to behave exactly the way it does
(20:24:31) Ethan Blanton (Paco-Paco): so changing it is
notbackwards compatible
(20:24:31) rlaager: I'm talking for HEAD.
(20:24:41) Ethan Blanton (Paco-Paco): oh, I think that's a
good approach, yes
(20:24:53) rlaager: The way I've described is how I
*expected* it to work, having not read the documentation.
(20:25:09) Ethan Blanton (Paco-Paco): I'm convinced
(20:27:04) Stu Tomlinson (nosnilmot): rlaager: this, I
assume, breaks the generic-ness of signals, by assuming
that any that return values return booleans?
(20:27:26) Ethan Blanton (Paco-Paco): please break it
(20:27:33) Ethan Blanton (Paco-Paco): we already have
out-parameters
(20:27:42) rlaager: nosnilmot: from what I can see, the
return type is handled as a (void *)... so I'm checking that
ret_value != NULL
(20:27:57) rlaager: nosnilmot: that's the correct way to do it,
right?
...
(20:29:01) Ethan Blanton (Paco-Paco): allowing a
meaningful return value is an over-engineering
(20:30:07) rlaager: even after this patch, you should be able
to return meaningful return values
(20:30:15) rlaager: it'll just short-circuit on the first handler
that does
committer: Tailor Script <tailor@pidgin.im>
author | Luke Schierer <lschiere@pidgin.im> |
---|---|
date | Thu, 07 Apr 2005 14:55:02 +0000 |
parents | 6663ad2386d9 |
children | fc464a0abccc |
line wrap: on
line source
/* * nmuserrecord.h * * Copyright (c) 2004 Novell, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License. * * 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ #ifndef __NM_USER_RECORD_H__ #define __NM_USER_RECORD_H__ #include <glib.h> typedef struct _NMUserRecord NMUserRecord; typedef struct _NMProperty NMProperty; #include "nmfield.h" #include "nmuser.h" /** * Creates an NMUserRecord * * The NMUserRecord should be released by calling * nm_release_user_record * * @return The new user record * */ NMUserRecord *nm_create_user_record(); /** * Creates an NMUserRecord * * The NMUserRecord should be released by calling * nm_release_user_record * * @param details Should be a NM_A_FA_USER_DETAILS * * * @return The new user record * */ NMUserRecord *nm_create_user_record_from_fields(NMField * details); /** * Add a reference to an existing user_record * * The reference should be released by calling * nm_release_user_record * * @param user_record The contact to addref * */ void nm_user_record_add_ref(NMUserRecord * user_record); /** * Release a reference to the user record * * @param user_record The user record * */ void nm_release_user_record(NMUserRecord * user_record); /** * Set the status for the user record * * @param user_record The user record * @param status The status for the user * @param text The status text for the user * */ void nm_user_record_set_status(NMUserRecord * user_record, NMSTATUS_T status, const char *text); /** * Get the status for the user record * * @param user_record The user record * * @return The status for the user record */ NMSTATUS_T nm_user_record_get_status(NMUserRecord * user_record); /** * Get the status text for the user record * * @param user_record The user record * * @return The status text if there is any, NULL otherwise * */ const char *nm_user_record_get_status_text(NMUserRecord * user_record); /** * Set the DN for the user record * * @param user_record The user record * @param dn The new DN for the user record * */ void nm_user_record_set_dn(NMUserRecord * user_record, const char *dn); /** * Get the DN for the user record * * @param user_record The user record * * @return The DN for the user record */ const char *nm_user_record_get_dn(NMUserRecord * user_record); /** * Set the user id for the * * @param user_record The user record * @param userid The userid (CN) for the user record * */ void nm_user_record_set_userid(NMUserRecord * user_record, const char *userid); /** * Get the user id for the user record * * @param user_record The user record * * @return The user id for the user record */ const char *nm_user_record_get_userid(NMUserRecord * user_record); /** * Set the display id for the user record * * @param user_record The user record * @param display_id The new display id for the user * */ void nm_user_record_set_display_id(NMUserRecord * user_record, const char *display_id); /** * Get the display id for the user record * * @param user_record The user record * * @return The display id for the user record */ const char *nm_user_record_get_display_id(NMUserRecord * user_record); /** * Return whether or not the display id is an auth attribute or not. * * @param user_record The user record * * @return TRUE if display_id is an auth attribute, FALSE otherwise. */ gboolean nm_user_record_get_auth_attr(NMUserRecord *user_record); /** * Get the full name for the user record * * @param user_record The user record * * @return The full name for the user */ const char *nm_user_record_get_full_name(NMUserRecord * user_record); /** * Get the first name for the user record * * @param user_record The user record * * @return The first name for the user */ const char *nm_user_record_get_first_name(NMUserRecord * user_record); /** * Get the last name for the user record * * @param user_record The user record * * @return The last name for the user */ const char *nm_user_record_get_last_name(NMUserRecord * user_record); /** * Set the user defined data for the user record * * @param user_record The user record * @param data The user defined data for the user record * */ void nm_user_record_set_data(NMUserRecord * user_record, gpointer data); /** * Get the user defined data for the user record * * @param user_record The user record * * @return The user defined data for the user record */ gpointer nm_user_record_get_data(NMUserRecord * user_record); /** * Get the property count for the user record * * @param user_record The user record * * @return The number of information properties for the user record * */ int nm_user_record_get_property_count(NMUserRecord * user_record); /** * Get an info property for the user record. The property must be released * by calling nm_release_property() * * @param user_record The user record * @param index The index of the property to get (zero based) * * @return The property */ NMProperty *nm_user_record_get_property(NMUserRecord * user_record, int index); /** * Release a property object * * @param property The property * */ void nm_release_property(NMProperty * property); /** * Get the tag for the property * * @param property The property * * @return The tag of the property (i.e. "Email Address") */ const char *nm_property_get_tag(NMProperty * property); /** * Get the value for the property * * @param property The property * * @return The value of the property (i.e. "nobody@nowhere.com") */ const char *nm_property_get_value(NMProperty * property); /** * Copy a user record (deep copy). The dest user record must have already been * created (nm_create_user_record) * * @param dest The destination of the copy * @param src The source of the copy * */ void nm_user_record_copy(NMUserRecord * dest, NMUserRecord * src); #endif