2011-10-15 14:56:47 +04:00
|
|
|
/*
|
|
|
|
GLIB - Library of useful routines for C programming
|
|
|
|
|
2017-01-01 17:33:11 +03:00
|
|
|
Copyright (C) 2009-2017
|
2014-02-12 10:33:10 +04:00
|
|
|
Free Software Foundation, Inc.
|
2009-10-21 23:18:03 +04:00
|
|
|
|
|
|
|
Written by:
|
2013-04-16 18:33:06 +04:00
|
|
|
Slava Zanko <slavazanko@gmail.com>, 2009, 2013.
|
2009-10-21 23:18:03 +04:00
|
|
|
|
|
|
|
This file is part of the Midnight Commander.
|
|
|
|
|
2011-10-15 14:56:47 +04:00
|
|
|
The Midnight Commander is free software: you can redistribute it
|
2009-10-21 23:18:03 +04:00
|
|
|
and/or modify it under the terms of the GNU General Public License as
|
2011-10-15 14:56:47 +04:00
|
|
|
published by the Free Software Foundation, either version 3 of the License,
|
|
|
|
or (at your option) any later version.
|
2009-10-21 23:18:03 +04:00
|
|
|
|
2011-10-15 14:56:47 +04:00
|
|
|
The Midnight Commander 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.
|
2009-10-21 23:18:03 +04:00
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2011-10-15 14:56:47 +04:00
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2010-11-08 13:21:45 +03:00
|
|
|
*/
|
2003-09-23 00:21:48 +04:00
|
|
|
|
2009-02-05 21:28:18 +03:00
|
|
|
/** \file glibcompat.c
|
2009-10-21 23:18:03 +04:00
|
|
|
* \brief Source: compatibility with older versions of glib
|
2009-02-05 21:28:18 +03:00
|
|
|
*
|
|
|
|
* Following code was copied from glib to GNU Midnight Commander to
|
|
|
|
* provide compatibility with older versions of glib.
|
2003-09-23 00:21:48 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
2013-04-16 18:33:06 +04:00
|
|
|
#include <string.h>
|
2005-02-08 12:04:03 +03:00
|
|
|
|
2005-10-04 19:20:10 +04:00
|
|
|
#include "global.h"
|
2003-09-23 00:21:48 +04:00
|
|
|
#include "glibcompat.h"
|
|
|
|
|
2009-10-21 23:18:03 +04:00
|
|
|
/*** global variables ****************************************************************************/
|
2003-09-23 00:21:48 +04:00
|
|
|
|
2009-10-21 23:18:03 +04:00
|
|
|
/*** file scope macro definitions ****************************************************************/
|
2003-09-23 00:21:48 +04:00
|
|
|
|
2009-10-21 23:18:03 +04:00
|
|
|
/*** file scope type declarations ****************************************************************/
|
2003-09-23 00:21:48 +04:00
|
|
|
|
2009-10-21 23:18:03 +04:00
|
|
|
/*** file scope variables ************************************************************************/
|
|
|
|
|
|
|
|
/*** file scope functions ************************************************************************/
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
2015-11-15 09:31:19 +03:00
|
|
|
/*** public functions ****************************************************************************/
|
2013-04-16 18:33:06 +04:00
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
2013-11-04 11:56:14 +04:00
|
|
|
|
|
|
|
#if ! GLIB_CHECK_VERSION (2, 28, 0)
|
|
|
|
/**
|
|
|
|
* g_slist_free_full:
|
|
|
|
* @list: a pointer to a #GSList
|
|
|
|
* @free_func: the function to be called to free each element's data
|
|
|
|
*
|
|
|
|
* Convenience method, which frees all the memory used by a #GSList, and
|
|
|
|
* calls the specified destroy function on every element's data.
|
|
|
|
*
|
|
|
|
* Since: 2.28
|
|
|
|
**/
|
|
|
|
void
|
|
|
|
g_slist_free_full (GSList * list, GDestroyNotify free_func)
|
|
|
|
{
|
|
|
|
g_slist_foreach (list, (GFunc) free_func, NULL);
|
|
|
|
g_slist_free (list);
|
|
|
|
}
|
2013-11-04 12:09:13 +04:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* g_list_free_full:
|
|
|
|
* @list: a pointer to a #GList
|
|
|
|
* @free_func: the function to be called to free each element's data
|
|
|
|
*
|
|
|
|
* Convenience method, which frees all the memory used by a #GList, and
|
|
|
|
* calls the specified destroy function on every element's data.
|
|
|
|
*
|
|
|
|
* Since: 2.28
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
g_list_free_full (GList * list, GDestroyNotify free_func)
|
|
|
|
{
|
|
|
|
g_list_foreach (list, (GFunc) free_func, NULL);
|
|
|
|
g_list_free (list);
|
|
|
|
}
|
|
|
|
|
2016-12-03 20:17:21 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------- */
|
|
|
|
|
2013-11-04 11:56:14 +04:00
|
|
|
#endif /* ! GLIB_CHECK_VERSION (2, 28, 0) */
|
|
|
|
|
2016-12-03 20:17:21 +03:00
|
|
|
#if ! GLIB_CHECK_VERSION (2, 32, 0)
|
|
|
|
/**
|
|
|
|
* g_queue_free_full:
|
|
|
|
* @queue: a pointer to a #GQueue
|
|
|
|
* @free_func: the function to be called to free each element's data
|
|
|
|
*
|
|
|
|
* Convenience method, which frees all the memory used by a #GQueue,
|
|
|
|
* and calls the specified destroy function on every element's data.
|
|
|
|
*
|
|
|
|
* Since: 2.32
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
g_queue_free_full (GQueue * queue, GDestroyNotify free_func)
|
|
|
|
{
|
|
|
|
g_queue_foreach (queue, (GFunc) free_func, NULL);
|
|
|
|
g_queue_free (queue);
|
|
|
|
}
|
|
|
|
#endif /* ! GLIB_CHECK_VERSION (2, 32, 0) */
|
|
|
|
|
2013-11-04 11:56:14 +04:00
|
|
|
/* --------------------------------------------------------------------------------------------- */
|