grim/guifications2

This was compatibility code for Pidgin 1.x.y; because it was written as a check
for "not 2.0.0" this code would be compiled in for 3.0.0. It looks like the
supporting code elsewhere was removed, causing this to leave an unresolved
symbol in guifications.so, thus causing Pidgin to refuse to load. Now we load
in Pidgin 3.0.0. Whether it works or not, I have no clue.
/*
* Guifications - The end all, be all, toaster popup plugin
* Copyright (C) 2003-2008 Gary Kramlich
*
* 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.
*/
#include <stdio.h>
/* MinGW has unistd.h!!! */
#include <unistd.h>
#ifdef HAVE_CONFIG_H
# include "../gf_config.h"
#endif
#include "gf_file.h"
#include "gf_internal.h"
gboolean
gf_file_copy_file(const gchar *source, const gchar *destination) {
FILE *src, *dest;
gint chr = EOF;
if(!(src = g_fopen(source, "rb")))
return FALSE;
if(!(dest = g_fopen(destination, "wb"))) {
fclose(src);
return FALSE;
}
while((chr = fgetc(src)) != EOF) {
fputc(chr, dest);
}
fclose(dest);
fclose(src);
return TRUE;
}
gboolean
gf_file_copy_directory(const gchar *source, const gchar *destination) {
GDir *dir;
const gchar *filename;
gchar *oldfile, *newfile;
g_return_val_if_fail(source, FALSE);
g_return_val_if_fail(destination, FALSE);
dir = g_dir_open(source, 0, NULL);
if(!dir)
return FALSE;
while((filename = g_dir_read_name(dir))) {
oldfile = g_build_filename(source, filename, NULL);
newfile = g_build_filename(destination, filename, NULL);
gf_file_copy_file(oldfile, newfile);
g_free(oldfile);
g_free(newfile);
}
g_dir_close(dir);
return TRUE;
}
void
gf_file_remove_dir(const gchar *directory) {
GDir *dir;
gchar *path;
const gchar *file = NULL;
g_return_if_fail(directory);
dir = g_dir_open(directory, 0, NULL);
while((file = g_dir_read_name(dir))) {
path = g_build_filename(directory, file, NULL);
g_remove(path);
g_free(path);
}
g_dir_close(dir);
g_rmdir(directory);
}
gint
gf_file_access(const gchar *filename, gint mode) {
#ifdef _WIN32
return _access(filename, mode);
#else
return access(filename, mode);
#endif
}