Replace g_list_remove_link+g_list_free_1 with g_list_delete_link
[pidgin-git.git] / ChangeLog.API
blob87dfbbd9bca89f7ae12070ec1f81a7e18e7a5c7e
1 Pidgin and Finch: The Pimpin' Penguin IM Clients That're Good for the Soul
3 This file intends to list all changes to libpurple, Pidgin, and Finch's public
4 API. We sometimes forget to add changes to this file--sorry.
6 If your plugin fails to build with a new major version (e.g. 3.0.0) we
7 suggest checking this list first, in case a function was simply renamed.
8 You may still need to consult our API docs or our source code.
10 If you notice something missing from this list, please let us know and we'll
11 add it.
13 version 3.0.0 (??/??/????):
14         libpurple:
15                 Added:
16                 * displaying-emails-clear signal (notification signal)
17                 * purple_account_is_disconnecting
18                 * purple_account_get_ui_data
19                 * purple_account_set_ui_data
20                 * purple_account_privacy_get_denied
21                 * purple_account_privacy_get_permitted
22                 * PurpleAccountPresence and PurpleBuddyPresence inherit PurplePresence
23                 * purple_account_presence_new
24                 * purple_buddy_presence_new
25                 * purple_account_register_completed
26                 * purple_blist_get_default_root
27                 * purple_blist_node_is_transient
28                 * purple_blist_node_set_transient
29                 * purple_certificate_get_der_data
30                 * purple_certificate_get_display_string
31                 * purple_chat_user_get_alias
32                 * purple_chat_user_get_chat
33                 * purple_chat_user_get_flags
34                 * purple_chat_user_is_buddy
35                 * purple_chat_user_get_ui_data
36                 * purple_chat_user_set_ui_data
37                 * purple_chat_user_set_chat
38                 * purple_connection_get_active_chats
39                 * purple_connection_get_error_info
40                 * purple_connection_get_flags
41                 * purple_connection_set_flags
42                 * purple_connection_update_last_received
43                 * purple_conversation_get_ui_data
44                 * purple_conversation_set_ui_data
45                 * purple_conversation_message_get_alias
46                 * purple_conversation_message_get_conv
47                 * PurpleCountingNode, inherits PurpleBlistNode
48                 * purple_counting_node_get_*
49                 * purple_counting_node_change_*
50                 * purple_counting_node_set_*
51                 * PurpleIMConversation and PurpleChatConversation inherit
52                   PurpleConversation
53                 * purple_notify_emails_pending
54                 * purple_notify_emails_present
55                 * purple_notify_searchresult_column_get_title
56                 * purple_notify_searchresult_column_is_visible
57                 * purple_notify_searchresult_column_set_visible
58                 * purple_notify_user_info_entry_destroy
59                 * purple_notify_user_info_prepend_pair_plaintext
60                 * purple_media_manager_enumerate_elements
61                 * purple_menu_action_get_callback
62                 * purple_menu_action_get_children
63                 * purple_menu_action_get_data
64                 * purple_menu_action_set_label
65                 * purple_menu_action_set_data
66                 * purple_menu_action_set_callback
67                 * purple_menu_action_set_children
68                 * PurplePluginInfoFlags (PURPLE_PLUGIN_INFO_FLAGS_INTERNAL and
69                   PURPLE_PLUGIN_INFO_FLAGS_AUTO_LOAD)
70                 * purple_plugin_get_dependent_plugins
71                 * purple_plugin_is_internal
72                 * purple_plugin_info_new
73                 * purple_plugin_get_info
74                 * purple_plugin_info_get_actions_cb
75                 * purple_plugin_info_get_error
76                 * purple_plugin_info_get_extra_cb
77                 * purple_plugin_info_get_pref_frame_cb
78                 * purple_plugin_info_get_pref_request_cb
79                 * purple_plugin_info_get_ui_data
80                 * purple_plugin_info_set_ui_data
81                 * PurpleProtocol, inherits GObject. Please see the documentation for
82                   details.
83                 * PurpleProtocolAction
84                 * PurpleProtocolOverrideFlags
85                 * PurpleProtocolClientIface
86                 * PurpleProtocolServerIface
87                 * PurpleProtocolIMIface
88                 * PurpleProtocolChatIface
89                 * PurpleProtocolPrivacyIface
90                 * PurpleProtocolXferIface
91                 * PurpleProtocolRoomlistIface
92                 * PurpleProtocolAttentionIface
93                 * PurpleProtocolMediaIface
94                 * PurpleProtocolFactoryIface
95                 * purple_protocol_get_* for PurpleProtocol members
96                 * purple_protocol_class_* for class methods
97                 * purple_protocol_server_iface_* for server interface methods
98                 * purple_protocol_im_iface_* for IM interface methods
99                 * purple_protocol_privacy_iface_* for privacy interface methods
100                 * purple_protocol_xfer_iface_* for xfer interface methods
101                 * purple_protocol_attention_iface_* for attention interface methods
102                 * purple_protocol_factory_iface_* for factory interface methods
103                 * purple_protocol_action_new
104                 * purple_protocol_action_free
105                 * purple_protocols_add
106                 * purple_protocols_remove
107                 * purple_protocols_find
108                 * purple_protocols_get_all
109                 * purple_protocols_get_handle
110                 * purple_protocols_init
111                 * purple_protocols_uninit
112                 * purple_request_certificate
113                 * purple_request_field_certificate_new
114                 * purple_request_field_certificate_get_value
115                 * purple_request_field_get_tooltip
116                 * purple_request_field_group_get_fields_list
117                 * purple_request_field_set_tooltip
118                 * purple_request_fields_get_ui_data
119                 * purple_request_fields_set_ui_data
120                 * purple_roomlist_get_account
121                 * purple_roomlist_get_proto_data
122                 * purple_roomlist_get_ui_data
123                 * purple_roomlist_room_get_expanded_once
124                 * purple_roomlist_room_set_expanded_once
125                 * purple_roomlist_set_proto_data
126                 * purple_roomlist_set_ui_data
127                 * purple_whiteboard_get_account
128                 * purple_whiteboard_get_draw_list
129                 * purple_whiteboard_set_draw_list
130                 * purple_whiteboard_get_protocol_data
131                 * purple_whiteboard_set_protocol_data
132                 * purple_whiteboard_get_state
133                 * purple_whiteboard_set_state
134                 * purple_whiteboard_get_ui_data
135                 * purple_whiteboard_set_ui_data
136                 * purple_whiteboard_get_who
137                 * purple_xfer_get_fd
138                 * purple_xfer_get_message
139                 * purple_xfer_get_protocol_data
140                 * purple_xfer_get_ui_data
141                 * purple_xfer_get_watcher
142                 * purple_xfer_set_fd
143                 * purple_xfer_set_local_port
144                 * purple_xfer_set_protocol_data
145                 * purple_xfer_set_remote_user
146                 * purple_xfer_set_status
147                 * purple_xfer_set_ui_data
148                 * purple_xfer_set_watcher
149                 * purple_xmlnode_get_default_namespace
150                 * purple_xmlnode_strip_prefixes
152                 Changed:
153                 * account.h has been split into account.h (PurpleAccount GObject) and
154                   accounts.h (Accounts subsystem)
155                 * blist.h has been split into buddylist.h (PurpleBuddyList and
156                   subsystem), blistnode.h (PurpleBlistNode and PurpleCountingNode
157                   GObjects), blistnodetypes (Buddy, Chat, Contact, Group GObjects)
158                 * circbuffer.h renamed to circularbuffer.h
159                 * conversation.h has been split into conversation.h
160                   (PurpleConversation), conversationtypes.h (PurpleIMConversation and
161                   PurpleChatConversation) and conversations.h (Conversations subsystem)
162                 * Renamed ft.h file to xfer.h
163                 * Renamed plugin.h file to plugins.h
164                 * prpl.h has been split into protocol.h (PurpleProtocol GObject and
165                   protocol interfaces) and protocols.h (protocols subsystem)
166                 * status.h has been split into status.h (Status API) and presence.h
167                   (Presence API)
168                 * account-authorization-requested signal merged with
169                   account-authorization-requested-with-message signal
170                 * purple_account_add_buddy now takes an invite message as the last
171                   parameter
172                 * purple_account_add_buddies now takes an invite message as the last
173                   parameter
174                 * PurpleAccount is now a GObject. Please see the documentation for
175                   details.
176                 * purple_account_get_alias renamed to purple_account_get_private_alias
177                 * purple_account_set_alias renamed to purple_account_set_private_alias
178                 * purple_account_option_get_type renamed to
179                   purple_account_option_get_pref_type
180                 * PurplePrivacyType renamed to PurpleAccountPrivacyType
181                 * purple_privacy_* functions are now purple_account_privacy_*
182                 * Removed arguments local and restore from purple_account_privacy_allow
183                   and purple_account_privacy_deny
184                 * PurpleBlistNode is now a GObject. Please see the documentation for
185                   details.
186                 * purple_blist_alias_buddy renamed to purple_buddy_set_local_alias
187                 * purple_blist_alias_chat renamed to purple_chat_set_alias
188                 * purple_blist_alias_contact renamed to purple_contact_set_alias
189                 * purple_blist_get_root now takes a PurpleBuddyList parameter;
190                   use purple_blist_get_default_root to work on the default buddy
191                   list as before
192                 * purple_blist_merge_contact renamed to purple_contact_merge
193                 * purple_blist_rename_buddy renamed to purple_buddy_set_name
194                 * purple_blist_rename_group renamed to purple_group_set_name
195                 * purple_blist_server_alias_buddy renamed to
196                 * purple_blist_update_buddy_status renamed to purple_buddy_update_status
197                   purple_buddy_set_server_alias
198                 * purple_buddy_get_local_buddy_alias renamed to
199                   purple_buddy_get_local_alias
200                 * PurpleContact and PurpleGroup inherit PurpleCountingNode
201                 * PurpleBuddyList is now a GObject. Please see the documentation for
202                   details.
203                 * purple_find_buddies renamed to purple_blist_find_buddies
204                 * purple_find_buddy_in_group renamed to purple_blist_find_buddy_in_group
205                 * purple_find_buddy renamed to purple_blist_find_buddy
206                 * purple_find_group renamed to purple_blist_find_group
207                 * purple_get_blist renamed to purple_blist_get_default
208                 * PurpleBuddyIconSpec has been moved to buddyicon.h
209                 * purple_certificate_check_signature_chain now returns a list of failing
210                   PurpleCertificate*s as the second parameter
211                 * PurpleConversation is now an abstract type, and is a GObject. Please
212                   see the documentation for details.
213                 * purple_conv_* functions are now purple_conversation_*
214                 * purple_conv_im_* functions are now purple_im_conversation_*
215                 * purple_conv_chat_* functions are now purple_chat_conversation_*
216                 * purple_chat_conversation_find_user renamed to
217                   purple_chat_conversation_has_user
218                 * PurpleTypingState renamed to PurpleIMTypingState
219                 * PurpleConvChatBuddy changed to PurpleChatUser, is now a GObject.
220                   Please see the documentation for details.
221                 * purple_conv_chat_cb_* functions are now purple_chat_user_*
222                 * Replaced 'chat-buddy' with 'chat-user' in conversation signals
223                 * Replaced chatname, buddyname arguments of 'chat-user-flags' (formerly
224                   'chat-buddy-flags') signal with PurpleChatUser *
225                 * PurpleCircBuffer changed to PurpleCircularBuffer, is now a GObject.
226                   Please see the documentation for details.
227                 * purple_circ_buffer_* functions are now purple_circular_buffer_*
228                 * purple_connection_error now takes a PurpleConnectionError
229                   as the second parameter
230                 * PurpleConnection is now a GObject. Please see the documentation for
231                   details.
232                 * PURPLE_CONNECTION_* prefix of PurpleConnectionFlag enum names changed
233                   to PURPLE_CONNECTION_FLAG_*
234                 * PURPLE_* prefix of PurpleConnectionState enum names changed to
235                   PURPLE_CONNECTION_*
236                 * purple_conversation_get_gc renamed to
237                   purple_conversation_get_connection
238                 * purple_dnsquery_a now takes a PurpleAccount as the first parameter
239                 * PurpleIconScaleRules renamed to PurpleBuddyIconScaleFlags
240                 * purple_imgstore_add renamed to purple_imgstore_new
241                 * purple_imgstore_add_with_id renamed to purple_imgstore_new_with_id
242                 * PurpleLog, purple_log_new, purple_log_write and
243                   PurpleLogLogger->write take a GDateTime instead of a time_t
244                   and struct tm
245                 * purple_network_listen now takes the protocol family as the second
246                   parameter
247                 * purple_network_listen now takes a boolean indicating external port
248                   mapping as the fourth parameter
249                 * purple_network_listen_range now takes a boolean indicating external
250                   port mapping as the fifth parameter
251                 * purple_network_listen_range now takes the protocol family as the
252                   third parameter
253                 * PurpleNotifyMsgType renamed to PurpleNotifyMessageType
254                 * purple_notify_user_info_add_pair renamed to
255                   purple_notify_user_info_add_pair_html
256                 * purple_notify_user_info_get_entries returns a GQueue instead of
257                   a GList
258                 * purple_notify_user_info_entry_get_type renamed to
259                   purple_notify_user_info_entry_get_entry_type
260                 * purple_notify_user_info_entry_set_type renamed to
261                   purple_notify_user_info_entry_set_entry_type
262                 * purple_notify_user_info_prepend_pair renamed to
263                   purple_notify_user_info_prepend_pair_html
264                 * PurplePlugin is now a GObject (alias for GPluginPlugin). Please see
265                   the documentation for details.
266                 * PurplePluginInfo is now a GObject, inherits GPluginPluginInfo. Please
267                   see the documentation for details.
268                 * PurplePluginAction no longer has a context field. Use
269                   PurpleProtocolAction for protocol actions.
270                 * PURPLE_INIT_PLUGIN(pluginname, initfunc, plugininfo) is now
271                   PURPLE_PLUGIN_INIT(pluginname, query_func, load_func, unload_func).
272                   See "C Plugins tutorial" (tut_c_plugins.xml) for an example.
273                 * purple_plugin_load and purple_plugin_unload now use an error argument
274                   to return load/unload errors
275                 * purple_plugins_get_all is now purple_plugins_find_all, and the
276                   returned list of plugins MUST be free'd using g_list_free
277                 * purple_plugin_get_* functions for plugin info are now
278                   purple_plugin_info_get_*
279                 * purple_plugin_get_author is now purple_plugin_info_get_authors, and
280                   returns a NULL-terminated list of authors
281                 * purple_plugins_probe is now purple_plugins_refresh
282                 * purple_plugins_find_with_id renamed to purple_plugins_find_plugin
283                 * purple_plugins_find_with_filename renamed to
284                   purple_plugins_find_by_filename
285                 * purple_plugin_pref_get_type renamed to
286                   purple_plugin_pref_get_pref_type
287                 * purple_plugin_pref_set_type renamed to
288                   purple_plugin_pref_set_pref_type
289                 * purple_prefs_get_type renamed to purple_prefs_get_pref_type
290                 * proto_chat_entry has been renamed to PurpleProtocolChatEntry
291                 * purple_proxy_info_get_type renamed to purple_proxy_info_get_proxy_type
292                 * purple_proxy_info_set_type renamed to purple_proxy_info_set_proxy_type
293                 * purple_request_field_get_type renamed to
294                   purple_request_field_get_field_type
295                 * PurpleRoomlist is now a GObject. Please see the documentation for
296                   details.
297                 * purple_roomlist_room_get_type is now
298                   purple_roomlist_room_get_room_type
299                 * purple_roomlist_field_get_type is now
300                   purple_roomlist_field_get_field_type
301                 * purple_savedstatus_get_type renamed to
302                   purple_savedstatus_get_primitive_type
303                 * purple_savedstatus_set_type renamed to
304                   purple_savedstatus_set_primitive_type
305                 * purple_savedstatus_substatus_get_type renamed to
306                   purple_savedstatus_substatus_get_status_type
307                 * serv_* functions are now purple_serv_*
308                 * purple_srv_resolve now takes a PurpleAccount as the first parameter
309                 * purple_srv_txt_query_get_type renamed to
310                   purple_srv_txt_query_get_query_type
311                 * PurpleStatus is now a GObject. Please see the documentation for
312                   details.
313                 * purple_status_attr_* functions are now purple_status_attribute_*
314                 * PurpleStatusAttr renamed to PurpleStatusAttribute
315                 * PurplePresence is now an abstract type, and is a GObject. Please see
316                   the documentation for details.
317                 * update_idle method has been added to PurplePresenceClass to update the
318                   idle state of a presence
319                 * StunCallback renamed to PurpleStunCallback
320                 * purple_str_size_to_units now takes a goffset as the size parameter
321                 * PTFunc renamed to PurpleThemeFunc
322                 * purple_txt_resolve now takes a PurpleAccount as the first parameter
323                 * UPnPMappingAddRemove renamed to PurpleUPnPMappingAddRemove
324                 * purple_util_fetch_url_request now takes a PurpleAccount as
325                   the first parameter
326                 * purple_util_fetch_url_request now takes a length as the eighth
327                   parameter
328                 * purple_util_fetch_url_len now takes a length as the fifth parameter
329                 * PurpleWhiteboard is now a GObject. Please see the documentation for
330                   details.
331                 * purple_value_destroy is now purple_value_free
332                 * purple_value_new, purple_value_dup and purple_value_free now operate
333                   on GValue instead of PurpleValue
334                 * Signal registration now uses GTypes instead of PurpleValues.  See
335                   SIGNAL-HOWTO for more information.
336                 * purple_whiteboard_create renamed to purple_whiteboard_new
337                 * purple_xfer_get_bytes_remaining now returns a goffset
338                 * purple_xfer_get_bytes_sent now returns a goffset
339                 * purple_xfer_get_size now returns a goffset
340                 * purple_xfer_is_canceled renamed to purple_xfer_is_cancelled
341                 * PurpleXfer is now a GObject. Please see the documentation for details.
342                 * purple_xfer_get_type renamed to purple_xfer_get_xfer_type
343                 * PurpleXferStatusType renamed to PurpleXferStatus
344                 * PURPLE_XFER_* prefix of PurpleXferType enums changed to
345                   PURPLE_XFER_TYPE_*
346                 * purple_xfer_set_bytes_sent now takes a goffset as the bytes_sent
347                   parameter
348                 * purple_xfer_set_size now takes a goffset as the size parameter
349                 * PurpleCertificateVerificationStatus enumeration is now merged with
350                   internal flags, thus removing PURPLE_CERTIFICATE_INVALID and
351                   replacing it with more precise errors.
352                 * PurpleConnectionUiOps.report_disconnect now passes a
353                   PurpleConnectionError as the second parameter
354                 * PurpleXfer.bytes_remaining is now a goffset
355                 * PurpleXfer.bytes_sent is now a goffset
356                 * PurpleXfer.size is now a goffset
357                 * PurpleCertificateScheme.get_times now uses gint64 instead of
358                   time_t to represent times
359                 * purple_certificate_get_times now uses gint64 instead of
360                   time_t to represent times
361                 * xmlnode renamed to PurpleXmlNode
362                 * XMLNodeType renamed to PurpleXmlNodeType
363                 * xmlnode_* functions are now purple_xmlnode_*
365                 Removed:
366                 * buddy-added and buddy-removed blist signals
367                 * privacy.h file
368                 * value.h file
369                 * _PurpleCmdFlag
370                 * _PurpleCmdPriority
371                 * _PurpleCmdRet
372                 * _PurpleCmdStatus
373                 * _PurplePrefType
374                 * _PurplePrivacyType
375                 * _PurpleSoundEventID
376                 * _XMLNodeType
377                 * account-authorization-requested-with-message signal
378                 * network-configuration-changed signal
379                 * PurpleAccoun->ui_data
380                 * purple_account_add_buddies_with_invite
381                 * purple_account_add_buddy_with_invite
382                 * purple_account_get_ui_data
383                 * purple_account_set_current_error
384                 * purple_account_set_ui_data
385                 * purple_base64_*. Use g_base64_* instead
386                 * purple_blist_get_ui_data
387                 * purple_blist_load
388                 * purple_blist_new
389                 * purple_blist_set_ui_data
390                 * purple_set_blist
391                 * purple_blist_update_buddy_icon
392                 * purple_buddy_get_local_alias
393                 * purple_buddy_icons_has_custom_icon
394                 * purple_buddy_icons_find_custom_icon
395                 * purple_buddy_icons_set_custom_icon
396                 * purple_certificate_check_signature_chain_with_failing. Use
397                   purple_certificate_check_signature_chain, instead
398                 * purple_certificate_display_x509. Use purple_request_certificate,
399                   instead
400                 * Purple Cipher API (PurpleCipherContext and friends).
401                   Use GLib's GHmac or GChecksum instead.
402                 * purple_connection_error_reason
403                 * purple_connection_new
404                 * purple_connection_new_unregister
405                 * purple_connection_destroy
406                 * purple_connection_set_account
407                 * purple_contact_set_alias
408                 * purple_conv_chat_set_users
409                 * PurpleConversationType
410                 * purple_core_ensure_single_instance. Check via GApplication
411                   or whatever is appropriate for your UI.
412                 * purple_core_migrate
413                 * Removed the general Purple DBus interface
414                 * purple_dnsquery_a_account
415                 * purple_event_loop_{get|set}_ui_ops. Manually drive the GLib
416                   event loop yourself. See GLib Main Event Loop docs.
417                 * PurpleEventLoopUiOps. Manually drive the GLib event loop
418                   yourself. See GLib Main Event Loop docs.
419                 * purple_get_tzoff_str(). Use g_date_time_format, instead.
420                 * purple_ip_address_is_valid, purple_ipv4_address_is_valid, and
421                   purple_ipv6_address_is_valid. Use g_hostname_is_ip_address()
422                   or #GInetAddress instead.
423                 * PurpleMimeDocument, PurpleMimePart,
424                   purple_mime_document_new, purple_mime_document_free,
425                   purple_mime_document_parse, purple_mime_document_parsen,
426                   purple_mime_document_write, purple_mime_document_get_fields,
427                   purple_mime_document_get_field,
428                   purple_mime_document_set_field,
429                   purple_mime_document_get_parts, purple_mime_part_new,
430                   purple_mime_part_get_fields, purple_mime_part_get_field,
431                   purple_mime_part_get_field_decoded,
432                   purple_mime_part_set_field, purple_mime_part_get_data,
433                   purple_mime_part_get_data_decoded,
434                   purple_mime_part_get_length, purple_mime_part_set_data, and
435                   purple_mime_decode_field. Use the GMime library, instead.
436                 * purple_network_convert_idn_to_ascii. Use g_hostname_to_ascii,
437                   instead.
438                 * purple_network_listen_family. Use purple_network_listen, instead.
439                 * purple_network_listen_map_external
440                 * purple_network_listen_range_family. Use purple_network_listen,
441                   instead.
442                 * purple_network_ip_atoi
443                 * purple_notify_searchresults_column_get_title
444                 * purple_notify_searchresults_get_columns_count
445                 * purple_notify_searchresults_get_rows_count
446                 * purple_notify_searchresults_row_get
447                 * purple_ntlm_*
448                 * PurplePluginType
449                 * PurplePluginPriority
450                 * PurplePluginLoaderInfo
451                 * PurplePluginUiInfo
452                 * purple_plugin_ipc_*
453                 * purple_plugin_is_unloadable
454                 * purple_plugin_new
455                 * purple_plugin_probe
456                 * purple_plugin_register
457                 * purple_plugin_reload
458                 * purple_plugins_destroy_all
459                 * purple_plugins_enabled
460                 * purple_plugins_find_with_basename
461                 * purple_plugins_find_with_name
462                 * purple_plugins_get_protocols
463                 * purple_plugins_get_search_paths
464                 * purple_plugins_register_load_notify_cb
465                 * purple_plugins_register_probe_notify_cb
466                 * purple_plugins_register_unload_notify_cb
467                 * purple_plugins_unregister_load_notify_cb
468                 * purple_plugins_unregister_probe_notify_cb
469                 * purple_plugins_unregister_unload_notify_cb
470                 * purple_plugins_unload
471                 * purple_plugins_unload_all
472                 * purple_pounces_load
473                 * purple_prefs_set_generic
474                 * purple_prefs_update_old
475                 * purple_presence_add_status
476                 * purple_presence_add_list
477                 * PurplePresenceContext
478                 * purple_presence_new
479                 * purple_presence_new_for_account
480                 * purple_presence_new_for_buddy
481                 * purple_print_utf8_to_console
482                 * PurplePluginProtocolInfo
483                 * purple_proxy_connect_socks5
484                 * purple_quotedp_decode. See the GMime library if needed.
485                 * purple_request_field_list_add
486                 * purple_srv_cancel
487                 * purple_srv_resolve_account
488                 * purple_ssl_connect_fd
489                 * purple_status_set_attr_boolean
490                 * purple_status_set_attr_int
491                 * purple_status_set_attr_string
492                 * purple_status_type_add_attr
493                 * purple_status_type_add_attrs
494                 * purple_status_type_add_attrs_vargs
495                 * purple_status_type_get_primary_attr
496                 * purple_status_type_set_primary_attr
497                 * purple_strlcat
498                 * purple_strlcpy
499                 * purple_str_size_to_units. Use g_format_size() instead.
500                 * purple_timeout_*. Use g_timeout_* or g_idle_* instead.
501                 * purple_txt_cancel
502                 * purple_txt_resolve_account
503                 * PurpleType, use GType instead.
504                 * purple_util_fetch_url_len. Use purple_util_fetch_url, instead.
505                 * purple_util_fetch_url_request_len. Use
506                 * purple_util_fetch_url_request, instead.
507                 * purple_util_fetch_url_request_len_with_account.  Use
508                   purple_util_fetch_url_request, instead.
509                 * purple_util_get_image_checksum.  Use
510                   g_compute_checksum_for_data(G_CHECKSUM_SHA1, ...), instead.
511                 * PurpleCertificateVerificationStatus.PURPLE_CERTIFICATE_INVALID
512                 * PurpleConnectionUiOps.report_disconnect_reason
513                 * PurplePluginProtocolInfo.add_buddy_with_invite
514                 * PurplePluginProtocolInfo.add_buddies_with_invite
515                 * PurplePluginProtocolInfo.get_cb_away
516                 * PurpleValue, use GValue instead.
517                 * serv_got_attention
518                 * serv_send_attention
519                 * struct _PurpleAttentionType
520                 * struct _PurpleCipherCaps
521                 * struct _PurpleConversation
522                 * struct _PurpleConvChat
523                 * struct _PurpleConvChatBuddy
524                 * struct _PurpleConvIm
525                 * struct _PurpleConvMessage
526                 * struct _PurpleMenuAction
527                 * struct _PurplePounce
528                 * struct _PurpleProxyInfo
529                 * struct _PurpleRequestField
530                 * struct _PurpleRoomlist
531                 * struct _PurpleRoomlistField
532                 * struct _PurpleRoomlistRoom
533                 * struct _PurpleWhiteboard
534                 * struct PurpleAccountOption
535                 * struct PurpleAccountUserSplit
536                 * struct PurpleNotifySearchColumn
537                 * wpurple_g_access
538                 * xmlnode_set_attrib_with_namespace
539                 * xmlnode_set_attrib_with_prefix
541                 Deprecated:
542                 * purple_user_dir
543                 * purple_util_write_data_to_file
544                 * purple_util_read_xml_from_file
546         Pidgin:
547                 Added:
548                 * pidgin_create_webview
549                 * PidginDockletFlag
550                 * pidgin_gdk_pixbuf_new_from_image
551                 * PidginPluginInfo, inherits PurplePluginInfo
552                 * Various WebKit-related functions in gtkwebview.h
554                 Changed:
555                 * gtkft.h file renamed to gtkxfer.h
556                 * pidgin_blist_sort_method renamed to _PidginBlistSortMethod
557                 * BRUSH_STATE_DOWN renamed to PIDGIN_BRUSH_STATE_DOWN
558                 * BRUSH_STATE_MOTION renamed to PIDGIN_BRUSH_STATE_MOTION
559                 * BRUSH_STATE_UP renamed to PIDGIN_BRUSH_STATE_UP
560                 * DEFAULT_FONT_FACE renamed to PIDGIN_DEFAULT_FONT_FACE
561                 * DndHintPosition renamed to PidginDndHintPosition
562                 * DndHintWindowId renamed to PidginDndHintWindowId
563                 * dnd_* functions renamed to pidgin_dnd_*
564                 * FULL_CIRCLE_DEGREES renamed to PIDGIN_FULL_CIRCLE_DEGREES
565                 * NUM_NICK_SEED_COLORS renamed to PIDGIN_NUM_NICK_SEED_COLORS
566                 * PALETTE_NUM_COLORS renamed to PIDGIN_PALETTE_NUM_COLORS
567                 * pidgin_account_option_menu_* renamed to
568                   pidgin_account_chooser_*
569                 * pidgin_new_item_from_stock renamed to pidgin_new_menu_item and
570                   removed the accel related parameters.
571                 * pidgin_setup_screenname_autocomplete now takes a filter function and
572                   its data as final two arguments
573                 * smiley_list renamed to PidginSmileyList
574                 * smiley_parse_markup renamed to pidgin_smiley_parse_markup
575                 * smiley_theme renamed to PidginSmileyTheme
576                 * PidginWindow renamed to PidginConvWindow
578                 Removed:
579                 * GtkIMHtml.clipboard_html_string
580                 * GtkIMHtml.clipboard_text_string
581                 * GtkIMHtmlFontDetail
582                 * gtk_imhtml_animation_free
583                 * gtk_imhtml_animation_new
584                 * gtk_imhtml_image_add_to
585                 * gtk_imhtml_image_free
586                 * gtk_imhtml_image_new
587                 * gtk_imhtml_image_scale
588                 * pidgin_blist_update_account_error_state
589                 * PidginBuddyList.connection_errors
590                 * pidgin_check_if_dir
591                 * PidginConversation.sg
592                 * PIDGIN_DIALOG
593                 * pidgin_dialogs_alias_contact
594                 * pidgin_make_pretty_arrows
595                 * pidgin_mini_dialog_links_supported
596                 * pidgin_set_custom_buddy_icon
597                 * pidgin_setup_screenname_autocomplete_with_filter
598                 * pidgin_toggle_sensitive, pidgin_toggle_sensitive_array, and
599                 pidgin_toggle_showhide; use g_object_bind_property instead
600                 * struct _GtkIMHtmlAnimation
601                 * struct _GtkIMHtmlFontDetail
602                 * struct _GtkIMHtmlHr
603                 * struct _GtkIMHtmlImage
604                 * struct _GtkIMHtmlScalable
605                 * struct _GtkSmileyTree
606                 * struct _PidginChatPane
607                 * struct _PidginImPane
609         Finch:
610                 Added:
611                 * FinchPluginInfo, inherits PurplePluginInfo
613                 Changed:
614                 * gntft.h file renamed to gntxfer.h
615                 * gnt_append_menu_action renamed to finch_append_menu_action
616                 * gnt_ui_init renamed to finch_ui_init
617                 * gnt_ui_uninit renamed to finch_ui_uninit
619         libgnt:
620                 Changed:
621                 * ENTRY_CHAR renamed to GNT_ENTRY_CHAR
622                 * g_hash_table_duplicate renamed to gnt_hash_table_duplicate
623                 * GDupFunc renamed to GntDuplicateFunc
625                 Removed:
626                 * _GntFileType
627                 * _GntKeyPressMode
628                 * _GntMouseEvent
629                 * _GntParamFlags
630                 * _GntProgressBarOrientation
631                 * _GntTreeColumnFlag
632                 * _GntWidgetFlags
634 version 2.13.0:
635         libpurple:
636                 Added:
637                 * purple_uri_escape_for_open
639 version 2.12.0:
640         libpurple:
641                 Added:
642                 * PURPLE_MESSAGE_REMOTE_SEND in PurpleMessageFlags, to specify
643                 messages like _SEND that were sent from another location.
644                 * purple_certificate_get_fingerprint_sha256
645                 * purple_certificate_compare_pubkeys
646                 * PurpleCertificateScheme.get_fingerprint_sha256
647                 * PurpleCertificateScheme.compare_pubkeys
648                 * PURPLE_CERTIFICATE_SCHEME_HAS_FUNC
650 version 2.11.0:
651         libpurple:
652                 Added:
653                 * account-status-changing signal (account signals)
654                 * buddy-removed-from-group signal (blist signals)
655                 * PurpleCommandsUiOps, to allow the UI to override the
656                   built-in handling of commands.
657                 * PurplePrefsUiOps, to allow the UI to override the way global
658                   preferences are stored.
659                 * PurpleAccountPrefsUiOps, to allow the UI to handle storage
660                   of account preferences.
661                 * purple_media_set_encryption_parameters
662                 * purple_media_set_decryption_parameters
663                 * purple_xfer_write_file
664                 * purple_xfer_read_file
665                 * purple_media_set_send_rtcp_mux
666                 * purple_media_backend_set_send_rtcp_mux
668 version 2.10.12:
669         * No changes
671 version 2.10.11:
672         * No changes
674 version 2.10.10:
675         * No changes
677 version 2.10.9:
678         * No changes
680 version 2.10.8:
681         * No changes
683 version 2.10.7:
684         * No changes
686 version 2.10.6:
687         * No changes
689 version 2.10.5:
690         * No changes
692 version 2.10.4:
693         * No changes
695 version 2.10.3:
696         * No changes
698 version 2.10.2:
699         * No changes
701 version 2.10.1:
702         * No changes
704 version 2.10.0:
705         libpurple:
706                 Added:
707                 * purple_srv_txt_query_destroy (accidentally left out of 2.8.0)
709         Pidgin:
710                 Added:
711                 * pidgin_dialogs_plugins_info (should not be used by anything but Pidgin)
713 version 2.9.0:
714         libpurple:
715                 Added:
716                 * Hash table to PurpleConvChat struct, used to make
717                   purple_conv_chat_cb_find O(1).
718                 * ui_data pointer to PurpleConvChatBuddy struct.
719                 * deleting-chat-buddy signal (conversation signals)
720                 * pidgin_pixbuf_from_data
721                 * pidgin_pixbuf_anim_from_data
722                 * pidgin_pixbuf_new_from_file
723                 * pidgin_pixbuf_new_from_file_at_size
724                 * pidgin_pixbuf_new_from_file_at_scale
726                 Deprecated:
727                 * purple_conv_chat_set_users
728                 * PurpleConvChat in_room list
730 version 2.8.0 (06/07/2011):
731         libpurple:
732                 Added:
733                 * account-authorization-requested-with-message signal (Stefan Ott)
734                   (#8690)
735                 * cleared-message-history signal (conversation signals)
736                 * purple_account_add_buddy_with_invite
737                 * purple_account_add_buddies_with_invite
738                 * purple_dnsquery_a_account
739                 * purple_notify_user_info_add_pair_plaintext
740                 * purple_media_get_active_local_candidates
741                 * purple_media_get_active_remote_candidates
742                 * purple_media_manager_get_video_caps (Jakub Adam) (#13095)
743                 * purple_media_manager_set_video_caps (Jakub Adam) (#13095)
744                 * purple_pounce_destroy_all_by_buddy (Kartik Mohta) (#1131)
745                 * purple_proxy_connect_socks5_account
746                 * purple_srv_resolve_account
747                 * purple_txt_resolve_account
748                 * Added add_buddy_with_invite to PurplePluginProtocolInfo
749                 * Added add_buddies_with_invite to PurplePluginProtocolInfo
750                 * Added PurpleSrvTxtQueryUiOps which allow UIs to specify their
751                   own mechanisms to resolve SRV and/or TXT queries. It works
752                   similar to PurpleDnsQueryUiOps
753                 * purple_marshal_BOOLEAN__POINTER_BOOLEAN (kawaii.neko) (#12599)
755                 Deprecated:
756                 * purple_account_add_buddy
757                 * purple_account_add_buddies_with_invite
758                 * purple_dnsquery_a
759                 * purple_proxy_connect_socks5
760                 * purple_srv_resolve
761                 * purple_txt_resolve
762                 * add_buddy from PurplePluginProtocolInfo struct
763                 * add_buddies from PurplePluginProtocolInfo struct
765         Pidgin:
766                 Added:
767                 * pidgin_make_scrollable (Gabriel Schulhof) (#10599)
768                 * chat-nick-clicked signal (kawaii.neko) (#12599)
769                 * chat-nick-autocomplete signal (kawaii.neko) (#12599)
771 version 2.7.11 (03/10/2011):
772         * libpurple:
773                 Added:
774                 * Four entries in the GHashTable passed when joining
775                   an XMPP chat room which allow the UI to request a limited
776                   amount of history.  See XEP-0045 7.1.16 for details; the
777                   entries are named history_maxchars, history_maxstanzas,
778                   history_seconds, and history_since.  history_since must be
779                   interpretable by purple_str_to_time, and the prpl takes care
780                   of formatting the time properly.
781         * Perl:
782                 Added:
783                 * Purple::find_conversation_with_account
784                 * Purple::Conversation::Chat::send_with_flags
785                 * Purple::Conversation::IM::send_with_flags
787 version 2.7.10 (02/06/2011):
788         * No changes
790 version 2.7.9 (12/26/2010):
791         * No changes
793 version 2.7.8 (12/19/2010):
794         * No changes
796 version 2.7.7 (11/23/2010):
797         * No changes
799 version 2.7.6 (11/21/2010):
800         * No changes
802 version 2.7.5 (10/31/2010):
803         * No changes
805 version 2.7.4 (10/20/2010):
806         Perl:
807                 Added:
808                 * Purple::BuddyList::Chat::get_components
810                 Changed:
811                 * Purple::BuddyList::Chat::new now works properly.  Thanks
812                   to Rafael in devel@conference.pidgin.im for reporting and
813                   testing.
815 version 2.7.3 (08/10/2010):
816         libpurple:
817                 Fixed:
818                 * purple_account_[gs]et_public_alias no longer crash when
819                   called for a protocol that doesn't support the underlying
820                   calls and the caller does not specify a failure callback.
822         Perl:
823                 Added:
824                 * Exposed log-subsystem signals.
826         Pidgin:
827                 Changed:
828                 * Changing the visibility (gtk_widget_hide/show) of
829                   the widgets in the GtkIMHtmlToolbar should now affect
830                   the visibility of the entries in the 'lean' view
831                   (the default toolbar view).
833                 Deprecated:
834                 * pidgin_check_if_dir
836         libgnt:
837                 Added:
838                 * gnt_tree_row_get_key, gnt_tree_row_get_next,
839                   gnt_tree_row_get_prev, gnt_tree_row_get_child and
840                   gnt_tree_row_get_parent.
842 version 2.7.2 (07/21/2010):
843         * No changes
845 version 2.7.1 (05/29/2010):
846         * No changes
848 version 2.7.0 (05/12/2010):
849         libpurple:
850                 Added:
851                 * Account signals (see account-signals.dox); useful for D-Bus
852                    * account-signed-on
853                    * account-signed-off
854                    * account-connection-error
855                 * purple_account_get_name_for_display
856                 * purple_account_get_privacy_type
857                 * purple_account_get_public_alias
858                 * purple_account_set_privacy_type
859                 * purple_account_set_public_alias
860                 * buddy-caps-changed blist signal
861                 * Added media_caps to the PurpleBuddy struct
862                 * purple_buddy_get_media_caps
863                 * purple_buddy_set_media_caps
864                 * purple_certificates_import for importing multiple
865                   certificates from a single file (and corresponding
866                   import_certificates member of PurpleCertificateScheme struct)
867                 * autojoin connection signal
868                 * purple_contact_get_group
869                 * sent-attention conversation signal
870                 * got-attention conversation signal
871                 * ui-caps-changed media manager signal
872                 * purple_media_candidate_copy
873                 * purple_media_codec_copy
874                 * purple_media_manager_get_backend_type
875                 * purple_media_manager_set_backend_type
876                 * PurpleMood struct in status.h
877                 * purple_network_get_all_local_system_ips, which returns all
878                   local IPs on the system.  On systems with the getifaddrs()
879                   function, this will return both IPv4 and IPv6 addresses
880                   (excluding link-local and loopback addresses).  On others,
881                   it returns just IPv4 addresses.
882                 * purple_network_listen_family and
883                   purple_network_listen_range_family.  These will replace the
884                   versions without _family in 3.0.0 and allow the caller to
885                   specifically request either an IPv4 or IPv6 socket.  IPv6 is
886                   only supported if the getaddrinfo() function is available
887                   at build-time (not the case on Windows, currently).
888                 * purple_prpl_got_media_caps
889                 * purple_request_action_with_icon
890                 * purple_request_action_with_icon_varg
891                 * purple_socket_get_family
892                 * purple_socket_speaks_ipv4
893                 * purple_unescape_text
894                 * purple_uuid_random
895                 * purple_xfer_get_thumbnail
896                 * purple_xfer_get_thumbnail_mimetype
897                 * purple_xfer_set_thumbnail
898                 * purple_xfer_prepare_thumbnail
900         Pidgin:
901                 Added:
902                 * pidgin_dialogs_buildinfo (should not be used by anything but Pidgin)
903                 * pidgin_dialogs_developers (should not be used by anything but Pidgin)
904                 * pidgin_dialogs_translators (should not be used by anything but Pidgin)
905                 * gtk_imhtmltoolbar_switch_active_conversation
906                 * 'paste' signal for GtkIMHtml (more in gtkimhtml-signals.dox)
907                 * 'drawing-buddy' signal for gtkblist (more in gtkblist-signals.dox)
909 version 2.6.6 (02/18/2010):
910         libpurple:
911                 Changed:
912                 * purple_xfer_cancel_local is now called instead of
913                   purple_xfer_request_denied if an error is found when selecting
914                   a file to send. Request denied is still used when a receive
915                   request is not allowed.
916                 * xmlnode_from_str now properly handles parsing an attribute which
917                   contain "<br>", which were previously transformed into a
918                   newline character (libxml2 unescapes all entities except
919                   representations of '&', and libpurple's purple_unescape_html
920                   converts "<br>" to a newline).
922         Perl:
923                 Changed:
924                 * Corrected the package names for the PurpleProxyType and
925                   PurpleLogReadFlags enums to have the correct number of colons
926                   (from Purple::ProxyType::::<type> to Purple::ProxyType::<type>
927                   and Purple::Log:ReadFlags::::<type> to
928                   Purple::Log::ReadFlags::<type>)  (Chris Foote)
930 version 2.6.5 (01/08/2010):
931         No changes
933 version 2.6.4 (11/29/2009):
934         No changes
936 version 2.6.3 (10/16/2009):
937         No changes
939 version 2.6.2 (09/05/2009):
940         Perl:
941                 Added:
942                 * Purple::XMLNode::get_next(), which returns the next neighbor tag of
943                   the current node.
944                 Changed:
945                 * Purple::XMLNode::get_child() will return the first child node if
946                   passed "" or undef as the name of the node.
948 version 2.6.1 (08/18/2009):
949         No changes
951 version 2.6.0 (08/18/2009):
952         libpurple:
953                 Added:
954                 * PurpleMedia and PurpleMediaManager API
955                 * PURPLE_BLIST_NODE
956                 * PURPLE_GROUP
957                 * PURPLE_CONTACT
958                 * PURPLE_BUDDY
959                 * PURPLE_CHAT
960                 * Account signals (see account-signals.dox)
961                         * account-actions-changed
962                         * account-created
963                         * account-destroying
964                 * blist-node-added and blist-node-removed signals (see
965                   blist-signals.dox)
966                 * Three Blist UI ops used to overload libpurple's built-in saving
967                   of the buddy list to blist.xml. If a UI implements these, it probably
968                   wants to add the buddies itself and not call purple_blist_load.
969                 * Three File Transfer UI ops used to overload libpurple's use of fread
970                   and fwrite for saving a file locally. These allow a UI to stream a
971                   file through a socket without buffering the file on the local disk.
972                 * Jabber plugin signals (see jabber-signals.dox)
973                 * purple_account_remove_setting
974                 * purple_buddy_destroy
975                 * purple_buddy_get_protocol_data
976                 * purple_buddy_set_protocol_data
977                 * purple_buddy_get_local_buddy_alias
978                 * purple_blist_get_buddies
979                 * purple_blist_get_ui_data
980                 * purple_blist_set_ui_data
981                 * purple_blist_node_get_ui_data
982                 * purple_blist_node_set_ui_data
983                 * purple_certificate_check_signature_chain_with_failing
984                 * purple_chat_destroy
985                 * purple_connection_get_protocol_data
986                 * purple_connection_set_protocol_data
987                 * purple_contact_destroy
988                 * purple_conv_chat_invite_user
989                 * purple_debug_is_unsafe
990                 * purple_debug_is_verbose
991                 * purple_debug_set_unsafe
992                 * purple_debug_set_verbose
993                 * purple_global_proxy_set_info
994                 * purple_group_destroy
995                 * purple_ipv4_address_is_valid
996                 * purple_ipv6_address_is_valid
997                 * purple_log_get_activity_score
998                 * purple_markup_is_rtl
999                 * purple_markup_escape_text
1000                 * purple_network_convert_idn_to_ascii
1001                 * purple_network_force_online
1002                 * purple_network_set_stun_server
1003                 * purple_network_set_turn_server
1004                 * purple_network_get_stun_ip
1005                 * purple_network_get_turn_ip
1006                 * purple_network_remove_port_mapping
1007                 * purple_plugins_get_search_paths
1008                 * purple_proxy_connect_udp
1009                 * purple_prpl_get_media_caps
1010                 * purple_prpl_got_account_actions
1011                 * purple_prpl_initiate_media
1012                 * purple_request_field_get_group
1013                 * purple_request_field_get_ui_data
1014                 * purple_request_field_set_ui_data
1015                 * purple_ssl_connect_with_ssl_cn
1016                 * purple_strequal
1017                 * purple_utf8_strip_unprintables
1018                 * purple_util_fetch_url_request_len_with_account
1019                 * purple_xfer_prpl_ready
1020                 * purple_xfer_ui_ready
1021                 * xmlnode_from_file
1022                 * xmlnode_get_parent
1023                 * xmlnode_set_attrib_full
1024                 * PURPLE_STATUS_MOOD as a new PurpleStatusPrimitive
1026                 Changed:
1027                 * xmlnode_remove_attrib now removes all attributes with the
1028                   same name.  Previously, it would remove the first one found,
1029                   which was completely non-deterministic.  If you want to remove
1030                   the attribute with no namespace, then use NULL with
1031                   xmlnode_remove_with_namespace.
1032                 * Plugins may now emit the jabber-sending-xmlnode signal in order
1033                   to send stanzas; this method is preferred to the prpl send_raw
1034                   function as other plugins listening to the signal see them.
1035                 * The conversation-updated signal with a PURPLE_CONV_UPDATE_TYPING
1036                   update type is emitted when receiving an IM.  Previously, the
1037                   typing state was modified (and the buddy-typing-stopped signal
1038                   emitted), but this signal was not emitted.
1039                 * Added a client_type field in the get_ui_info core UI op. See
1040                   core.h for details.
1041                 * Added introspection of signals exposed via the D-Bus API.
1042                 * purple_find_buddies is now more efficient in the case where
1043                   it is enumerating all the buddies for an account.
1044                 * purple_find_group is now more efficient for large numbers of groups.
1045                 * purple_find_conversation_with_account is more efficient for large
1046                   numbers of concurrent conversations.
1047                 * All DNS routines support internationalized domain names (IDNs) when
1048                   libpurple is compiled with GNU libidn.
1049                 * status is set before emitting signals in purple_xfer_set_status.
1050                 * Creating multiple distinct chats with the same name (i.e. "MSN Chat")
1051                   is deprecated and will be removed in libpurple 3.0.0.
1052                 * purple_xfer_start now accepts -1 as the fd parameter if the protocol
1053                   plugin will administer the transfer itself. 0 is still accepted for
1054                   backward compatibility since older versions of libpurple will not
1055                   accept -1.
1057                 Deprecated:
1058                 * buddy-added and buddy-removed blist signals
1059                 * purple_blist_destroy
1060                 * purple_blist_new
1061                 * purple_buddy_get_local_alias
1062                 * purple_certificate_check_signature_chain
1063                 * purple_ip_address_is_valid
1064                 * purple_notify_user_info_remove_entry
1065                 * purple_set_blist
1066                 * purple_status_type_set_primary_attr
1067                 * purple_status_type_add_attr
1068                 * purple_status_type_add_attrs
1069                 * purple_status_type_add_attrs_vargs
1070                 * purple_status_type_get_primary_attr
1071                 * purple_status_set_attr_boolean
1072                 * purple_status_set_attr_int
1073                 * purple_status_set_attr_string
1074                 * purple_presence_add_status
1075                 * purple_presence_add_list
1076                 * purple_util_fetch_url_request_len
1077                 * xmlnode_set_attrib_with_namespace
1078                 * xmlnode_set_attrib_with_prefix
1080         pidgin:
1081                 Added:
1082                 * gtk_imhtml_class_register_protocol
1083                 * gtk_imhtml_link_get_url, gtk_imhtml_link_get_text_tag,
1084                   gtk_imhtml_link_activate functions to process GtkIMHtmlLink
1085                   objects from GtkIMHtml protocol callbacks.
1086                 * gtk_imhtml_set_return_inserts_newline
1087                 * gtk_imhtml_set_populate_primary_clipboard
1088                 * pidgin_blist_set_theme
1089                 * pidgin_blist_get_theme
1090                 * pidgin_prefs_labeled_password
1091                 * pidgin_smiley_editor_set_data
1092                 * pidgin_sound_is_customized
1093                 * pidgin_utils_init, pidgin_utils_uninit
1094                 * pidgin_notify_pounce_add
1095                 * PidginBlistTheme, PidginBlistThemeLoader API
1096                 * PidginIconTheme, PidginStatusIconTheme, PidginIconThemeLoader
1097                   API
1098                 * pidgin_stock_id_from_status_primitive
1099                 * pidgin_stock_id_from_presence
1101         libgnt:
1102                 Added:
1103                 * GntProgressBar and functions (Saleem Abdulrasool)
1105         perl:
1106                 Added:
1107                 * Purple::XMLNode::get_name()
1109                 Changed:
1110                 * Made a bunch of functions act more perl-like. Call the new()
1111                   functions as Class->new(...) instead of Class::new(...):
1112                         * Purple::Request::Fields::new
1113                         * Purple::Request::Field::new
1114                         * Purple::Request::Field::account_new
1115                         * Purple::Request::Field::bool_new
1116                         * Purple::Request::Field::choice_new
1117                         * Purple::Request::Field::int_new
1118                         * Purple::Request::Field::label_new
1119                         * Purple::Request::Field::list_new
1120                         * Purple::Request::Field::string_new
1121                         * Purple::Request::Field::group_new
1122                 * Make the XMLNode API more perl-like. Don't pass len
1123                   parameters and call them like:
1124                         * $xmlnode->copy()
1125                         * $xmlnode->to_str()
1126                         * $xmlnode->to_formatted_str()
1127                         * Purple::XMLNode::from_str(...)
1128 version 2.5.9 (08/18/2009):
1129         No changes
1131 version 2.5.8 (06/27/2009):
1132         No changes
1134 version 2.5.7 (06/20/2009):
1135         No changes
1137 version 2.5.6 (05/19/2009):
1138         No changes
1140 version 2.5.5 (03/01/2009):
1141         libpurple:
1142                 Changed:
1143                 * purple_status_type_new now defaults "saveable" to TRUE.
1144                   This was necessary in order to maintain the current behavior
1145                   while fixing non-saveable statuses not to be saved.
1146                 * xmlnode_get_prefix, xmlnode_to_str and xmlnode_to_formatted_str
1147                   now all take a const xmlnode* instead of an xmlnode*
1149 version 2.5.4 (01/12/2009):
1150         perl:
1151                 Changed:
1152                 * Purple::PluginPref->get_bounds no longer takes two integer
1153                   arguments it now returns two integers.
1155                 Removed:
1156                 * Removed a handful of string-related utility functions that
1157                   can generally be better handled with perl's built-in string
1158                   functions rather than using pidgin's:
1159                         * Purple::Util::strcasereplace
1160                         * Purple::Util::strcasestr
1161                         * Purple::Util::strreplace
1162                         * Purple::Util::str_strip_char
1163                         * Purple::Util::chrreplace
1165 version 2.5.3 (12/20/2008):
1166         libpurple
1167                 Changed:
1168                 * purple_util_fetch_url and purple_util_fetch_url_request can
1169                   now fetch https URLs
1171 version 2.5.0 (08/18/2008):
1172         libpurple:
1173                 Added:
1174                 * Connection flag PURPLE_CONNECTION_ALLOW_CUSTOM_SMILEY to indicate
1175                   that the connection supports sending and receiving custom smileys.
1176                 * PurpleSmiley and the Smiley API.
1177                 * purple_serv_got_join_chat_failed
1178                 * chat-join-failed signal (see conversation-signals.dox)
1179                 * chat-invite-blocked and blocked-im-msg signals (see
1180                   converation-signals.dox) (Thanks to Stefan Ott)
1181                 * purple_blist_update_node_icon
1182                 * purple_buddy_icons_node_has_custom_icon
1183                 * purple_buddy_icons_node_find_custom_icon
1184                 * purple_buddy_icons_node_set_custom_icon
1185                 * purple_buddy_icons_node_set_custom_icon_from_file
1186                 * purple_notify_user_info_prepend_section_break
1187                 * purple_notify_user_info_prepend_section_header
1188                 * "website" and "dev_website" items to the ui_info hash table
1189                 * purple_cmds_get_handle, purple_cmds_init, purple_cmds_uninit
1190                 * cmd-added and cmd-removed signals
1191                 * purple_get_host_name
1192                 * purple_util_fetch_url_len (temporary function overload to add max_len param)
1193                 * purple_util_fetch_url_request_len
1194                 * purple_prpl_send_attention
1195                 * purple_prpl_got_attention
1196                 * purple_prpl_got_attention_in_chat
1198                 Deprecated:
1199                 * purple_blist_update_buddy_icon
1200                 * purple_buddy_icons_has_custom_icon
1201                 * purple_buddy_icons_find_custom_icon
1202                 * purple_buddy_icons_set_custom_icon
1203                 * pidgin_set_custom_buddy_icon
1204                 * purple_util_fetch_url_len
1205                 * purple_util_fetch_url_request_len
1206                 * serv_send_attention
1207                 * serv_got_attention
1209                 Changed:
1210                 * xmlnode_copy now copies the prefix and namespace map for nodes.
1212         pidgin:
1213                 Added:
1214                 * gtk_imhtml_smiley_create, gtk_imhtml_smiley_reload and
1215                   gtk_imhtml_smiley_destroy to deal with GtkIMHtmlSmiley's.
1216                 * pidgin_pixbuf_from_imgstore to create a GdkPixbuf from a
1217                   PurpleStoredImage.
1218                 * pidgin_themes_smiley_themeize_custom to associate custom smileys to
1219                   a GtkIMHtml widget.
1220                 * GTK_IMHTML_CUSTOM_SMILEY flag for GtkIMHtml.
1221                 * GTK+ Custom Smiley API.
1223 version 2.4.2 (05/17/2008):
1224         perl:
1225                 Added:
1226                 * Purple::Prefs::get_children_names.
1227                 * Purple::timeout_remove.
1228                 Changed:
1229                 * Purple::timeout_add now returns a handle which can be used
1230                   to remove the timeout.
1231                 * Callbacks to Purple::Util::fetch_url and the
1232                   Purple::Request::* functions can now be specified as both
1233                   strings (the name of the callback function) and as coderefs.
1234         Finch:
1235                 libgnt:
1236                 * Added gnt_bindable_check_key to check if a keystroke is bound.
1238 version 2.4.0 (02/29/2008):
1239         libpurple:
1240                 Added:
1241                 * purple_certificate_add_ca_search_path. (Florian Quèze)
1242                 * purple_gai_strerror.
1243                 * purple_major_version, purple_minor_version,
1244                   purple_micro_version variables are exported by version.h,
1245                   giving the version of libpurple in use at runtime.
1246                 * purple_util_set_current_song, purple_util_format_song_info
1247                 * purple_ip_address_is_valid
1248                 * Some accessor functions to the Roomlist API:
1249                         * purple_roomlist_get_fields
1250                         * purple_roomlist_room_get_type
1251                         * purple_roomlist_room_get_name
1252                         * purple_roomlist_room_get_parent
1253                         * purple_roomlist_room_get_fields
1254                         * purple_roomlist_field_get_type
1255                         * purple_roomlist_field_get_label
1256                         * purple_roomlist_field_get_hidden
1257                 * unlocalized_name field in PurpleAttentionType for UIs that need it.
1258                 * Some accessor and mutator functions for PurpleAttentionType:
1259                         * purple_attention_type_set_name
1260                         * purple_attention_type_set_incoming_desc
1261                         * purple_attention_type_set_outgoing_desc
1262                         * purple_attention_type_set_icon_name
1263                         * purple_attention_type_set_unlocalized_name
1264                         * purple_attention_type_get_name
1265                         * purple_attention_type_get_incoming_desc
1266                         * purple_attention_type_get_outgoing_desc
1267                         * purple_attention_type_get_icon_name
1268                         * purple_attention_type_get_unlocalized_name
1269                 * Add some PurpleBuddyListNode accessor functions:
1270                         * purple_blist_node_get_parent
1271                         * purple_blist_node_get_first_child
1272                         * purple_blist_node_get_sibling_next
1273                         * purple_blist_node_get_sibling_prev
1274                 * Added last_received to PurpleConnection, the time_t of the
1275                   last received packet.
1276                 * Added some more accessor functions:
1277                         * purple_chat_get_account
1278                         * purple_chat_get_components
1279                         * purple_connection_get_prpl
1280                         * purple_xfer_get_start_time
1281                         * purple_xfer_get_end_time
1282                 * purple_serv_got_private_alias for prpls to call after receiving a
1283                   private alias from the server.
1285         Pidgin:
1286                 Added:
1287                 * pidgin_create_dialog to create a window that closes on escape. Also
1288                   added utility functions pidgin_dialog_get_vbox_with_properties,
1289                   pidgin_dialog_get_vbox, pidgin_dialog_get_action_area to access the
1290                   contents in the created dialog. (Peter 'fmoo' Ruibal)
1291                 * pidgin_dialog_add_button to add buttons to a dialog created by
1292                   pidgin_create_dialog.
1293                 * GTK_IMHTML_NO_SMILEY for GtkIMHtmlOptions means not to look for
1294                   smileys in the text. (Florian 'goutnet' Delizy)
1295                 * pidgin_auto_parent_window to make a window transient for a suitable
1296                   parent window.
1297                 * pidgin_tooltip_setup_for_treeview, pidgin_tooltip_destroy,
1298                   pidgin_tooltip_show and pidgin_tooltip_setup_for_widget to simplify
1299                   the process of drawing tooltips.
1300                 * pidgin_add_widget_to_vbox to simplify adding a labeled widget to a
1301                   window.
1303                 Deprecated:
1304                 * PIDGIN_DIALOG
1306         Finch:
1307                 * finch_roomlist_get_ui_ops and finch_roomlist_show_all
1308                 * finch_request_field_get_widget to get the widget for a request
1309                   field.
1310                 * finch_blist_get_tree to get the GntTree widget representing the
1311                   buddy list.
1312                 * FinchBlistManager structure to manage the buddylist view, and some
1313                   util functions finch_blist_install_manager,
1314                   finch_blist_uninstall_manager, finch_blist_manager_find and
1315                   finch_blist_manager_add_node.
1316                 * Added finch_log_show, finch_log_show_contact, finch_syslog_show,
1317                   finch_log_init, finch_log_get_handle, finch_log_uninit
1319                 libgnt:
1320                 * Added gnt_tree_set_row_color to set the color for a row in a tree.
1321                 * Added gnt_style_get_string_list
1322                 * Added gnt_color_add_pair to define a new color.
1323                 * Added gnt_colors_get_color to get an ncurses color value from a
1324                   string.
1325                 * Added gnt_style_get_color to get a color pair from an entry in
1326                   ~/.gntrc
1327                 * Added gnt_tree_get_parent_key to get the key for the parent row.
1329 version 2.3.0 (11/24/2007):
1330         libpurple:
1331                 Added:
1332                 * a PurpleConversation field and an alias field in PurpleConvMessage
1333                 * account-authorization signals (see account-signals.dox for
1334                   details) (Stefan Ott)
1335                 * libpurple/purple.h, which includes #define's and #include's
1336                   required to compile stand-alone plugins
1337                 * PURPLE_STATUS_TUNE as a new PurpleStatusPrimitive
1338                 * purple_plugin_disable(), which is intended to be called when
1339                   a purple_plugin_unload()--which was called when a user tried
1340                   to unload a plugin--fails.  This then prevents the plugin
1341                   from being saved in the saved plugins list, so it'll won't
1342                   be loaded at the next startup.
1343                 * PurpleDisconnectReason enumeration of machine-readable
1344                   types of connection error.
1345                 * purple_connection_error_reason(), to be used by prpls
1346                   (instead of purple_connection_error() and setting
1347                   gc->wants_to_die) to report errors along with a
1348                   PurpleDisconnectReason.
1349                 * PurpleConnectionUiOps.report_disconnect_reason, to be
1350                   implemented by UIs (rather than .report_disconnect) if
1351                   they want to use the reported PurpleDisconnectReason
1352                   to give a more specific error.
1353                 * A connection-error signal, fired just after the UiOp is
1354                   called with the same information.
1355                 * purple_connection_reason_is_fatal(), acting as a hint
1356                   to whether automatic reconnection should be attempted
1357                   after a connection error (rather than checking
1358                   gc->wants_to_die).
1359                 * PurpleConnectionErrorInfo, a struct to hold a
1360                   PurpleConnectionError and a const char *description.
1361                 * purple_account_get_current_error() to get the most recent
1362                   PurpleConnectionError and description (or NULL if the
1363                   account is happy with life), to allow bits of the UI to know
1364                   the last error without caching it themselves (as
1365                   PidginBuddyList does).
1366                 * purple_account_clear_current_error() to reset an account's
1367                   error state to NULL.
1368                 * An account-error-changed signal, firing when
1369                   purple_account_get_current_error()'s return value changes.
1371                 * PidginMiniDialog, a Gtk widget-ified version of
1372                   pidgin_make_mini_dialog().
1374                 * purple_util_init()
1375                 * purple_util_uninit()
1377                 * purple_network_listen_map_external() to temporarily disable
1378                   mapping ports externally via NAT-PMP or UPnP.
1380                 Changed:
1381                 * purple_plugin_unload() now honors the return value of a
1382                   plugin's unload function and can actually return FALSE now.
1383                 * purple_plugin_unload() no longer does its own notifications
1384                   when a dependent plugin fails to unload.  The UI should do
1385                   something appropriate.
1387                 * pidgin_make_mini_dialog() now declares its return type to be
1388                   GtkWidget * rather than void *.  This should not break any
1389                   existing code since any code using it must already rely on
1390                   the return type actually being GtkWidget * all along.
1392                 Deprecated:
1393                 * pidgin_dialogs_about()
1394                 * pidgin_log_show_contact()
1395                 * pidgin_log_show()
1396                 * pidgin_plugin_dialog_show()
1397                 * pidgin_pounce_editor_show()
1398                 * pidgin_pounces_manager_show()
1399                 * pidgin_syslog_show()
1401                 * purple_connection_error()
1402                 * pidgin_blist_update_account_error_state()
1403                 * PidginBuddyList.connection_errors
1404                 * purple_network_listen_map_external()
1406                 MSN:
1407                 * A new independant status type with PURPLE_STATUS_TUNE primitive, and
1408                   PURPLE_TUNE_ARTIST, PURPLE_TUNE_ALBUM and PURPLE_TUNE_TITLE
1409                   attributes.
1411                 XMPP:
1412                 * A new independant status type with PURPLE_STATUS_TUNE primitive, and
1413                   PURPLE_TUNE_{ARTIST, TITLE, ALBUM, GENRE, COMMENT, TRACK, TIME,
1414                   YEAR, URL} attributes.
1416         Finch:
1417                 libgnt:
1418                 * Added gnt_color_pair, which will try to intelligenty set text
1419                   attributes in place of colors if the terminal doesn't have color
1420                   support. (Bug: #3560) All future code should use gnt_color_pair
1421                   instead of COLOR_PAIR.
1422                 * Added gnt_menuitem_set_id and gnt_menuitem_get_id to set and get the
1423                   string id of a menuitem respectively.
1424                 * Added gnt_window_get_accel_item, which returns a the id of a menuitem
1425                   bound to a keystroke.
1426                 * Added gnt_menu_get_item to get a menuitem of the given id from a
1427                   menu.
1428                 * Added gnt_menuitem_activate, which triggers the 'activate' signal on
1429                   the menuitem and calls the callback function, if available.
1430                 * Added GntEntryKillRing in GntEntry.
1431                 * Added gnt_window_set_maximize and gnt_window_get_maximize, and
1432                   GntWindowFlags enum.
1434 version 2.2.2 (10/23/2007):
1435         libpurple:
1436                 Changed:
1437                 * The size parameter of purple_util_write_data_to_file_absolute
1438                   has been changed to gssize instead of a size_t to correctly
1439                   indicate that -1 can be used for a nul-delimited string.
1440                 * The documentation for purple_savedstatuses_get_popular used to
1441                   incorrectly claim that the active status is excluded from the
1442                   returned list. The documentation has been corrected. Also, the
1443                   function now returns a correct list when called with a value of 0.
1445 version 2.2.0 (09/13/2007):
1446         libpurple:
1447                 Added:
1448                 * PURPLE_MESSAGE_INVISIBLE flag, which can be used by
1449                   purple_conv_im_send_with_flags to send a message, but not display it
1450                   in the conversation
1451                 * serv_send_attention(), serv_got_attention(), as well as send_attention 
1452                   and attention_types in PurplePluginProtocolInfo. This new API is used
1453                   for zapping in MySpaceIM, buzzing in Yahoo, and nudging in MSN.
1454                 * PurpleConvMessage structure to represent a message in a
1455                   conversation. purple_conversation_message_get_sender,
1456                   purple_conversation_message_get_message,
1457                   purple_conversation_message_get_flags and
1458                   purple_conversation_message_get_timestamp to get information about a
1459                   PurpleConvMessage.
1460                 * purple_conversation_get_message_history() to retrieve a list of
1461                   PurpleConvMessage's in a conversation, and
1462                   purple_conversation_clear_message_history to clear the history.
1463                 * purple_certificate_* functions in libpurple/certificate.h - "A public-key certificate API"
1464                 * purple_ssl_get_peer_certificates() and associated field in PurpleSslOps to retrieve a server's presented SSL certificate chain.
1465                 * PurpleSslConnection::verifier to provide a "how to verify the peer's certificates" callback to the SSL handlers. See certificate.h for more on this.
1466                 * purple_ssl_connect_with_host_fd() to create an SSL connection from a file descriptor and provide a hostname with it to authenticate the peer against.
1468                 Changed:
1469                 * purple_prefs_load is now called within purple_prefs_init.
1470                   The UI no longer needs to call it.
1471                 * writing-im-msg now receives the conversation name as the who
1472                   argument if the caller of purple_conversation_write didn't
1473                   provide a value for who.
1475         Pidgin:
1476                 Added:
1477                 * pidgin_set_accessible_relations, sets up label-for and labelled-by
1478                   ATK relations (broken out from pidgin_set_accessible_label)
1479                 * pidgin_conv_attach_to_conversation, to reattach the Pidgin UI to a
1480                   conversation
1481                 * conversation-hiding and conversation-displayed signals.
1482                 * pidgin_text_combo_box_entry_new, pidgin_text_combo_box_entry_get_text
1483                   and pidgin_text_combo_box_entry_set_text
1485                 Changed:
1486                 * pidgin_conversations_fill_menu now also adds a separator and a 'Show
1487                   All' item if there are more than one conversations in the list.
1489         Finch:
1490                 Added:
1491                 * finch_sound_is_enabled
1492                 * The reserved field in the FinchConv is now used to store information
1493                   about the conversation (using FinchConversationFlag)
1494                 * finch_account_dialog_show
1496                 libgnt:
1497                 * gnt_slider_set_small_step, gnt_slider_set_large_step to allow more
1498                   fine tuned updates of a GntSlider
1499                 * gnt_util_parse_xhtml_to_textview to parse XHTML strings in a
1500                   GntTextView (this works only if libxml2 is available)
1502 version 2.1.1 (08/20/2007):
1503         libpurple:
1504                 Changed:
1505                 * PurpleAccountUiOps.request_authorize's authorize_cb and
1506                   deny_cb parameters now correctly have type
1507                   PurpleAccountRequestAuthorizationCb rather than GCallback.
1508                   (You'll want to change your UI's implementation's signature
1509                   to avoid warnings, and then remove some now-redundant casts
1510                   back to the proper type.)
1512 version 2.1.0 (7/28/2007):
1513         libpurple:
1514                 Added:
1515                 * purple-remote: added getstatus command
1516                 * conversation-extended-menu signal (See Doxygen docs)
1517                 * OPT_PROTO_SLASH_COMMANDS_NATIVE protocol option to indicate that
1518                   slash commands are "native" to the protocol
1519                 * PURPLE_MESSAGE_NO_LINKIFY message flag to indicate that the message
1520                   should not be auto-linkified
1521                 * PurpleEventLoopUiOps.timeout_add_seconds
1522                     UIs can now use better scheduling for whole-second timers.  For
1523                     example, clients based on the glib event loop can now use
1524                     g_timeout_add_seconds.
1525                 * purple_blist_node_get_type
1526                 * purple_conversation_do_command
1527                 * purple_conversation_get_extended_menu
1528                 * purple_core_ensure_single_instance
1529                     This is for UIs to use to ensure only one copy is running.
1530                 * purple_dbus_is_owner
1531                 * purple_timeout_add_seconds
1532                     Callers should prefer this to purple_timeout_add for timers
1533                     longer than 1 second away.  Be aware of the rounding, though.
1534                 * purple_xfer_get_remote_user
1535                 * purple_pounces_get_all_for_ui
1536                 * purple_prefs_get_children_names
1537                 * added displaying-email-notification and 
1538                   displaying-emails-notification signals
1540                 Changed:
1541                 * The documentation of the following functions now properly
1542                   declares that the returned value must not be modified or
1543                   freed, which was always the case:
1544                         * purple_accounts_get_all
1545                         * purple_connections_get_all
1546                         * purple_connections_get_connecting
1547                         * purple_conv_chat_get_ignored
1548                         * purple_conv_chat_get_users
1549                         * purple_get_chats
1550                         * purple_get_conversations
1551                         * purple_get_ims
1552                         * purple_notify_user_info_get_entries
1553                 * The following functions now return a GList* instead of a
1554                   const GList*, as const is not very useful with GLists.  The
1555                   returned value still must not be modified or freed:
1556                         * purple_account_get_status_types
1557                         * purple_mime_document_get_fields
1558                         * purple_mime_document_get_parts
1559                         * purple_mime_part_get_fields
1560                         * purple_request_fields_get_required
1561                         * purple_request_field_list_get_selected
1562                         * purple_request_field_list_get_items
1563                         * purple_status_type_get_attrs
1564                         * purple_presence_get_statuses
1565                 * purple_request_field_list_set_selected now takes a GList*
1566                   instead of a const GList* for items, as const is not very
1567                   useful with GLists.  The passed list is still not modified
1568                   or freed.
1569                 * purple_presence_add_list now takes a GList* instead of a
1570                   const GList* for source_list, as const is not very useful with
1571                   GLists.  The passed list is still not modified or freed.
1573         Pidgin:
1574                 Added:
1575                 * gtk_imhtml_setup_entry
1576                 * pidgin_create_window
1577                 * pidgin_retrieve_user_info and pidgin_retrieve_user_info_in_chat,
1578                   shows immediate feedback when getting information about a user.
1579                 * gtk_imhtml_animation_new
1580                     Can be used for inserting an animated image into an IMHTML.
1581                 * pidgin_menu_position_func_helper
1582                 * pidgin_blist_get_name_markup, returns the buddy list markup
1583                   text for a given buddy.
1584                 * pidgin_blist_draw_tooltip and pidgin_blist_tooltip_destroy
1585                   for creating blist tooltips from outside of buddy list code
1586                 * pidgin_themes_remove_smiley_theme
1588                 Changed:
1589                 * pidgin_append_menu_action returns the menuitem added to the menu.
1590                 * pidgin_separator returns the separator added to the menu.
1591                 * PidginConversation has struct members to handle the new info
1592                   pane:
1593                         * infopane
1594                         * infopane_hbox
1595                         * infopane_model
1596                         * infopane_iter
1598         Finch:
1599                 Added:
1600                 * finch_retrieve_user_info
1602                 libgnt:
1603                         Added:
1604                         * GntWS for workspaces
1605                         * gnt_tree_set_column_title
1606                         * GntSlider widget
1607                         * "completion" signal for GntEntry
1608                         * "terminal-refresh" signal for GntWM, with a corresponding entry
1609                           in GntWMClass
1610                         * New flags for GntTextView to decide whether to word-wrap or show
1611                           scrollbars (GntTextViewFlag) which can be set by
1612                           gnt_text_view_set_flag
1613                         * gnt_style_get_from_name
1614                         * gnt_window_present
1615                         * gnt_tree_set_column_width_ratio
1616                         * gnt_tree_set_column_resizable
1617                         * gnt_tree_set_column_is_right_aligned
1618                         * gnt_tree_set_search_function, gnt_tree_set_search_column,
1619                           gnt_tree_is_searching
1620                         * 'file-selected' signal is emited for GntFileSel
1621                         * gnt_style_parse_bool
1622                         * gnt_util_set_trigger_widget
1624                         Changed:
1625                         * gnt_tree_get_rows() now returns a GList* instead of a const
1626                           GList*, as const is not very useful with GLists.  The
1627                           returned value still must not be modified or freed.
1628                         * Instead of keeping an 'invisible' item, the GntTreeColumns now
1629                           maintain 'flags' with the appropriate flags set
1631 version 2.0.2 (6/14/2007):
1632         Pidgin:
1633                 Deprecated:
1634                 * pidgin_dialogs_alias_contact:  This will be removed in 3.0.0
1635                   unless there is sufficient demand to keep it.
1637 version 2.0.0 (5/3/2007):
1638         Please note all functions, defines, and data structures have been
1639         re-namespaced to match the new names of Pidgin, Finch, and libpurple.
1640         All gaim_gtk_* functions are now pidgin_*, former libgaim functions are
1641         now purple_*.  Please consult our doxygen documentation for a complete
1642         reference.
1644         The gaim-compat.h header exists to provide an API compatibility layer
1645         for libpurple functions.  As an API compatibility layer, it must be
1646         included at compile time to be of use.
1648         Changed:
1649         * All the status stuff.  Yay!
1650         * gaim_prefs_connect_callback(), added handle parameter
1651         * gtk_imhtml_toolbar now descends from GtkHBox making it easier to add your
1652           own widgets to it
1653         * gaim_find_conversation_with_account, added a "type" parameter
1654         * gaim_gtk_prefs_labeled_spin_button, the "key" parameter is now a
1655           const char* instead of just a char*
1656         * gaim_gtk_prefs_labeled_entry, the "key" parameter is now a const char*
1657           instead of just a char*
1658         * the add_buddy perl sub.  The sub now takes the account as the first
1659           argument, and buddy and group as the second and third.  It also adds
1660           the buddy to the server-side buddy list of the given account.
1661         * gaim_connection_new, gaim_account_connect and gaim_account_register no
1662           longer return a GaimConnection
1663         * keep_alive in GaimConnection is renamed to keepalive
1664         * gaim_mkstemp, added a second argument, a boolean, of whether or not the
1665           file is binary
1666         * gaim_log_logger_new, rewritten
1667         * gaim_conv_window_remove_conversation()'s last argument to be a
1668           GaimConversation.
1669         * A new blocked icon: pixmaps/status/default/blocked.png
1670         * In pixmaps/status/default: extendedaway.png renamed to extended_away.png
1671         * In pixmaps/status/default: na.png renamed to unavailable.png
1672         * gtk_imhtml_toggle_bold(): No longer returns a value
1673         * gtk_imhtml_toggle_italic(): No longer returns a value
1674         * gtk_imhtml_toggle_underline(): No longer returns a value
1675         * gtk_imhtml_toggle_strike(): No longer returns a value
1676         * gtk_imhtml_scroll_to_end(): Added the smooth paramter
1677         * gaim_log_new(), added conv parameter
1678         * gaim_buddy_icon_new(), leaves a reference which the caller owns.  Use
1679           gaim_buddy_icon_unref() immediately if you don't want a reference (the
1680           old behavior).
1681         * GAIM_CONV_UNKNOWN to GAIM_CONV_TYPE_UNKNOWN.
1682         * GAIM_CONV_IM to GAIM_CONV_TYPE_IM.
1683         * GAIM_CONV_CHAT to GAIM_CONV_TYPE_CHAT.
1684         * GAIM_CONV_MISC to GAIM_CONV_TYPE_MISC.
1685         * GAIM_CONV_ANY to GAIM_CONV_TYPE_ANY.
1686         * GaimConversationUiOps.write_conv, Replaced const char *who with
1687           const char *name, const char *alias
1688         * gaim_conv_chat_add_users(), added extra_msgs and new_arrivals (pass NULL
1689           and FALSE respectively, to get the same behavior as before)
1690         * chat_add_users in GaimConversationUiOps, added cbuddies and 
1691           new_arrivals and removed buddies.
1692         * chat_rename_user in GaimConversationUiOps, added new_alias
1693         * gaim_conv_chat_cb_new(), added alias. (pass NULL to get the same
1694           behavior as before).
1695         * GaimConversation.log became GList * GaimConversation.logs, so that a
1696           conversation can have multiple logs at once
1697         * gaim_conv_chat_add_user, added extra_msgs
1698         * gaim_notify_userinfo, removed primary and secondary parameters
1699         * GaimNotifyUiOps.notify_userinfo: removed title, primary, and
1700           secondary parameters
1701         * Idle timers are now added and removed in gtkidle.c in response
1702           to the signed-on and signed-off signals
1703         * GaimXfer->ops.read, GaimXfer->ops.write, gaim_xfer_set_read_fnc(),
1704           gaim_xfer_set_write_fnc(), gaim_xfer_read(), gaim_xfer_write():
1705           Changed ssize_t to gssize
1706         * serv_got_im, serv_got_chat_in, serv_send_im and serv_chat_send all use
1707           GaimMessageFlags instead of GaimConvImFlags / GaimConvChatFlags
1708         * All core<->prpl message passing now uses html.  This was previously true
1709           for receiving messages, it's now also true for sending them.  prpls that
1710           don't support html need to gaim_unescape_html() the message.
1711         * Notify API: GCallback -> GaimNotifyCloseCallback,
1712                       void *user_data -> gpointer user_data
1713         * gaim_notify_searchresults_get_rows_count,
1714           gaim_notify_searchresults_get_columns_count: return type now guint
1715         * gaim_account_notify_added: No longer checks if there is a
1716           GaimBuddy for the added user, that's left up to the prpls.  See the
1717           documentation for this function and gaim_account_request_add.
1718         * gaim_accounts_reorder: new_index is now a gint instead of a size_t
1719         * displaying-message signals: displaying-[im|chat]-msg and
1720           displayed-[im|chat]-msg signals are emitted for all messages
1721           (ie, for received messages, sent messages, system messages, error
1722           messages etc.), and the signals now have
1723           gaim_gtk_conversations_get_handle() for their handle.
1724         * GAIM_NOTIFY_BUTTON_ADD_BUDDY to GAIM_NOTIFY_BUTTON_ADD
1725         * conversation-switched: This signal has been moved from conversation to
1726                                  the UI and the signal-handlers only receive the
1727                                  conversation that has been switched to.
1728         * GaimPluginProtocolInfo: Added offline_message
1729         * GaimPluginProtocolInfo: Added whiteboard_prpl_ops
1730         * GaimPluginProtocolInfo: Added media_prpl_ops
1731         * GaimPluginProtocolInfo: Added "user_info" argument to tooltip_text,
1732                                   changed the return type to void
1733         * GaimPluginProtocolInfo: Added "full" argument to tooltip_text
1734         * gaim_pounce_new(): Added option argument for pounce options
1735         * gaim_network_listen() and gaim_network_listen_range(): Added
1736           socket_type parameter to allow creation of UDP listening. Modified
1737           to be asynchronous with a callback to allow for UPnP operation.
1738           Returns a data structure that can be used to cancel the listen
1739           attempt using gaim_network_listen_cancel()
1740         * GaimPrefCallback: val is now a gconstpointer instead of a gpointer
1741         * gtk_imhtml_get_current_format(): the arguments are now set to TRUE or
1742           FALSE.  Previously they were set to TRUE or left alone.  Also, you
1743           may now pass NULL if you're not interested in a specific formatting.
1744         * Smiley Themes: Backslashes must be backslash-escaped.
1745         * Plugins: Depedencies are now honored when unloading plugins.
1746         * gaim_markup_extract_info_field(): Added format_cb parameter.
1747         * gaim_markup_extract_info_field(): Changed GString parameter to a GaimNotifyUserInfo paramter.
1748         * gaim_str_to_time(): Added support for parsing the MM/DD/YYYY format.
1749         * gaim_plugin_action_new(): label is now const char *
1750         * gaim_plugin_pref_new_with_name(): name is now const char *
1751         * gaim_plugin_pref_new_with_label(): label is now const char *
1752         * gaim_plugin_pref_new_with_name_and_label(): name and label are
1753           now const char *
1754         * gaim_plugin_pref_set_name(): name is now const char *
1755         * gaim_plugin_pref_get_name(): return type is now const char *
1756         * gaim_plugin_pref_set_label(): label is now const char *
1757         * gaim_plugin_pref_get_label(): return type is now const char *
1758         * gaim_plugin_pref_add_choice(): label is now const char *
1759         * struct proto_chat_entry: label is now const char *
1760         * struct proto_chat_entry: identifier is now const char *
1761         * All network activity has been updated to use non-blocking sockets.
1762           This means that plugins must be updated to expect such a socket from
1763           gaim_proxy_connect() and gaim_network_listen*().
1764         * gaim_proxy_connect(): changed to return NULL on error and a pointer
1765           to a GaimProxyConnectInfo object which can be used to cancel
1766           connection attempts using gaim_proxy_connect_cancel().  Also added
1767           a 'handle' parameter that can be used to cancel the connection
1768           attempt using gaim_proxy_connect_cancel_with_handle().
1769         * gaim_gethostbyname_async(): Renamed to gaim_dnsquery_a() and
1770           changed to return a pointer to a data structure that can be
1771           used to cancel the pending DNS query using gaim_dnsquery_destroy()
1772         * gaim_url_fetch(): Renamed to gaim_util_fetch_url() and changed
1773           to return a pointer to a data structure that can be used to cancel
1774           the pending HTTP request using gaim_util_fetch_url_cancel().
1775           Corresponding callback has changed to accept this data structure
1776           as its first argument, and to accept an error message as an
1777           additional final argument.
1778         * gaim_gtk_create_imhtml(): Added sw_ret() parameter
1779         * gaim_account_get_log(): Added create parameter
1780         * GAIM_CMD_P_VERYHIGH is now GAIM_CMD_P_VERY_HIGH
1781         * gtk_imhtml_search_find(): Now wraps around to the top instead of
1782           clearing the search at the end.
1783         * gaim_gtkxfer_dialog_show: Can now take NULL to show (and possibly
1784           create) a default gtkxfer dialog.
1785         * CHAT_USERS_BUDDY_COLUMN became CHAT_USERS_WEIGHT_COLUMN, along with
1786           a change in the values stored in the column.
1787         * gaim_find_buddies() returns a list of all buddies in the account if name
1788           is NULL.
1789         * gaim_gtk_set_custom_buddy_icon() sets custom icon for a user.
1790         * Hid the definition of _GaimStringref, which already had a warning to
1791           avoid accessing it directly.
1792         * notify_userinfo() UI op is passed a GaimNotifyUserInfo instead of a char*
1793           for the user information
1794         * gaim_buddy_icon_get_scale_size() and was changed to ALWAYS scale
1795           the icon instead of only when icon_spec->scale_rules contains
1796           GAIM_ICON_SCALE_DISPLAY.  Callers should be changed to check the
1797           scale_rules before calling this function.
1798         * gaim_gtk_buddy_icon_get_scale_size() was changed to accept an
1799           additional parameter which is used to determine what kind of
1800           scaling should be done, if any.
1801         * purple_request_input(), purple_request_choice(),
1802           purple_request_choice_varg(), purple_request_action(),
1803           purple_request_action_varg(), purple_request_fields(),
1804           purple_request_yes_no(), purple_request_ok_cancel(),
1805           purple_request_accept_cancel(), purple_request_file(), and
1806           purple_request_folder() was changed to accept account, who, and
1807           conversation parameters for associating the request with an account, a
1808           buddy, or a conversation.
1809         * Significant changes to the buddy icon and imgstore APIs.  If you
1810           were using any of it, it's best to look at the header files or
1811           Doxygen documentation, but here are some significant changes:
1812             purple_buddy_icon_new() now takes ownership of ("frees") icon_data
1813             purple_buddy_icon_set_data(): likewise for data
1814             purple_buddy_icon_set_for_user(): likewise for data
1815             purple_buddy_icon_set_for_user() now takes a checksum parameter
1816             purple_imgstore_add() was renamed to purple_imgstore_add_with_id()
1817               which takes ownership of data
1819         Removed:
1820         * gaim_gtk_sound_{get,set}_mute() (replaced by the /gaim/gtk/sound/mute
1821           preference)
1822         * gaim_escape_html(const char *html) (use g_markup_escape_text(html, -1)
1823           instead)
1824         * gaim_accounts_sync, account changes are now scheduled to be saved
1825           automatically
1826         * gaim_connection_connect
1827         * gaim_connection_disconnect
1828         * gaim_connection_register
1829         * gaim_accounts_auto_login
1830         * gaim_find_conversation, use gaim_find_conversation_with_account instead
1831         * gaim_chat_get_display_name
1832         * gaim_conversation_set_history, gaim_conversation_get_history, and
1833           GaimConversation->history.  Use gtk_imhtml_get_markup instead.
1834         * set_gaim_user_dir to gaim_util_set_user_dir
1835         * create_prpl_icon to gaim_gtk_create_prpl_icon
1836         * Window flashing support in the core: gaim_conv_window_flash, and flash UI
1837           operation for conversations.  Use signal "received-im-msg" or similar.
1838         * All warning stuff from the core.
1839         * gaim_gtkconv_get_dest_tab_at_xy(), instead use gaim_gtkconv_get_tab_at_xy()
1840         * chat_add_user from GaimConversationUiOps: only chat_add_users is used
1841         * chat_remove_user from GaimConversationUiOps: only chat_remove_users is used
1842         * uc from the GaimBuddy struct
1843         * gaim_sound_get_handle()
1844         * gaim_debug_vargs()
1845         * serv_add_buddy(); use gaim_account_add_buddy() instead
1846         * serv_add_buddies(); use gaim_account_add_buddies() instead
1847         * serv_change_passwd(); use gaim_account_change_password() instead
1848         * serv_close()
1849         * serv_finish_login()
1850         * serv_login()
1851         * serv_remove_buddy(); use gaim_account_remove_buddy() instead
1852         * serv_remove_buddies(); use gaim_account_remove_buddies() instead
1853         * serv_rename_group()
1854         * serv_set_buddyicon(): use gaim_account_set_buddy_icon() instead
1855         * serv_touch_idle(): use gaim_gtk_check_idle() instead
1856         * GaimGtkImPane->a_virgin
1857         * gaim_str_strip_cr(); use gaim_str_strip_char(str, '\r') instead
1858         * gaim_find_buddys_group renamed to gaim_buddy_get_group
1859         * gaim_gtkpounce_menu_build()
1860         * gaim_gtkpounce_dialog_show()
1861         * GaimGtkBuddyList->bpmenu
1862         * GaimConvImFlags and GaimConvChatFlags; use GaimMessageFlags instead
1863         * cb and user_data from the ops in GaimNotifyUiOps: This is now handled
1864           by the notify API in the core.
1865         * GaimConversationUiOps.updated: use the conversation-updated signal
1866         * GAIM_SUBTYPE_CONV_WINDOW: windows are now only represented in the UI,
1867           so GAIM_TYPE_BOXED is used for the signal types
1868         * gaim_gtk_privacy_is_showable(): We do fallback privacy in the core
1869           now, so this would always be TRUE now.
1870         * GaimBlistNodeAction: See GaimMenuAction
1871         * gaim_blist_node_action_new(); use gaim_menu_action_new() instead
1872         * gaim_date()
1873         * gaim_date_full(): See gaim_date_format_full()
1874         * gaim_strftime(): See gaim_utf8_strftime()
1875         * GAIM_MESSAGE_COLORIZE
1876         * user_data from gaim_notify_searchresults_new_rows and from 
1877           notify_searchresults in GaimNotifyUiOps.
1878         * gaim_conversation_get_send_history(), and send_history from
1879           GaimConversation
1880         * Removed ui_ops from GaimBuddyList. Use gaim_blist_get_ui_ops() instead
1881         * GaimGtkConversation: dialogs (dialogs.search moved to GaimGtkWindow)
1882         * gaim_show_xfer_dialog: Use gaim_gtk_xfer_dialog_show(NULL) instead.
1883         * GaimGtkRoomlistDialog: Nothing used it outside of the file it was in.
1884         * gaim_gtk_roomlist_dialog_new: use gaim_gtk_roomlist_show
1885         * gaim_gtk_roomlist_dialog_new_with_account: use gaim_gtk_roomlist_show_with_account
1886         * binreloc functions
1888         Added:
1889         * gaim_prefs_disconnect_by_handle()
1890         * a password field to GaimConnection, which only persists for the
1891           session (when "remember password" is false, account->password is
1892           NEVER set) Use gaim_connection_get_password(GaimConnection *gc)
1893         * gaim_log_common_writer, gaim_log_common_lister, gaim_log_common_sizer,
1894           and gaim_log_get_log_dir to allow log formats that use standard Gaim
1895           log directory to use Gaim's built-in code for these purposes.
1896         * GaimLogCommonLoggerData struct for a basic logger_data struct to be
1897           used with "common" logger functions.
1898         * gaim_gtk_blist_node_is_contact_expanded, returns TRUE if the given
1899           blist node is a buddy inside an expanded contact, or is itself an
1900           expanded contact
1901         * GaimLogSet struct, get_log_sets function to GaimLogLogger,
1902           gaim_log_get_log_sets, gaim_log_set_compare
1903         * gaim_privacy_check(), to check if a given user is allowed to send
1904           messages to the specified account
1905         * gtk_imhtml_clear_formatting()
1906         * gtk_imhtml_delete to clear out part of a imhtml buffer
1907         * gtk_imhtml_get_protocol_name()
1908         * gaim_buddy_icons_get_full_path(), to get the full path of a buddy
1909           icon setting
1910         * CHAT_USERS_ALIAS_COLUMN, CHAT_USERS_COLOR_COLUMN,
1911           CHAT_USERS_BUDDY_COLUMN to the list of columns for the chat
1912           user list
1913         * gaim_account_add_buddy()
1914         * gaim_account_add_buddies()
1915         * gaim_account_remove_buddy()
1916         * gaim_account_remove_buddies()
1917         * gaim_account_change_password()
1918         * gaim_account_supports_offline_message()
1919         * gaim_conversation_close_logs(), to force a conversation's log(s) to
1920           be closed.  New logs will be opened as necessary.
1921         * gaim_got_protocol_handler_uri()
1922         * gaim_plugin_get_id()
1923         * gaim_plugin_get_name()
1924         * gaim_plugin_get_version()
1925         * gaim_plugin_get_summary()
1926         * gaim_plugin_get_description()
1927         * gaim_plugin_get_author()
1928         * gaim_plugin_get_homepage()
1929         * gaim_gtkconv_switch_active_conversation(GaimConversation *)
1930         * gaim_str_strip_char() to strip a given character from
1931           a given string
1932         * gaim_util_chrreplace() to replace a given character with a
1933           different character
1934         * gaim_gtk_blist_toggle_visibility() to intelligently toggle the
1935           visiblity of the buddy list
1936         * gaim_gtk_blist_visibility_manager_add() to indicate the addition of a
1937           visibility manager - see the docs for more information
1938         * gaim_gtk_blist_visibility_manager_remove() to indicate the removal of
1939           a visibility manager - see the docs for more information
1940         * gaim_gtk_conversations_find_unseen_list() to get a list of conversations
1941           with an "unseen" state >= to the specified state and other criteria
1942         * gaim_gtk_conversations_fill_menu() fill a menu from list of conversations
1943         * gaim_gtk_create_prpl_icon()
1944         * gaim_gtk_create_prpl_icon_with_status()
1945         * gaim_gtk_pounces_manager_show()
1946         * gaim_gtk_pounces_manager_hide()
1947         * gaim_gtk_pounce_editor_show()
1948         * GAIM_POUNCE_MESSAGE_RECEIVED
1949         * GaimPounceOption
1950         * gaim_pounce_set_options()
1951         * gaim_pounce_set_options()
1952         * GAIM_STOCK_CONNECT, GAIM_STOCK_DISCONNECT
1953         * GAIM_STOCK_PLUGIN
1954         * gaim_account_request_add: Notifies the user that they were added to
1955                                     someone's buddy list, and offers them the choice
1956                                     of adding that person to their buddy list.
1957         * gaim_blist_alias_contact()
1958         * gaim_cipher_http_digest_calculate_session_key()
1959         * gaim_cipher_http_digest_calculate_response()
1960         * gaim_notify_searchresults_labeled()
1961         * GAIM_NOTIFY_BUTTON_LABELED, GAIM_NOTIFY_BUTTON_INFO,
1962           GAIM_NOTIFY_BUTTON_IM, GAIM_NOTIFY_BUTTON_JOIN,
1963           GAIM_NOTIFY_BUTTON_INVITE
1964         * stock buttons GAIM_STOCK_IM, GAIM_STOCK_INFO
1965         * gaim_conversation_present()
1966         * GaimConversationUiOps->present(GaimConversation *)
1967         * GaimPlugin.unloadable
1968         * gaim_plugin_is_unloadable()
1969         * GAIM_PLUGIN_PREF_STRING_FORMAT
1970         * gaim_plugin_pref_get_format_type()
1971         * gaim_plugin_pref_set_format_type()
1972         * GaimStringFormatType
1973         * gaim_log_get_handle()
1974         * gaim_log_uninit()
1975         * GAIM_SUBTYPE_LOG
1976         * gaim_marshal_POINTER__POINTER_POINTER
1977         * gaim_utf8_ncr_encode()
1978         * gaim_gtk_log_init()
1979         * gaim_gtk_log_get_handle()
1980         * gaim_gtk_log_uninit()
1981         * gaim_util_fetch_url_request()
1982         * GaimMenuAction
1983         * gaim_menu_action_new()
1984         * gaim_menu_action_free()
1985         * GaimInfoFieldFormatCallback
1986         * gaim_utf8_strftime()
1987         * gaim_date_format_short()
1988         * gaim_date_format_long()
1989         * gaim_date_format_full()
1990         * gaim_time_format()
1991         * gaim_plugin_action_free()
1992         * GaimRequestType: Added GAIM_REQUEST_FOLDER
1993         * GaimRequestUiOps: Added request_folder
1994         * gaim_request_folder()
1995         * gaim_gtk_setup_screenname_autocomplete()
1996         * gaim_gtk_set_cursor()
1997         * gaim_gtk_clear_cursor()
1998         * GAIM_MESSAGE_ACTIVE_ONLY
1999         * gaim_proxy_get_setup()
2000         * GaimNotifySearchResultsCallback: Added user_data.
2001         * gaim_notify_searchresults: Added user_data.
2002         * gaim_network_listen_cancel(): Can be used to cancel a previous
2003           call to gaim_network_listen() or gaim_network_listen_range()
2004         * gaim_proxy_connect_cancel(): Can be used to cancel a pending
2005           gaim_proxy_connect() request
2006         * gaim_proxy_connect_cancel_with_handle(): Can be used to cancel
2007           a previous gaim_proxy_connect() request using a specified handle
2008         * gaim_dnsquery_destroy(): Can be used to cancel a pending DNS
2009           query.
2010         * gaim_util_fetch_url_cancel(): Can be used to cancel a pending
2011           call to gaim_util_fetch_url() or gaim_util_fetch_url_request().
2012         * GaimGtkWindow: dialogs.search (previously in GaimGtkConversation)
2013         * gaim_buddy_get_server_alias()
2014         * gaim_conv_send_confirm()
2015         * GaimConversationUiOps.send_confirm
2016         * gaim_gtk_roomlist_dialog_show_with_account
2017         * gaim_gtk_tree_view_search_equal_func to be used with
2018           gtk_tree_view_set_search_equal_func
2019         * gaim_xfer_set_bytes_sent().  Sets the offset in the file to
2020           read from or write to.
2021         * gaim_privacy_deny and gaim_privacy_allow
2022         * gaim_gtk_blist_set_headline
2023         * gaim_gtk_set_urgent
2024         * GtkGaimScrollBook and its functions.
2025         * purple_markup_unescape_entity()
2026         * purple_markup_get_css_property()
2027         * purple_group_get_name()
2029         Signals - Changed:  (See the Doxygen docs for details on all signals.)
2030         * Signal propagation now stops after a handler returns a non-NULL value.
2031           This value is now returned.  Previously, all registered handlers were
2032           called and the value from the last handler was used.
2033         * "buddy-typing" and "buddy-typing-stopped": replaced the GaimConversation*
2034           with GaimAccount*, const char *name.  Also, the signal is now emitted
2035           regardless of whether a conversation exists and regardless of whether
2036           the user is on the buddy list.
2037         * "chat-buddy-joined": added the new_arrival argument
2038         * "chat-invited" handlers can now return a value to control what happens
2039           to the invite (accept, reject, prompt the user).
2040         * "chat-left": Emitted *after* setting chat->left to TRUE.
2041         * "drawing-tooltip": the second argument is now a GString* instead of
2042           a char**
2043         * "drawing-tooltip": added the "full" argument
2044         * "received-im-msg" and "received-chat-msg" to match, both now pass a
2045           conversation pointer and flags
2046         * "receiving-im-msg" and "receving-chat-msg" to match, both now pass a
2047           conversation pointer and a pointer to the flags.
2048         * "writing-im-msg", "wrote-im-msg", "writing-chat-msg", "wrote-chat-msg":
2049           Now emitted from a difference place in the message handling code.
2050           The arguments also changed.
2051         * "displaying-im-msg", "displayed-im-msg", "displaying-chat-msg",
2052           "displayed-chat-msg": Added "who" argument, which changes the order
2053           of the existing arguments.
2055         Signals - Added:  (See the Doxygen docs for details on all signals.)
2056         * "account-disabled"
2057         * "account-status-changed"
2058         * "account-alias-changed"
2059         * "cipher-added"
2060         * "cipher-removed"
2061         * "conversation-dragging"
2062         * "dbus-method-called"
2063         * "dbus-introspect"
2064         * "file-recv-accept"
2065         * "file-recv-start"
2066         * "file-recv-cancel"
2067         * "file-recv-complete"
2068         * "file-recv-request"
2069         * "file-send-accept"
2070         * "file-send-start"
2071         * "file-send-cancel"
2072         * "file-send-complete"
2073         * "buddy-added"
2074         * "buddy-removed"
2075         * "blist-node-aliased"
2076         * "buddy-status-changed"
2077         * "buddy-idle-changed": A buddy's idle status changed.
2078         * "buddy-icon-changed"
2079         * "buddy-got-login-time": The login time for a buddy is now known
2080         * "displaying-userinfo"
2081         * "gtkblist-hiding"
2082         * "gtkblist-unhiding"
2083         * "log-displaying"
2084         * "network-configuration-changed"
2085         * "savedstatus-changed"
2086         * "sendto-extended-menu"
2087         * "uri-handler"
2089         Signals - Removed:
2090         * "account-away": replaced by account-status-changed
2091         * "account-warned"
2092         * "buddy-away": replaced by buddy-status-changed
2093         * "buddy-back": replaced by buddy-status-changed
2094         * "buddy-idle": replaced by buddy-idle-changed
2095         * "buddy-unidle": replaced by buddy-idle-changed
2096         * "buddy-icon-cached": replaced by buddy-icon-changed
2097         * "conversation-drag-end": replaced by conversation-dragging
2098         * "conversation-switching"
2100 version 1.5.0 (8/11/2005):
2101         * Added: gaim_xfer_conversation_write
2102           Writes a messages to a conversation window with the use
2103           of the associated file transfer.
2105 version 1.4.0 (7/7/2005):
2106         * Added: gaim_buddy_icon_uncache()
2107           Deletes a cached buddy icon for a specified buddy
2108         * Added: gaim_buddy_icon_get_type
2109           Attempts to determine the type of a given buddy icon.
2110         * Added: buddy-icon-cached signal
2111           Emitted when a new buddy icon is cached.
2113 version 1.3.1 (6/9/2005):
2114         * No changes
2116 version 1.3.0 (5/10/2005):
2117         * Added: gaim_blist_schedule_save()
2118           This should be used instead of gaim_blist_sync when you
2119           want the blist.xml file to be written to disk.  There
2120           should not be many occasions when you want to do this,
2121           as the functions in the blist API that modify the buddy
2122           list will normally call it for you.
2123         * Added: OPT_PROTO_NO_NORMALIZE_CONV
2124           Tells the conversation API to not normalize screen names
2125           in conversations.  This is used by the Jabber PRPL.
2127 version 1.2.1 (4/3/2005):
2128         * No changes
2130 version 1.2.0 (3/17/2005):
2131         * You can use gaim_signal_connect_priority() and
2132           gaim_signal_connect_priority_vargs() to connect to
2133           Gaim signals with a given priority (Will Gorman)
2134         * Added: gaim_conversation_set_features
2135                  gaim_conversation_get_features
2136           These allow plugins (notable prpls) to change the
2137           formatting capabilities of an existing conversation.
2138           This comes with a new "features" field in
2139           GaimConversation (Christopher O'Brien)
2140         * Added: GAIM_CONNECTION_NO_IMAGES to GaimConectionFlags
2141            (Christopher O'Brien)
2142         * Added: GAIM_CBFLAGS_TYPING to GaimConvChatBuddyFlags
2143            (Christopher O'Brien)
2144         * Added: gaim_account_request_add which takes the same arguments as
2145         *  gaim_account_notify_added but always asks the user if they want to add
2146         *  the buddy to the buddy list
2147         * Added: An accompanying request_add GaimAccountUiOp
2149 version 1.1.4 (2/24/2005):
2150         * No changes
2152 version 1.1.3 (2/17/2005):
2153         * No changes
2155 version 1.1.2 (1/20/2005):
2156         * No changes
2158 version 1.1.1 (12/28/2004):
2159         * No changes
2161 version 1.1.0 (12/02/2004):
2162         * Added: gaim_utf8_salvage
2163         * Added: binary relocation support in prefix.h
2164                  WARNING: If your plugin uses anything inside the
2165                  #ifdef ENABLE_BINRELOC from prefix.h, it won't be
2166                  loadable on a copy of Gaim compiled without binreloc
2167                  support. In particular, watch out for the autoconf-like
2168                  macros, and accidently including them through internal.h,
2169                  which you probably shouldn't be including anyway.
2171 version 1.0.0 (09/17/2004):
2172         * Added: get_chat_name to the GaimPluginProtocolInfo struct
2173         * Changed: gaim_blist_update_buddy_presence(), presence changed to
2174                    type gboolean
2175         * Changed: the versioning scheme, and all the plugin structs
2177 version 0.82 (08/26/2004):
2178         Gaim API:
2179         * Removed: gaim_gtk_get_dispstyle(), gaim_gtk_change_text()
2180         * Removed: multi.h
2181         * Renamed: ui.h to gtkdialogs.h
2182         * Renamed: gtkinternal.h to gtkgaim.h
2183         * Renamed: show_info_dialog to gaim_gtkdialogs_info
2184         * Renamed: show_log_dialog to gaim_gtkdialogs_log
2185         * Renamed: show_warn_dialog to gaim_gtkdialogs_warn
2186         * Renamed: show_im_dialog to gaim_gtkdialogs_im
2187         * Renamed: gaim_gtkdialogs_new_im to gaim_gtkdialogs_im_with_user
2188         * Renamed: destroy_all_dialogs to gaim_gtkdialogs_destroy_all
2189         * Renamed: alias_dialog_bud to gaim_gtkdialogs_alias_buddy
2190         * Renamed: alias_dialog_contact to gaim_gtkdialogs_alias_contact
2191         * Renamed: alias_dialog_blist_chat to gaim_gtkdialogs_alias_chat
2192         * Renamed: show_confirm_del to gaim_gtkdialogs_remove_buddy
2193         * Renamed: show_confirm_del_group to gaim_gtkdialogs_remove_group
2194         * Renamed: show_confirm_del_blist_chat to gaim_gtkdialogs_remove_chat
2195         * Renamed: show_confirm_del_contact to gaim_gtkdialogs_remove_contact
2196         * Renamed: show_about to gaim_gtkdialogs_about
2197         * Added: gaim_notify_userinfo() and the associated notify_userinfo() UI op
2198                  which pass account and contact information associated with the
2199                  userinfo
2201         Buddy List API:
2202         * Changed: gaim_blist_request_add_chat(), added name parameter
2203         * Added: gaim_contact_on_account()
2204         * Added: flags parameter to the GaimBlistNode struct
2206         Conversation API:
2207         * Added: gaim_gtkconv_button_new()
2209         Protocol Plugin API: v7
2210         * Added: chat_info_defaults to the GaimPluginProtocolInfo struct
2212         Signals:
2213         * Added: conversation-updated for any update to the data associated
2214           with the conversation (topic, icon, adding to buddy list, etc.)
2216         Conversation API:
2217         * Changed: gaim_conv_chat_add_user() (added new_arrival parameter)
2219 version 0.81 (08/05/2004):
2220         Commands API:
2221         * Most functions now have a void *data argument.
2223         Blist API:
2224         * Added: gaim_buddy_get_contact_alias
2225         * Renamed: gaim_get_buddy_alias to gaim_buddy_get_alias
2226         * Renamed: gaim_get_buddy_alias_only to gaim_buddy_get_alias_only
2228         Conversation API:
2229         * Changed: gaim_conv_chat_add_user(), added flags parameter
2230         * Changed: gaim_conv_chat_add_users(), added GList of flags parameter
2231         * Changed: gaim_conv_chat_get_users(), now returns a GList of
2232           GaimConvChatBuddy's
2233         * Changed: gaim_conv_chat_set_users() now expects a GList of
2234           GaimConvChatBuddy's
2235         * Added: gaim_conv_chat_set_user_flags()
2236         * Added: gaim_conv_chat_get_user_flags()
2237         * Added: gaim_conv_chat_find_user()
2238         * Added: gaim_conv_chat_cb_new()
2239         * Added: gaim_conv_chat_cb_find()
2240         * Added: gaim_conv_chat_cb_destroy()
2241         * Added: gaim_conv_chat_cb_get_name()
2243         Conversation UI ops:
2244         * Added: chat_update_user()
2246         Signals:
2247         * Changed: chat-buddy-joining & chat-buddy-joined now include the user's flags
2248         * Changed: chat-buddy-joining & chat-buddy-leaving are now booleans, return
2249           TRUE if you don't want the join/leave to be displayed in the UI.
2250         * Added: chat-buddy-flags for when user's flags change
2251           gaim_marshal_VOID__POINTER_POINTER_POINTER_UINT_UINT (required for the new
2252           chat-buddy-flags signal)
2253         * Added: account-modified for when account settings have been changed.
2255 version 0.80 (07/15/2004):
2256         Gaim API:
2257         * Removed: PRPL numbers : gaim_account_set_protocol(),
2258           gaim_account_get_protocol(), gaim_accounts_find_with_prpl_num,
2259           gaim_prpl_num_to_id(), gaim_prpl_id_to_num(), GaimProtocol
2261         Protocol Plugin API: v6
2262         * Added: can_receive_file & send_file to the GaimPluginProtocolInfo struct
2264         Signals:
2265         * Changed "chat-invited" to also include the components hash table so
2266           plugins can use serv_join_chat when the signal is emitted.
2267         * Added "chat-topic-changed" signal plugins know when a topic is changed.
2269 version 0.79 (06/24/2004):
2270         Gaim API:
2271         * gaim_url_parse() now takes two additional parameters, which are used
2272           for returning the username and password from the URL, if they exist.
2273         * Added: has_focus UI op to GaimConversationUiOps and
2274           GaimConvWindowUiOps.
2275         * Added: gaim_conversation_has_focus() and gaim_conv_window_has_focus().
2276         * Removed: gaim_blist_save()
2278         Protocol Plugin API: v5
2279         * Changed: add_buddy, add_buddies, remove_buddy, remove_buddies,
2280           rename_group and remove_group to take GaimBuddy's and
2281           GaimGroup's consistently.
2282         * Removed: OPT_PROTO_BUDDY_ICON (replaced by icon_spec)
2283         * Added: icon_spec to the GaimPluginProtocolInfo struct
2285 version 0.78 (05/30/2004):
2286         Plugin API: v4
2287         * Added: actions - for plugins to add to the new Plugin Actions menu
2289         Loader Plugin API: v2 (no changes)
2291         Protocol Plugin API: v4
2292         * Removed: set_dir, get_dir and dir_search (not used, AIM-centric)
2293         * Removed: actions (replaced by generic plugin actions)
2295         Perl Plugin API: v2 (no changes)
2296         TCL Plugin API: (no changes)
2298         Signals:
2299         * Added: "blist-node-extended-menu" for extending Buddy, Chat and
2300                          Group right-click menus
2301         * Added: "drawing-tooltip" for plugins to allow plugins to change text
2302                          appearing in tooltips
2303         * Added: "gtkblist-created"
2304         * Added: "receiving-im-msg" and "receiving-chat-msg" (these behave
2305                           exactly like received-*-msg used to)
2306         * Added: "buddy-idle-updated" signal, for when the idle time changes.
2307         * Changed: "received-im-msg" and "received-chat-msg" no longer pass
2308                            pointers to who, message and flags, and are now void.
2309         * Removed: "drawing-menu" - it was UI sepecific and
2310                            "blist-node-extended-menu" is superior
2312 version 0.77 (04/22/2004):
2313         Loader & Protocol Plugins independantly versioned
2314         Plugin loading now checks versioning on plugins (Standard, Loader &
2315         Protocol)
2316         new GAIM_{PLUGIN,PRPL,LOADER}_API_VERSION constants
2318         Plugin API: v3
2319         * Added: prefs_info for UI independant plugin prefs
2321         Loader Plugin API: v2
2322         * Added: api_version at top of GaimPluginLoaderInfo struct
2324         Protocol Plugin API: v2
2325         * Added: api_version at top of GaimPluginProtocolInfo struct
2326         * Added: chat_menu for protocol specific extensions to the chat menu
2327         * Removed: get_away "Nada used it. Pink elephants on parade."
2328         * Removed: protocol_prefs (replaced by generic plugin prefs_info)
2330         Perl Plugin API: v2 (no changes)
2331         TCL API: (no changes)
2333         Signals:
2334         * Added: "conversation-drag-ended"
2336 version 0.76 (04/01/2004):
2337         Plugin API: v2
2338         Perl Plugin API: v2
2339         Loader Plugin API: (not versioned)
2340         Protocol Plugin API: (not versioned)
2341         * Added: protocol_prefs for protocol specific preferences
2342         * Added: reject_chat so protocols can act on chat invite rejection
2344         TCL Plugin API: (not versioned)
2345         * Changes to plugin registration to show descriptions