/*
* ggit-config-entry.c
* This file is part of libgit2-glib
*
* Copyright (C) 2012 - Ignacio Casal Quinteiro
*
* libgit2-glib 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.1 of the License, or (at your option) any later version.
*
* libgit2-glib 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 libgit2-glib. If not, see <http://www.gnu.org/licenses/>.
*/
#include "ggit-config-entry.h"
struct _GgitConfigEntry
{
const git_config_entry *entry;
gint ref_count;
};
G_DEFINE_BOXED_TYPE (GgitConfigEntry,
ggit_config_entry,
ggit_config_entry_ref,
ggit_config_entry_unref)
GgitConfigEntry *
_ggit_config_entry_wrap (const git_config_entry *entry)
{
GgitConfigEntry *ret;
ret = g_slice_new (GgitConfigEntry);
ret->entry = entry;
ret->ref_count = 1;
return ret;
}
/**
* ggit_config_entry_ref:
* @entry: a #GgitConfigEntry.
*
* Atomically increments the reference count of @entry by one.
* This function is MT-safe and may be called from any thread.
*
* Returns: (transfer none) (nullable): a #GgitConfigEntry or %NULL.
**/
GgitConfigEntry *
ggit_config_entry_ref (GgitConfigEntry *entry)
{
g_return_val_if_fail (entry != NULL, NULL);
g_atomic_int_inc (&entry->ref_count);
return entry;
}
/**
* ggit_config_entry_unref:
* @entry: a #GgitConfigEntry.
*
* Atomically decrements the reference count of @entry by one.
* If the reference count drops to 0, @entry is freed.
**/
void
ggit_config_entry_unref (GgitConfigEntry *entry)
{
g_return_if_fail (entry != NULL);
if (g_atomic_int_dec_and_test (&entry->ref_count))
{
g_slice_free (GgitConfigEntry, entry);
}
}
/**
* ggit_config_entry_get_name:
* @entry: a #GgitConfigEntry.
*
* Gets the name of @entry.
*
* Returns: (transfer none) (nullable): the name of @entry or %NULL.
*/
const gchar *
ggit_config_entry_get_name (GgitConfigEntry *entry)
{
g_return_val_if_fail (entry != NULL, NULL);
return entry->entry->name;
}
/**
* ggit_config_entry_get_value:
* @entry: a #GgitConfigEntry.
*
* Gets the value of @entry.
*
* Returns: (transfer none) (nullable): the value of @entry or %NULL.
*/
const gchar *
ggit_config_entry_get_value (GgitConfigEntry *entry)
{
g_return_val_if_fail (entry != NULL, NULL);
return entry->entry->value;
}
/**
* ggit_config_entry_get_level:
* @entry: a #GgitConfigEntry.
*
* Gets the #GgitConfigLevel of @entry.
*
* Returns: the #GgitConfigLevel of @entry.
*/
GgitConfigLevel
ggit_config_entry_get_level (GgitConfigEntry *entry)
{
g_return_val_if_fail (entry != NULL, 0);
return (GgitConfigLevel)entry->entry->level;
}
/* ex:set ts=8 noet: */