Added coordinates and house system as properties of GsweMoment

This commit is contained in:
Gergely Polonkai 2013-09-14 16:31:22 +02:00
parent 9247b755f0
commit 3d563f9af2

View File

@ -60,7 +60,9 @@ enum {
enum { enum {
PROP_0, PROP_0,
PROP_TIMESTAMP PROP_TIMESTAMP,
PROP_COORDINATES,
PROP_HOUSE_SYSTEM
}; };
struct GsweAspectFinder { struct GsweAspectFinder {
@ -104,6 +106,20 @@ gswe_moment_class_init(GsweMomentClass *klass)
* The timestamp associated with this moment * The timestamp associated with this moment
*/ */
g_object_class_install_property(gobject_class, PROP_TIMESTAMP, g_param_spec_object("timestamp", "Timestamp", "Timestamp of this moment", GSWE_TYPE_TIMESTAMP, G_PARAM_READWRITE)); g_object_class_install_property(gobject_class, PROP_TIMESTAMP, g_param_spec_object("timestamp", "Timestamp", "Timestamp of this moment", GSWE_TYPE_TIMESTAMP, G_PARAM_READWRITE));
/**
* GsweMoment:coordinates:
*
* The geographical coordinates associated with this moment
*/
g_object_class_install_property(gobject_class, PROP_COORDINATES, g_param_spec_boxed("coordinates", "Coordinates", "Geographical coordinates", GSWE_TYPE_COORDINATES, G_PARAM_READWRITE));
/**
* GsweMoment:house-system:
*
* The house system associated with this moment
*/
g_object_class_install_property(gobject_class, PROP_HOUSE_SYSTEM, g_param_spec_enum("house-system", "House System", "Astrological house system", GSWE_TYPE_HOUSE_SYSTEM, GSWE_HOUSE_SYSTEM_PLACIDUS, G_PARAM_READWRITE));
} }
static void static void
@ -173,6 +189,21 @@ gswe_moment_set_property(GObject *object, guint prop_id, const GValue *value, GP
break; break;
case PROP_COORDINATES:
{
GsweCoordinates *coords = g_value_get_boxed(value);
gswe_moment_set_coordinates(moment, coords->longitude, coords->latitude, coords->altitude);
}
break;
case PROP_HOUSE_SYSTEM:
gswe_moment_set_house_system(moment, g_value_get_enum(value));
break;
default: default:
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec); G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);
@ -192,6 +223,19 @@ gswe_moment_get_property(GObject *object, guint prop_id, GValue *value, GParamSp
break; break;
case PROP_COORDINATES:
{
GsweCoordinates *coords = gswe_coordinates_copy(&(priv->coordinates));
g_value_set_boxed(value, coords);
}
break;
case PROP_HOUSE_SYSTEM:
g_value_set_enum(value, priv->house_system);
break;
default: default:
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec); G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);
@ -1239,18 +1283,7 @@ gswe_planet_data_copy(GswePlanetData *planet_data)
return ret; return ret;
} }
/** G_DEFINE_BOXED_TYPE(GswePlanetData, gswe_planet_data, (GBoxedCopyFunc)gswe_planet_data_copy, (GBoxedFreeFunc)g_free);
* gswe_planet_data_get_type: (skip)
*
* Register the #GswePlanetData struct as a #GBoxedType. It is required for GObject Introspection. You should never need to call this directly.
*
* Returns: the newly registered type ID
*/
GType
gswe_planet_data_get_type(void)
{
return g_boxed_type_register_static("GswePlanetData", (GBoxedCopyFunc)gswe_planet_data_copy, (GBoxedFreeFunc)g_free);
}
static GsweCoordinates * static GsweCoordinates *
gswe_coordinates_copy(GsweCoordinates *coordinates) gswe_coordinates_copy(GsweCoordinates *coordinates)
@ -1264,16 +1297,5 @@ gswe_coordinates_copy(GsweCoordinates *coordinates)
return ret; return ret;
} }
/** G_DEFINE_BOXED_TYPE(GsweCoordinates, gswe_coordinates, (GBoxedCopyFunc)gswe_coordinates_copy, (GBoxedFreeFunc)g_free);
* gswe_coordinates_get_type:
*
* Register the #Gswecoordinates struct as a #GBoxedType. It is required for GObject Introspection. You should never need to call this directly.
*
* Returns: the newly registered type ID
*/
GType
gswe_coordinates_get_type(void)
{
return g_boxed_type_register_static("GsweCoordinates", (GBoxedCopyFunc)gswe_coordinates_copy, (GBoxedFreeFunc)g_free);
}