Trac is being migrated to new services! Issues can be found in our new YouTrack instance and WIKI pages can be found on our website.

Version 23 (modified by MarkDoliner, 11 years ago) (diff)

I updated the description for Meebo earlier today. This change is just to fix a small typo. I'm also going to make this page not-read-only... it should be fine for non-admins to change this page. I think a lot of us monitor the wiki changes mailing list, so we'll notice bad edits.

What is libpurple?

libpurple is intended to be the core of an IM program. When using libpurple, you'll basically be writing a UI for this core chunk of code. Pidgin is a GTK+ frontend to libpurple, Finch is an ncurses frontend, and Adium is a Cocoa frontend.

Who uses libpurple?

  • Adium - A user-friendly graphical IM program for OS X.
  • EQO - An IM program for mobile phones.
  • Finch - A text-based IM program that works well in Linux and other Unixes.
  • Instantbird - A graphical IM program based on Mozilla's XUL framework.
  • Meebo - Provides a hosted XMPP IM solution to some large social networks via the Meebo Bar. The XMPP client is based on libpurple.
  • Palm - Maybe used in the messenger on the Palm Pre?
  • Pidgin - A user-friendly graphical IM program for Windows, Linux and other Unixes.
  • Spectrum - Open source XMPP transport/gateway.
  • Telepathy-Haze - A connection manager for the Telepathy IM framework.

How does it work?

You write a program in C or C++ that provides all the fancy windows and dialogs and anything that the user interacts with. Your program uses our libpurple library to connect to the IM networks, manage accounts and preferences, and lots of other helpful little things.

Your program registers a bunch of callback functions, called "UI ops," with libpurple. This is done by populating the appropriate uiops structures (eg. PurpleAccountUiOps, PurpleBlistUiOps, etc.) and making them available to the libpurple core (by calling purple_account_set_ui_ops, purple_blist_set_ui_ops, etc.). These ui ops are triggered by specific events. For example, the buddylist ui ops are used to update your buddylist window when a new buddy is added, or if a buddy goes away, or becomes idle, etc. The same thing happens for conversations, logging etc.

While the uiops are sufficient for most of the ui operations, it's likely that you will want to use various libpurple signals, as well.

Can you give me some details?

Your application will first initialize the core (purple_core_init), add plugin-search paths, load the saved plugins, prefs etc. Your best bet is to check out a copy of the source code and look at finch/finch.c:init_libpurple().

Is it threaded?

libpurple is not threadsafe. It should be accessed by an implementing UI only one thread ever (that is, do not attempt to use synchronization or locks to access it from multiple threads). Plugins can use multiple threads, but they must always call libpurple functions and callbacks on the thread on which they were initialized (typically the main thread of the program).

libpurple's run loop access occurs through eventloop.c; the UI must implement the UI Ops defined there and register them in order to watch sockets for new data and call timeout functions after a specified delay. For example, Pidgin uses the glib run loop, and Adium uses the Cocoa event run loop.

Where to get it?

You can find libpurple's source in Pidgin's source package.

All information, including names and email addresses, entered onto this website or sent to mailing lists affiliated with this website will be public. Do not post confidential information, especially passwords!