pidgin/pidgin

Display the preferences window as a singleton from the application

This is how we handle displaying other dialogs and apparently the preferences
window just got missed. We also make it transient for whatever window is active
which means it won't fill an entire cell in a tiling window manager.

Testing Done:
Opened the preferences dialog in i3 and verified it was no longer a full tile and that everything worked as expected.

Reviewed at https://reviews.imfreedom.org/r/2242/
/*
* finch
*
* Finch is the legal property of its developers, whose names are too numerous
* to list here. Please refer to the COPYRIGHT file distributed with this
* source distribution.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
*/
#if !defined(FINCH_GLOBAL_HEADER_INSIDE) && !defined(FINCH_COMPILATION)
# error "only <finch.h> may be included directly"
#endif
#ifndef FINCH_REQUEST_H
#define FINCH_REQUEST_H
#include <purple.h>
#include "gnt.h"
/**********************************************************************
* GNT Request API
**********************************************************************/
/**
* finch_request_get_ui_ops:
*
* Get the ui-functions.
*
* Returns: The PurpleRequestUiOps structure populated with the appropriate functions.
*/
PurpleRequestUiOps *finch_request_get_ui_ops(void);
/**
* finch_request_init:
*
* Perform necessary initializations.
*/
void finch_request_init(void);
/**
* finch_request_uninit:
*
* Perform necessary uninitializations.
*/
void finch_request_uninit(void);
/**
* finch_request_save_in_prefs:
* @data: No longer used, set to %NULL.
* @fields: The #PurpleRequestFields to save.
*
* Save the request fields in preferences where the id attribute of each field is the
* id of a preference.
*/
void finch_request_save_in_prefs(gpointer data, PurpleRequestFields *fields);
/**
* finch_request_field_get_widget:
* @field: The request field.
*
* Create a widget field for a request-field.
*
* Returns: (transfer full): A GntWidget for the request field.
*/
GntWidget *finch_request_field_get_widget(PurpleRequestField *field);
#endif /* FINCH_REQUEST_H */