Testing Done:
Deleted the old `blist.xml` from my `XDG_CONFIG_HOME` and verified that I only got the new contacts and verified that they were not stored back to `blist.xml`.
Reviewed at https://reviews.imfreedom.org/r/2432/
/*
* purple
*
* Purple 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
*
*/
#ifdef HAVE_CONFIG_H
#include<config.h>
#endif /* HAVE_CONFIG_H */
#include<string.h>
#include<stdio.h>
#include<stdlib.h>
#include<sys/types.h>
#include<glib.h>
#include"prefs.h"
#include"debug.h"
#include"purplepath.h"
#include"util.h"
#ifdef _WIN32
#include"win32/win32dep.h"
#endif
struct_PurplePrefCallbackData{
PurplePrefCallbackfunc;
gpointerdata;
guintid;
void*handle;
void*ui_data;
char*name;
};
structpref_cb{
PurplePrefCallbackfunc;
gpointerdata;
guintid;
void*handle;
void*ui_data;
char*name;
};
/* TODO: This should use PurpleValues? */
structpurple_pref{
PurplePrefTypetype;
char*name;
union{
/* 'generic' is kind of ugly. We use it as an elegant way to refer to
the value of this pref when calling callback functions. We could
use 'boolean' or 'integer' or any other field... but it feels
mildly cleaner to use a gpointer. Maybe it would be best to use a