1 /* ADG - Automatic Drawing Generation
2 * Copyright (C) 2007,2008,2009 Nicola Fontana <ntd at entidi.it>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17 * Boston, MA 02110-1301, USA.
24 * @short_description: A GObject based wrapper for the #CpmlSegment struct
26 * The AdgSegment is a wrapper typedef in #GType syntax of the
27 * #CpmlSegment struct. Furthermore, some dynamic memory functions
28 * are provided, such as shallow and deep duplication, as the CPML
29 * library does not have dynamic memory APIs.
35 * Another name for the #CpmlSegment type: check its documentation
36 * for fields description.
40 #include "adg-segment.h"
46 adg_segment_get_type(void)
48 static int segment_type
= 0;
50 if (G_UNLIKELY(segment_type
== 0))
51 segment_type
= g_boxed_type_register_static("AdgSegment",
52 (GBoxedCopyFunc
) adg_segment_dup
,
60 * @segment: an #AdgSegment structure
62 * Duplicates @segment. This function makes a shallow duplication,
63 * that is the internal pointers of the resulting segment struct
64 * refer to the same memory as the original @segment. Check out
65 * adg_segment_deep_dup() if it is required also the content
68 * Return value: a shallow duplicate of @segment: must be freed
69 * with g_free() when no longer needed.
72 adg_segment_dup(const AdgSegment
*segment
)
74 return g_memdup(segment
, sizeof(AdgSegment
));
78 * adg_segment_deep_dup:
79 * @segment: an #AdgSegment structure
81 * Duplicates @segment. This function makes a deep duplication,
82 * that is it duplicates also the underlying data that defines
83 * the segment. The <structfield>path</structfield> field
84 * is set to %NULL as <structfield>data</structfield> is no
85 * more referring to the original cairo path.
87 * All the data is allocated in the same chunk of memory so freeing
88 * the returned pointer releases all the occupied memory.
90 * Return value: a deep duplicate of @segment: must be freed
91 * with g_free() when no longer needed.
94 adg_segment_deep_dup(const AdgSegment
*segment
)
97 gsize segment_size
, data_size
;
98 cairo_path_data_t
*p_data
;
100 segment_size
= sizeof(AdgSegment
);
101 data_size
= segment
->data
== NULL
?
102 0 : sizeof(cairo_path_data_t
) * segment
->num_data
;
103 dest
= (AdgSegment
*) g_malloc(segment_size
+ data_size
);
104 p_data
= (cairo_path_data_t
*) ((gchar
*) dest
+ segment_size
);
109 dest
->data
= memcpy(p_data
, segment
->data
, data_size
);
110 dest
->num_data
= segment
->num_data
;