mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2024-12-26 07:26:15 +01:00
gdate: add g_date_copy()
This will allow passing invalid GDates through GValues. https://bugzilla.gnome.org/show_bug.cgi?id=760109
This commit is contained in:
parent
652a47d1d1
commit
5564ddef12
@ -1551,6 +1551,7 @@ g_date_new_dmy
|
|||||||
g_date_new_julian
|
g_date_new_julian
|
||||||
g_date_clear
|
g_date_clear
|
||||||
g_date_free
|
g_date_free
|
||||||
|
g_date_copy
|
||||||
|
|
||||||
<SUBSECTION>
|
<SUBSECTION>
|
||||||
g_date_set_day
|
g_date_set_day
|
||||||
|
29
glib/gdate.c
29
glib/gdate.c
@ -342,6 +342,35 @@ g_date_free (GDate *date)
|
|||||||
g_free (date);
|
g_free (date);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* g_date_copy:
|
||||||
|
* @date: a #GDate to copy
|
||||||
|
*
|
||||||
|
* Copies a GDate to a newly-allocated GDate. If the input was invalid
|
||||||
|
* (as determined by g_date_valid()), the invalid state will be copied
|
||||||
|
* as is into the new object.
|
||||||
|
*
|
||||||
|
* Returns: (transfer full): a newly-allocated #GDate initialized from @date
|
||||||
|
*
|
||||||
|
* Since: 2.56
|
||||||
|
*/
|
||||||
|
GDate *
|
||||||
|
g_date_copy (const GDate *date)
|
||||||
|
{
|
||||||
|
GDate *res;
|
||||||
|
g_return_val_if_fail (date != NULL, NULL);
|
||||||
|
|
||||||
|
if (g_date_valid (date))
|
||||||
|
res = g_date_new_julian (g_date_get_julian (date));
|
||||||
|
else
|
||||||
|
{
|
||||||
|
res = g_date_new ();
|
||||||
|
*res = *date;
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_date_valid:
|
* g_date_valid:
|
||||||
* @date: a #GDate to check
|
* @date: a #GDate to check
|
||||||
|
@ -127,6 +127,8 @@ GLIB_AVAILABLE_IN_ALL
|
|||||||
GDate* g_date_new_julian (guint32 julian_day);
|
GDate* g_date_new_julian (guint32 julian_day);
|
||||||
GLIB_AVAILABLE_IN_ALL
|
GLIB_AVAILABLE_IN_ALL
|
||||||
void g_date_free (GDate *date);
|
void g_date_free (GDate *date);
|
||||||
|
GLIB_AVAILABLE_IN_2_56
|
||||||
|
GDate* g_date_copy (const GDate *date);
|
||||||
|
|
||||||
/* check g_date_valid() after doing an operation that might fail, like
|
/* check g_date_valid() after doing an operation that might fail, like
|
||||||
* _parse. Almost all g_date operations are undefined on invalid
|
* _parse. Almost all g_date operations are undefined on invalid
|
||||||
|
@ -357,6 +357,32 @@ test_order (void)
|
|||||||
g_assert (g_date_compare (&d1, &d2) == 1);
|
g_assert (g_date_compare (&d1, &d2) == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_copy (void)
|
||||||
|
{
|
||||||
|
GDate *d;
|
||||||
|
GDate *c;
|
||||||
|
|
||||||
|
d = g_date_new ();
|
||||||
|
g_assert_false (g_date_valid (d));
|
||||||
|
|
||||||
|
c = g_date_copy (d);
|
||||||
|
g_assert_nonnull (c);
|
||||||
|
g_assert_false (g_date_valid (c));
|
||||||
|
g_date_free (c);
|
||||||
|
|
||||||
|
g_date_set_day (d, 10);
|
||||||
|
|
||||||
|
c = g_date_copy (d);
|
||||||
|
g_date_set_month (c, 1);
|
||||||
|
g_date_set_year (c, 2015);
|
||||||
|
g_assert_true (g_date_valid (c));
|
||||||
|
g_assert_cmpuint (g_date_get_day (c), ==, 10);
|
||||||
|
g_date_free (c);
|
||||||
|
|
||||||
|
g_date_free (d);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char** argv)
|
main (int argc, char** argv)
|
||||||
{
|
{
|
||||||
@ -401,6 +427,7 @@ main (int argc, char** argv)
|
|||||||
g_test_add_data_func (path, GINT_TO_POINTER(check_years[i]), test_year);
|
g_test_add_data_func (path, GINT_TO_POINTER(check_years[i]), test_year);
|
||||||
g_free (path);
|
g_free (path);
|
||||||
}
|
}
|
||||||
|
g_test_add_func ("/date/copy", test_copy);
|
||||||
|
|
||||||
return g_test_run ();
|
return g_test_run ();
|
||||||
}
|
}
|
||||||
|
@ -109,12 +109,6 @@ _g_boxed_type_init (void)
|
|||||||
g_assert (type == G_TYPE_BOXED);
|
g_assert (type == G_TYPE_BOXED);
|
||||||
}
|
}
|
||||||
|
|
||||||
static GDate *
|
|
||||||
gdate_copy (GDate *date)
|
|
||||||
{
|
|
||||||
return g_date_new_julian (g_date_get_julian (date));
|
|
||||||
}
|
|
||||||
|
|
||||||
static GString *
|
static GString *
|
||||||
gstring_copy (GString *src_gstring)
|
gstring_copy (GString *src_gstring)
|
||||||
{
|
{
|
||||||
@ -130,7 +124,7 @@ gstring_free (GString *gstring)
|
|||||||
G_DEFINE_BOXED_TYPE (GClosure, g_closure, g_closure_ref, g_closure_unref)
|
G_DEFINE_BOXED_TYPE (GClosure, g_closure, g_closure_ref, g_closure_unref)
|
||||||
G_DEFINE_BOXED_TYPE (GValue, g_value, value_copy, value_free)
|
G_DEFINE_BOXED_TYPE (GValue, g_value, value_copy, value_free)
|
||||||
G_DEFINE_BOXED_TYPE (GValueArray, g_value_array, g_value_array_copy, g_value_array_free)
|
G_DEFINE_BOXED_TYPE (GValueArray, g_value_array, g_value_array_copy, g_value_array_free)
|
||||||
G_DEFINE_BOXED_TYPE (GDate, g_date, gdate_copy, g_date_free)
|
G_DEFINE_BOXED_TYPE (GDate, g_date, g_date_copy, g_date_free)
|
||||||
/* the naming is a bit odd, but GString is obviously not G_TYPE_STRING */
|
/* the naming is a bit odd, but GString is obviously not G_TYPE_STRING */
|
||||||
G_DEFINE_BOXED_TYPE (GString, g_gstring, gstring_copy, gstring_free)
|
G_DEFINE_BOXED_TYPE (GString, g_gstring, gstring_copy, gstring_free)
|
||||||
G_DEFINE_BOXED_TYPE (GHashTable, g_hash_table, g_hash_table_ref, g_hash_table_unref)
|
G_DEFINE_BOXED_TYPE (GHashTable, g_hash_table, g_hash_table_ref, g_hash_table_unref)
|
||||||
|
Loading…
Reference in New Issue
Block a user