1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263
|
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
* Copyright (C) 2001-2003 CodeFactory AB
* Copyright (C) 2001-2003 Richard Hult <richard@imendio.com>
* Copyright (C) 2001-2002 Mikael Hallendal <micke@imendio.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU 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
* General Public License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
/**
* SECTION:mrp-assignment
* @Short_Description: assigning resources to tasks.
* @Title: MrpAssignment
* @include: libplanner/mrp-assignment.h
*
* Resources are assigned to tasks.
* #MrpAssignment implements the association between #MrpTask and #MrpResource.
* The association is pounded.
*/
#include <config.h>
#include <glib/gi18n.h>
#include "mrp-task.h"
#include "mrp-resource.h"
#include "mrp-marshal.h"
#include "mrp-assignment.h"
struct _MrpAssignment
{
MrpObject parent_instance;
};
typedef struct {
MrpTask *task;
MrpResource *resource;
gint units;
} MrpAssignmentPrivate;
G_DEFINE_TYPE_WITH_CODE (MrpAssignment, mrp_assignment, MRP_TYPE_OBJECT, G_ADD_PRIVATE (MrpAssignment))
/* Properties */
enum {
PROP_0,
PROP_TASK,
PROP_RESOURCE,
PROP_UNITS
};
static void
mrp_assignment_finalize (GObject *object)
{
MrpAssignment *assignment = MRP_ASSIGNMENT (object);
MrpAssignmentPrivate *priv = mrp_assignment_get_instance_private (assignment);
if (priv->task) {
g_object_unref (priv->task);
priv->task = NULL;
}
if (priv->resource) {
g_object_unref (priv->resource);
priv->resource = NULL;
}
G_OBJECT_CLASS (mrp_assignment_parent_class)->finalize (object);
}
static void
mrp_assignment_set_property (GObject *object,
guint prop_id,
const GValue *value,
GParamSpec *pspec)
{
MrpAssignment *assignment = MRP_ASSIGNMENT (object);
MrpAssignmentPrivate *priv = mrp_assignment_get_instance_private (assignment);
/* FIXME: See bug #138368 about this. The assignment doesn't have a
* project pointer so we can't emit changed on it. We cheat for now and
* use the resource/task in those cases.
*/
switch (prop_id) {
case PROP_TASK:
if (priv->task) {
g_object_unref (priv->task);
}
priv->task = g_object_ref (g_value_get_object (value));
mrp_object_changed (MRP_OBJECT (priv->task));
break;
case PROP_RESOURCE:
if (priv->resource) {
g_object_unref (priv->resource);
}
priv->resource = g_object_ref (g_value_get_object (value));
mrp_object_changed (MRP_OBJECT (priv->resource));
break;
case PROP_UNITS:
priv->units = g_value_get_int (value);
mrp_object_changed (MRP_OBJECT (priv->resource));
break;
default:
break;
}
}
static void
mrp_assignment_get_property (GObject *object,
guint prop_id,
GValue *value,
GParamSpec *pspec)
{
MrpAssignment *assignment = MRP_ASSIGNMENT (object);
MrpAssignmentPrivate *priv = mrp_assignment_get_instance_private (assignment);
switch (prop_id) {
case PROP_TASK:
g_value_set_object (value, priv->task);
break;
case PROP_RESOURCE:
g_value_set_object (value, priv->resource);
break;
case PROP_UNITS:
g_value_set_int (value, priv->units);
break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
}
}
static void
mrp_assignment_class_init (MrpAssignmentClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
object_class->finalize = mrp_assignment_finalize;
object_class->set_property = mrp_assignment_set_property;
object_class->get_property = mrp_assignment_get_property;
/* Properties */
g_object_class_install_property (object_class,
PROP_TASK,
g_param_spec_object ("task",
"Task",
"The task",
MRP_TYPE_TASK,
G_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_RESOURCE,
g_param_spec_object ("resource",
"Resource",
"The resource that is assigned to the task",
MRP_TYPE_RESOURCE,
G_PARAM_READWRITE));
g_object_class_install_property (object_class,
PROP_UNITS,
g_param_spec_int ("units",
"Units",
"Number of units assignment",
-1,
G_MAXINT,
0,
G_PARAM_READWRITE));
}
static void
mrp_assignment_init (MrpAssignment *assignment)
{
}
/**
* mrp_assignment_new:
*
* Creates a new, empty, assignment. You most often don't want to create an
* assignment explicitly like this, but using mrp_resource_assign() instead.
*
* Return value: Newly created assignment.
**/
MrpAssignment *
mrp_assignment_new (void)
{
MrpAssignment *assignment;
assignment = g_object_new (MRP_TYPE_ASSIGNMENT, NULL);
return assignment;
}
/**
* mrp_assignment_get_task:
* @assignment: an #MrpAssignment
*
* Retrieves the #MrpTask associated with @assignment.
*
* Return value: the task associated with the assignment object. The reference
* count of the task is not increased.
**/
MrpTask *
mrp_assignment_get_task (MrpAssignment *assignment)
{
MrpAssignmentPrivate *priv = mrp_assignment_get_instance_private (assignment);
g_return_val_if_fail (MRP_IS_ASSIGNMENT (assignment), NULL);
return priv->task;
}
/**
* mrp_assignment_get_resource:
* @assignment: an #MrpAssignment
*
* Retrieves the #MrpResource associated with @assignment.
*
* Return value: the resource associated with the assignment object. The reference
* count of the resource is not increased.
**/
MrpResource *
mrp_assignment_get_resource (MrpAssignment *assignment)
{
MrpAssignmentPrivate *priv = mrp_assignment_get_instance_private (assignment);
g_return_val_if_fail (MRP_IS_ASSIGNMENT (assignment), NULL);
return priv->resource;
}
/**
* mrp_assignment_get_units:
* @assignment: an #MrpAssignment
*
* Retrieves the number of units that the resource is assigned with to the
* task. 100 means 100%, etc.
*
* Return value: number of units of the assignment.
**/
gint
mrp_assignment_get_units (MrpAssignment *assignment)
{
MrpAssignmentPrivate *priv = mrp_assignment_get_instance_private (assignment);
g_return_val_if_fail (MRP_IS_ASSIGNMENT (assignment), -1);
return priv->units;
}
|