3 * Pidgin is the legal property of its developers, whose names are too numerous
4 * to list here. Please refer to the COPYRIGHT file distributed with this
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
22 #ifndef PIDGIN_CONTACT_COMPLETION_H
23 #define PIDGIN_CONTACT_COMPLETION_H
26 * SECTION:pidgincontactcompletion
27 * @section_id: pidgin-contact-completion
28 * @short_description: A GtkEntryCompletion for contacts
29 * @title: Contact Name Completion
31 * #PidginContactCompletion should be treated like a normal
32 * #GtkEntryCompletion, except it already does all of the setup for the
33 * completion. You can also filter by a #PurpleAccount to limit what's shown.
35 * |[<!-- language="C" -->
36 * GtkWidget *entry = gtk_entry_new();
37 * GtkEntryCompletion *completion = pidgin_contact_completion_new();
39 * gtk_entry_set_completion(GTK_ENTRY(entry), completion);
40 * pidgin_contact_completion_set_account(PIDGIN_CONTACT_COMPLETION(completion), account);
41 * g_object_unref(completion);
51 #define PIDGIN_TYPE_CONTACT_COMPLETION pidgin_contact_completion_get_type()
53 G_DECLARE_FINAL_TYPE(PidginContactCompletion
, pidgin_contact_completion
, PIDGIN
,
54 CONTACT_COMPLETION
, GtkEntryCompletion
)
57 * pidgin_contact_completion_new:
59 * Creates a new #GtkEntryCompletion for looking up contacts.
61 * Returns: (transfer full): The new #GtkEntryCompletion instance.
65 GtkEntryCompletion
*pidgin_contact_completion_new(void);
68 * pidgin_contact_completion_get_account:
69 * @completion: The #PidginContactCompletion instance.
71 * Gets the account that @completion is filtering for. If no filtering is set
72 * %NULL will be returned.
74 * Returns: (transfer full) (nullable): The #PurpleAccount that's being
79 PurpleAccount
*pidgin_contact_completion_get_account(PidginContactCompletion
*completion
);
82 * pidgin_contact_completion_set_account:
83 * @completion: The #PidginContactCompletion instance.
84 * @account: (nullable): The #PurpleAccount to filter for or %NULL.
86 * Set the #PurpleAccount that @completion should filter for. If @account is
87 * %NULL, all filtering will be disabled.
91 void pidgin_contact_completion_set_account(PidginContactCompletion
*completion
, PurpleAccount
*account
);
95 #endif /* PIDGIN_CONTACT_COMPLETION_H */