245 lines
6.6 KiB
C
245 lines
6.6 KiB
C
|
/* LIBPIKA - The PIKA Library
|
||
|
* Copyright (C) 1995-1997 Spencer Kimball and Peter Mattis
|
||
|
*
|
||
|
* pikabasetypes.c
|
||
|
* Copyright (C) 2004 Sven Neumann <sven@gimp.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 3 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, see
|
||
|
* <https://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
|
||
|
#include "config.h"
|
||
|
|
||
|
#include <glib-object.h>
|
||
|
|
||
|
#include "pikabasetypes.h"
|
||
|
|
||
|
|
||
|
/**
|
||
|
* SECTION: pikabasetypes
|
||
|
* @title: pikabasetypes
|
||
|
* @short_description: Translation between gettext translation domain
|
||
|
* identifier and GType.
|
||
|
*
|
||
|
* Translation between gettext translation domain identifier and
|
||
|
* GType.
|
||
|
**/
|
||
|
|
||
|
|
||
|
static GQuark pika_translation_domain_quark (void) G_GNUC_CONST;
|
||
|
static GQuark pika_translation_context_quark (void) G_GNUC_CONST;
|
||
|
static GQuark pika_value_descriptions_quark (void) G_GNUC_CONST;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* pika_type_set_translation_domain:
|
||
|
* @type: a #GType
|
||
|
* @domain: a constant string that identifies a translation domain or %NULL
|
||
|
*
|
||
|
* This function attaches a constant string as a gettext translation
|
||
|
* domain identifier to a #GType. The only purpose of this function is
|
||
|
* to use it when registering a #G_TYPE_ENUM with translatable value
|
||
|
* names.
|
||
|
*
|
||
|
* Since: 2.2
|
||
|
**/
|
||
|
void
|
||
|
pika_type_set_translation_domain (GType type,
|
||
|
const gchar *domain)
|
||
|
{
|
||
|
g_type_set_qdata (type,
|
||
|
pika_translation_domain_quark (), (gpointer) domain);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_type_get_translation_domain:
|
||
|
* @type: a #GType
|
||
|
*
|
||
|
* Retrieves the gettext translation domain identifier that has been
|
||
|
* previously set using pika_type_set_translation_domain(). You should
|
||
|
* not need to use this function directly, use pika_enum_get_value()
|
||
|
* or pika_enum_value_get_desc() instead.
|
||
|
*
|
||
|
* Returns: the translation domain associated with @type
|
||
|
* or %NULL if no domain was set
|
||
|
*
|
||
|
* Since: 2.2
|
||
|
**/
|
||
|
const gchar *
|
||
|
pika_type_get_translation_domain (GType type)
|
||
|
{
|
||
|
return (const gchar *) g_type_get_qdata (type,
|
||
|
pika_translation_domain_quark ());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_type_set_translation_context:
|
||
|
* @type: a #GType
|
||
|
* @context: a constant string that identifies a translation context or %NULL
|
||
|
*
|
||
|
* This function attaches a constant string as a translation context
|
||
|
* to a #GType. The only purpose of this function is to use it when
|
||
|
* registering a #G_TYPE_ENUM with translatable value names.
|
||
|
*
|
||
|
* Since: 2.8
|
||
|
**/
|
||
|
void
|
||
|
pika_type_set_translation_context (GType type,
|
||
|
const gchar *context)
|
||
|
{
|
||
|
g_type_set_qdata (type,
|
||
|
pika_translation_context_quark (), (gpointer) context);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_type_get_translation_context:
|
||
|
* @type: a #GType
|
||
|
*
|
||
|
* Retrieves the translation context that has been previously set
|
||
|
* using pika_type_set_translation_context(). You should not need to
|
||
|
* use this function directly, use pika_enum_get_value() or
|
||
|
* pika_enum_value_get_desc() instead.
|
||
|
*
|
||
|
* Returns: the translation context associated with @type
|
||
|
* or %NULL if no context was set
|
||
|
*
|
||
|
* Since: 2.8
|
||
|
**/
|
||
|
const gchar *
|
||
|
pika_type_get_translation_context (GType type)
|
||
|
{
|
||
|
return (const gchar *) g_type_get_qdata (type,
|
||
|
pika_translation_context_quark ());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_enum_set_value_descriptions:
|
||
|
* @enum_type: a #GType
|
||
|
* @descriptions: a %NULL terminated constant static array of #PikaEnumDesc
|
||
|
*
|
||
|
* Sets the array of human readable and translatable descriptions
|
||
|
* and help texts for enum values.
|
||
|
*
|
||
|
* Since: 2.2
|
||
|
**/
|
||
|
void
|
||
|
pika_enum_set_value_descriptions (GType enum_type,
|
||
|
const PikaEnumDesc *descriptions)
|
||
|
{
|
||
|
g_return_if_fail (g_type_is_a (enum_type, G_TYPE_ENUM));
|
||
|
g_return_if_fail (descriptions != NULL);
|
||
|
|
||
|
g_type_set_qdata (enum_type,
|
||
|
pika_value_descriptions_quark (),
|
||
|
(gpointer) descriptions);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_enum_get_value_descriptions:
|
||
|
* @enum_type: a #GType
|
||
|
*
|
||
|
* Retrieves the array of human readable and translatable descriptions
|
||
|
* and help texts for enum values.
|
||
|
*
|
||
|
* Returns: a %NULL terminated constant array of #PikaEnumDesc
|
||
|
*
|
||
|
* Since: 2.2
|
||
|
**/
|
||
|
const PikaEnumDesc *
|
||
|
pika_enum_get_value_descriptions (GType enum_type)
|
||
|
{
|
||
|
g_return_val_if_fail (g_type_is_a (enum_type, G_TYPE_ENUM), NULL);
|
||
|
|
||
|
return (const PikaEnumDesc *)
|
||
|
g_type_get_qdata (enum_type, pika_value_descriptions_quark ());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_flags_set_value_descriptions:
|
||
|
* @flags_type: a #GType
|
||
|
* @descriptions: a %NULL terminated constant static array of #PikaFlagsDesc
|
||
|
*
|
||
|
* Sets the array of human readable and translatable descriptions
|
||
|
* and help texts for flags values.
|
||
|
*
|
||
|
* Since: 2.2
|
||
|
**/
|
||
|
void
|
||
|
pika_flags_set_value_descriptions (GType flags_type,
|
||
|
const PikaFlagsDesc *descriptions)
|
||
|
{
|
||
|
g_return_if_fail (g_type_is_a (flags_type, G_TYPE_FLAGS));
|
||
|
g_return_if_fail (descriptions != NULL);
|
||
|
|
||
|
g_type_set_qdata (flags_type,
|
||
|
pika_value_descriptions_quark (),
|
||
|
(gpointer) descriptions);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* pika_flags_get_value_descriptions:
|
||
|
* @flags_type: a #GType
|
||
|
*
|
||
|
* Retrieves the array of human readable and translatable descriptions
|
||
|
* and help texts for flags values.
|
||
|
*
|
||
|
* Returns: a %NULL terminated constant array of #PikaFlagsDesc
|
||
|
*
|
||
|
* Since: 2.2
|
||
|
**/
|
||
|
const PikaFlagsDesc *
|
||
|
pika_flags_get_value_descriptions (GType flags_type)
|
||
|
{
|
||
|
g_return_val_if_fail (g_type_is_a (flags_type, G_TYPE_FLAGS), NULL);
|
||
|
|
||
|
return (const PikaFlagsDesc *)
|
||
|
g_type_get_qdata (flags_type, pika_value_descriptions_quark ());
|
||
|
}
|
||
|
|
||
|
|
||
|
/* private functions */
|
||
|
|
||
|
static GQuark
|
||
|
pika_translation_domain_quark (void)
|
||
|
{
|
||
|
static GQuark quark = 0;
|
||
|
|
||
|
if (! quark)
|
||
|
quark = g_quark_from_static_string ("pika-translation-domain-quark");
|
||
|
|
||
|
return quark;
|
||
|
}
|
||
|
|
||
|
static GQuark
|
||
|
pika_translation_context_quark (void)
|
||
|
{
|
||
|
static GQuark quark = 0;
|
||
|
|
||
|
if (! quark)
|
||
|
quark = g_quark_from_static_string ("pika-translation-context-quark");
|
||
|
|
||
|
return quark;
|
||
|
}
|
||
|
|
||
|
static GQuark
|
||
|
pika_value_descriptions_quark (void)
|
||
|
{
|
||
|
static GQuark quark = 0;
|
||
|
|
||
|
if (! quark)
|
||
|
quark = g_quark_from_static_string ("pika-value-descriptions-quark");
|
||
|
|
||
|
return quark;
|
||
|
}
|