Hard require GLib 2.34
Anyone wanting to build against an earlier version can use the embedded-dependencies system.
This commit is contained in:
parent
464f4a81c9
commit
da43fb6db5
|
|
@ -33,8 +33,6 @@ libotutil_la_SOURCES = \
|
||||||
src/libotutil/ot-variant-utils.h \
|
src/libotutil/ot-variant-utils.h \
|
||||||
src/libotutil/ot-gio-utils.c \
|
src/libotutil/ot-gio-utils.c \
|
||||||
src/libotutil/ot-gio-utils.h \
|
src/libotutil/ot-gio-utils.h \
|
||||||
src/libotutil/ot-glib-compat.c \
|
|
||||||
src/libotutil/ot-glib-compat.h \
|
|
||||||
src/libotutil/otutil.c \
|
src/libotutil/otutil.c \
|
||||||
src/libotutil/otutil.h \
|
src/libotutil/otutil.h \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
|
||||||
|
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
||||||
AM_CPPFLAGS = -DDATADIR='"$(datadir)"' -DLIBEXECDIR='"$(libexecdir)"' \
|
AM_CPPFLAGS = -DDATADIR='"$(datadir)"' -DLIBEXECDIR='"$(libexecdir)"' \
|
||||||
-DGLIB_VERSION_MIN_REQUIRED=GLIB_VERSION_2_28 -DGLIB_VERSION_MAX_ALLOWED=GLIB_VERSION_2_28
|
-DGLIB_VERSION_MIN_REQUIRED=GLIB_VERSION_2_34 -DGLIB_VERSION_MAX_ALLOWED=GLIB_VERSION_2_34
|
||||||
AM_CFLAGS = $(WARN_CFLAGS)
|
AM_CFLAGS = $(WARN_CFLAGS)
|
||||||
|
|
||||||
if BUILD_EMBEDDED_DEPENDENCIES
|
if BUILD_EMBEDDED_DEPENDENCIES
|
||||||
|
|
|
||||||
|
|
@ -39,7 +39,7 @@ if test x$enable_embedded_dependencies = xyes; then
|
||||||
echo "NOTICE: Embedded dependencies (GLib and libsoup) enabled"
|
echo "NOTICE: Embedded dependencies (GLib and libsoup) enabled"
|
||||||
with_soup=yes
|
with_soup=yes
|
||||||
else
|
else
|
||||||
GIO_DEPENDENCY="gio-unix-2.0 >= 2.28"
|
GIO_DEPENDENCY="gio-unix-2.0 >= 2.33.4"
|
||||||
PKG_CHECK_MODULES(OT_DEP_GIO_UNIX, $GIO_DEPENDENCY)
|
PKG_CHECK_MODULES(OT_DEP_GIO_UNIX, $GIO_DEPENDENCY)
|
||||||
|
|
||||||
SOUP_DEPENDENCY="libsoup-2.4 >= 2.39.1"
|
SOUP_DEPENDENCY="libsoup-2.4 >= 2.39.1"
|
||||||
|
|
|
||||||
|
|
@ -120,7 +120,7 @@ ostree_repo_finalize (GObject *object)
|
||||||
ot_clear_ptrarray (&self->cached_content_indexes);
|
ot_clear_ptrarray (&self->cached_content_indexes);
|
||||||
g_hash_table_destroy (self->cached_pack_index_mappings);
|
g_hash_table_destroy (self->cached_pack_index_mappings);
|
||||||
g_hash_table_destroy (self->cached_pack_data_mappings);
|
g_hash_table_destroy (self->cached_pack_data_mappings);
|
||||||
ot_mutex_free (self->cache_lock);
|
g_mutex_clear (&self->cache_lock);
|
||||||
|
|
||||||
G_OBJECT_CLASS (ostree_repo_parent_class)->finalize (object);
|
G_OBJECT_CLASS (ostree_repo_parent_class)->finalize (object);
|
||||||
}
|
}
|
||||||
|
|
@ -214,7 +214,7 @@ ostree_repo_class_init (OstreeRepoClass *klass)
|
||||||
static void
|
static void
|
||||||
ostree_repo_init (OstreeRepo *self)
|
ostree_repo_init (OstreeRepo *self)
|
||||||
{
|
{
|
||||||
ot_mutex_init (self->cache_lock);
|
g_mutex_init (&self->cache_lock);
|
||||||
self->cached_pack_index_mappings = g_hash_table_new_full (g_str_hash, g_str_equal,
|
self->cached_pack_index_mappings = g_hash_table_new_full (g_str_hash, g_str_equal,
|
||||||
g_free,
|
g_free,
|
||||||
(GDestroyNotify)g_variant_unref);
|
(GDestroyNotify)g_variant_unref);
|
||||||
|
|
@ -1924,7 +1924,7 @@ ostree_repo_list_pack_indexes (OstreeRepo *self,
|
||||||
ot_lptrarray GPtrArray *ret_meta_indexes = NULL;
|
ot_lptrarray GPtrArray *ret_meta_indexes = NULL;
|
||||||
ot_lptrarray GPtrArray *ret_data_indexes = NULL;
|
ot_lptrarray GPtrArray *ret_data_indexes = NULL;
|
||||||
|
|
||||||
ot_mutex_lock (self->cache_lock);
|
g_mutex_lock (&self->cache_lock);
|
||||||
if (self->cached_meta_indexes)
|
if (self->cached_meta_indexes)
|
||||||
{
|
{
|
||||||
ret_meta_indexes = g_ptr_array_ref (self->cached_meta_indexes);
|
ret_meta_indexes = g_ptr_array_ref (self->cached_meta_indexes);
|
||||||
|
|
@ -1955,7 +1955,7 @@ ostree_repo_list_pack_indexes (OstreeRepo *self,
|
||||||
ot_transfer_out_value (out_meta_indexes, &ret_meta_indexes);
|
ot_transfer_out_value (out_meta_indexes, &ret_meta_indexes);
|
||||||
ot_transfer_out_value (out_data_indexes, &ret_data_indexes);
|
ot_transfer_out_value (out_data_indexes, &ret_data_indexes);
|
||||||
out:
|
out:
|
||||||
ot_mutex_unlock (self->cache_lock);
|
g_mutex_unlock (&self->cache_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -3392,7 +3392,7 @@ ostree_repo_load_pack_index (OstreeRepo *self,
|
||||||
ot_lvariant GVariant *ret_variant = NULL;
|
ot_lvariant GVariant *ret_variant = NULL;
|
||||||
ot_lobj GFile *path = NULL;
|
ot_lobj GFile *path = NULL;
|
||||||
|
|
||||||
ot_mutex_lock (self->cache_lock);
|
g_mutex_lock (&self->cache_lock);
|
||||||
|
|
||||||
ret_variant = g_hash_table_lookup (self->cached_pack_index_mappings, pack_checksum);
|
ret_variant = g_hash_table_lookup (self->cached_pack_index_mappings, pack_checksum);
|
||||||
if (ret_variant)
|
if (ret_variant)
|
||||||
|
|
@ -3415,7 +3415,7 @@ ostree_repo_load_pack_index (OstreeRepo *self,
|
||||||
ret = TRUE;
|
ret = TRUE;
|
||||||
ot_transfer_out_value (out_variant, &ret_variant);
|
ot_transfer_out_value (out_variant, &ret_variant);
|
||||||
out:
|
out:
|
||||||
ot_mutex_unlock (self->cache_lock);
|
g_mutex_unlock (&self->cache_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -3441,7 +3441,7 @@ ostree_repo_map_pack_file (OstreeRepo *self,
|
||||||
GMappedFile *map = NULL;
|
GMappedFile *map = NULL;
|
||||||
ot_lobj GFile *path = NULL;
|
ot_lobj GFile *path = NULL;
|
||||||
|
|
||||||
ot_mutex_lock (self->cache_lock);
|
g_mutex_lock (&self->cache_lock);
|
||||||
|
|
||||||
map = g_hash_table_lookup (self->cached_pack_data_mappings, pack_checksum);
|
map = g_hash_table_lookup (self->cached_pack_data_mappings, pack_checksum);
|
||||||
if (map == NULL)
|
if (map == NULL)
|
||||||
|
|
@ -3465,7 +3465,7 @@ ostree_repo_map_pack_file (OstreeRepo *self,
|
||||||
if (out_len)
|
if (out_len)
|
||||||
*out_len = ret_len;
|
*out_len = ret_len;
|
||||||
out:
|
out:
|
||||||
ot_mutex_unlock (self->cache_lock);
|
g_mutex_unlock (&self->cache_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,160 +0,0 @@
|
||||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*-
|
|
||||||
*
|
|
||||||
* Copyright (C) 2011 Colin Walters <walters@verbum.org>
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library 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
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
* Boston, MA 02111-1307, USA.
|
|
||||||
*
|
|
||||||
* Author: Colin Walters <walters@verbum.org>
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
|
|
||||||
#include <gio/gio.h>
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "otutil.h"
|
|
||||||
|
|
||||||
#if GLIB_CHECK_VERSION(2,32,0) && !defined(OSTREE_GLIB_TARGET_MIN)
|
|
||||||
/* nothing */
|
|
||||||
#else
|
|
||||||
/* Code copied from glib/glib/genviron.c */
|
|
||||||
/* GLIB - Library of useful routines for C programming
|
|
||||||
* Copyright (C) 1995-1998 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library 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
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
* Boston, MA 02111-1307, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Modified by the GLib Team and others 1997-2000. See the AUTHORS
|
|
||||||
* file for a list of people on the GLib Team. See the ChangeLog
|
|
||||||
* files for a list of changes. These files are distributed with
|
|
||||||
* GLib at ftp://ftp.gtk.org/pub/gtk/.
|
|
||||||
*/
|
|
||||||
|
|
||||||
static gint
|
|
||||||
ot_g_environ_find (gchar **envp,
|
|
||||||
const gchar *variable)
|
|
||||||
{
|
|
||||||
gint len, i;
|
|
||||||
|
|
||||||
len = strlen (variable);
|
|
||||||
|
|
||||||
for (i = 0; envp[i]; i++)
|
|
||||||
{
|
|
||||||
if (strncmp (envp[i], variable, len) == 0 &&
|
|
||||||
envp[i][len] == '=')
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
const gchar *
|
|
||||||
ot_g_environ_getenv (gchar **envp,
|
|
||||||
const gchar *variable)
|
|
||||||
{
|
|
||||||
gint index;
|
|
||||||
|
|
||||||
g_return_val_if_fail (envp != NULL, NULL);
|
|
||||||
g_return_val_if_fail (variable != NULL, NULL);
|
|
||||||
|
|
||||||
index = ot_g_environ_find (envp, variable);
|
|
||||||
if (index != -1)
|
|
||||||
return envp[index] + strlen (variable) + 1;
|
|
||||||
else
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
gchar **
|
|
||||||
ot_g_environ_setenv (gchar **envp,
|
|
||||||
const gchar *variable,
|
|
||||||
const gchar *value,
|
|
||||||
gboolean overwrite)
|
|
||||||
{
|
|
||||||
gint index;
|
|
||||||
|
|
||||||
g_return_val_if_fail (envp != NULL, NULL);
|
|
||||||
g_return_val_if_fail (variable != NULL, NULL);
|
|
||||||
g_return_val_if_fail (strchr (variable, '=') == NULL, NULL);
|
|
||||||
|
|
||||||
index = ot_g_environ_find (envp, variable);
|
|
||||||
if (index != -1)
|
|
||||||
{
|
|
||||||
if (overwrite)
|
|
||||||
{
|
|
||||||
g_free (envp[index]);
|
|
||||||
envp[index] = g_strdup_printf ("%s=%s", variable, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
gint length;
|
|
||||||
|
|
||||||
length = g_strv_length (envp);
|
|
||||||
envp = g_renew (gchar *, envp, length + 2);
|
|
||||||
envp[length] = g_strdup_printf ("%s=%s", variable, value);
|
|
||||||
envp[length + 1] = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return envp;
|
|
||||||
}
|
|
||||||
|
|
||||||
gchar **
|
|
||||||
ot_g_environ_unsetenv (gchar **envp,
|
|
||||||
const gchar *variable)
|
|
||||||
{
|
|
||||||
gint len;
|
|
||||||
gchar **e, **f;
|
|
||||||
|
|
||||||
g_return_val_if_fail (envp != NULL, NULL);
|
|
||||||
g_return_val_if_fail (variable != NULL, NULL);
|
|
||||||
g_return_val_if_fail (strchr (variable, '=') == NULL, NULL);
|
|
||||||
|
|
||||||
len = strlen (variable);
|
|
||||||
|
|
||||||
/* Note that we remove *all* environment entries for
|
|
||||||
* the variable name, not just the first.
|
|
||||||
*/
|
|
||||||
e = f = envp;
|
|
||||||
while (*e != NULL)
|
|
||||||
{
|
|
||||||
if (strncmp (*e, variable, len) != 0 || (*e)[len] != '=')
|
|
||||||
{
|
|
||||||
*f = *e;
|
|
||||||
f++;
|
|
||||||
}
|
|
||||||
e++;
|
|
||||||
}
|
|
||||||
*f = NULL;
|
|
||||||
|
|
||||||
return envp;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
@ -1,64 +0,0 @@
|
||||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*-
|
|
||||||
*
|
|
||||||
* Copyright (C) 2011 Colin Walters <walters@verbum.org>.
|
|
||||||
*
|
|
||||||
* This library is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
|
||||||
* License as published by the Free Software Foundation; either
|
|
||||||
* version 2 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This library 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
|
|
||||||
* Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public
|
|
||||||
* License along with this library; if not, write to the
|
|
||||||
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
||||||
* Boston, MA 02111-1307, USA.
|
|
||||||
*
|
|
||||||
* Author: Colin Walters <walters@verbum.org>
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __OSTREE_GLIB_COMPAT_H__
|
|
||||||
#define __OSTREE_GLIB_COMPAT_H__
|
|
||||||
|
|
||||||
#include <gio/gio.h>
|
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
|
||||||
|
|
||||||
#if GLIB_CHECK_VERSION(2,32,0) && !defined(OSTREE_GLIB_TARGET_MIN)
|
|
||||||
#define ot_g_environ_getenv g_environ_getenv
|
|
||||||
#define ot_g_environ_setenv g_environ_setenv
|
|
||||||
#define ot_g_environ_unsetenv g_environ_unsetenv
|
|
||||||
|
|
||||||
#define ot_mutex_init(v) do { g_mutex_init (&(v)); } while (0);
|
|
||||||
#define ot_mutex_free(v) do { g_mutex_clear (&(v)); } while (0);
|
|
||||||
#define ot_mutex_lock(v) do { g_mutex_lock (&(v)); } while (0);
|
|
||||||
#define ot_mutex_unlock(v) do { g_mutex_unlock (&(v)); } while (0);
|
|
||||||
|
|
||||||
#else
|
|
||||||
const gchar *
|
|
||||||
ot_g_environ_getenv (gchar **envp,
|
|
||||||
const gchar *variable);
|
|
||||||
|
|
||||||
gchar **
|
|
||||||
ot_g_environ_setenv (gchar **envp,
|
|
||||||
const gchar *variable,
|
|
||||||
const gchar *value,
|
|
||||||
gboolean overwrite);
|
|
||||||
|
|
||||||
gchar **
|
|
||||||
ot_g_environ_unsetenv (gchar **envp,
|
|
||||||
const gchar *variable);
|
|
||||||
|
|
||||||
#define ot_mutex_init(v) do { v = g_mutex_new (); } while (0);
|
|
||||||
#define ot_mutex_free(v) do { g_mutex_free (v); } while (0);
|
|
||||||
#define ot_mutex_lock(v) do { g_mutex_lock (v); } while (0);
|
|
||||||
#define ot_mutex_unlock(v) do { g_mutex_unlock (v); } while (0);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
G_END_DECLS
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
@ -45,7 +45,6 @@
|
||||||
|
|
||||||
#include <ot-local-alloc.h>
|
#include <ot-local-alloc.h>
|
||||||
#include <ot-gio-utils.h>
|
#include <ot-gio-utils.h>
|
||||||
#include <ot-glib-compat.h>
|
|
||||||
#include <ot-opt-utils.h>
|
#include <ot-opt-utils.h>
|
||||||
#include <ot-unix-utils.h>
|
#include <ot-unix-utils.h>
|
||||||
#include <ot-variant-utils.h>
|
#include <ot-variant-utils.h>
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue