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