#define FONT_SCALE (72.0/96.0)
#define PI 3.141592654
+#define GL_BARCODE_FONT_FAMILY "Sans"
+
+#define HANDLE_OUTLINE_RGBA_ARGS 0.5, 0.5, 0.5, 0.75
+#define HANDLE_OUTLINE_WIDTH_PIXELS 2.0
+
+#define SELECTION_SLOP_PIXELS 4.0
+
/*========================================================*/
/* Private types. */
/*========================================================*/
struct _glLabelBarcodePrivate {
- glTextNode *text_node;
- gchar *id;
- glColorNode *color_node;
- gboolean text_flag;
- gboolean checksum_flag;
- guint format_digits;
+
+ glTextNode *text_node;
+ glLabelBarcodeStyle *style;
+ glColorNode *color_node;
+
+ /* Cached info. Only regenerate when text_node,
+ * style, or raw size changed */
+ lglBarcode *display_gbc;
+ gdouble w, h;
+
};
static void copy (glLabelObject *dst_object,
glLabelObject *src_object);
+static void update_barcode (glLabelBarcode *lbc);
+
+static void set_size (glLabelObject *object,
+ gdouble w,
+ gdouble h,
+ gboolean checkpoint);
+
static void get_size (glLabelObject *object,
gdouble *w,
gdouble *h);
gdouble x_pixels,
gdouble y_pixels);
+static void draw_handles (glLabelObject *object,
+ cairo_t *cr);
+
+static void create_alt_msg_path (cairo_t *cr,
+ gchar *text);
+
/*****************************************************************************/
/* Boilerplate object stuff. */
/*****************************************************************************/
-G_DEFINE_TYPE (glLabelBarcode, gl_label_barcode, GL_TYPE_LABEL_OBJECT);
+G_DEFINE_TYPE (glLabelBarcode, gl_label_barcode, GL_TYPE_LABEL_OBJECT)
static void
gl_label_barcode_parent_class = g_type_class_peek_parent (class);
label_object_class->copy = copy;
+ label_object_class->set_size = set_size;
label_object_class->get_size = get_size;
label_object_class->set_line_color = set_line_color;
label_object_class->get_line_color = get_line_color;
label_object_class->draw_object = draw_object;
label_object_class->draw_shadow = NULL;
label_object_class->object_at = object_at;
+ label_object_class->draw_handles = draw_handles;
object_class->finalize = gl_label_barcode_finalize;
}
g_return_if_fail (object && GL_IS_LABEL_BARCODE (object));
gl_text_node_free (&lbc->priv->text_node);
- g_free (lbc->priv->id);
+ gl_label_barcode_style_free (lbc->priv->style);
gl_color_node_free (&(lbc->priv->color_node));
+ lgl_barcode_free (lbc->priv->display_gbc);
g_free (lbc->priv);
G_OBJECT_CLASS (gl_label_barcode_parent_class)->finalize (object);
gboolean checkpoint)
{
glLabelBarcode *lbc;
+ glLabelBarcodeStyle *style;
glColorNode *line_color_node;
lbc = g_object_new (gl_label_barcode_get_type(), NULL);
gl_label_checkpoint (label, _("Create barcode object"));
}
- line_color_node = gl_color_node_new_default ();
+ /* Default barcode style and properties. */
+ style = gl_label_barcode_style_new ();
+ gl_label_barcode_style_set_backend_id (style, gl_barcode_backends_backend_name_to_id (NULL));
+ gl_label_barcode_style_set_style_id (style, gl_barcode_backends_style_name_to_id (style->backend_id, NULL));
+ style->text_flag = gl_barcode_backends_style_can_text (style->backend_id, style->id);
+ style->checksum_flag = gl_barcode_backends_style_can_csum (style->backend_id, style->id);
+ style->format_digits = gl_barcode_backends_style_get_prefered_n (style->backend_id, style->id);
+ lbc->priv->style = style;
+ update_barcode (lbc);
+ line_color_node = gl_color_node_new_default ();
line_color_node->color = gl_label_get_default_line_color(label);
-
lbc->priv->color_node = line_color_node;
gl_label_add_object (label, GL_LABEL_OBJECT (lbc));
glLabelBarcode *lbc = (glLabelBarcode *)src_object;
glLabelBarcode *new_lbc = (glLabelBarcode *)dst_object;
glTextNode *text_node;
- gchar *id;
- gboolean text_flag;
- gboolean checksum_flag;
+ glLabelBarcodeStyle *style;
glColorNode *color_node;
- guint format_digits;
gl_debug (DEBUG_LABEL, "START");
g_return_if_fail (new_lbc && GL_IS_LABEL_BARCODE (new_lbc));
text_node = gl_label_barcode_get_data (lbc);
- gl_label_barcode_get_props (lbc, &id, &text_flag, &checksum_flag, &format_digits);
+ style = gl_label_barcode_get_style (lbc);
color_node = get_line_color (src_object);
- gl_label_barcode_set_data (new_lbc, text_node, FALSE);
- gl_label_barcode_set_props (new_lbc, id, text_flag, checksum_flag, format_digits, FALSE);
- set_line_color (dst_object, color_node, FALSE);
+ new_lbc->priv->text_node = text_node;
+ new_lbc->priv->style = style;
+ new_lbc->priv->color_node = color_node;
- gl_color_node_free (&color_node);
- gl_text_node_free (&text_node);
- g_free (id);
+ update_barcode (new_lbc);
gl_debug (DEBUG_LABEL, "END");
}
/* Set object params. */
/*****************************************************************************/
void
-gl_label_barcode_set_data (glLabelBarcode *lbc,
- glTextNode *text_node,
- gboolean checkpoint)
+gl_label_barcode_set_data (glLabelBarcode *lbc,
+ const glTextNode *text_node,
+ gboolean checkpoint)
{
glLabel *label;
gl_text_node_free (&lbc->priv->text_node);
lbc->priv->text_node = gl_text_node_dup (text_node);
+ update_barcode (lbc);
+
gl_label_object_emit_changed (GL_LABEL_OBJECT(lbc));
}
void
-gl_label_barcode_set_props (glLabelBarcode *lbc,
- gchar *id,
- gboolean text_flag,
- gboolean checksum_flag,
- guint format_digits,
- gboolean checkpoint)
+gl_label_barcode_set_style (glLabelBarcode *lbc,
+ const glLabelBarcodeStyle *style,
+ gboolean checkpoint)
{
glLabel *label;
g_return_if_fail (lbc && GL_IS_LABEL_BARCODE (lbc));
- if ( ((lbc->priv->id == NULL) && (id != NULL))
- || ((lbc->priv->id != NULL) && (id != NULL) && (g_ascii_strcasecmp (lbc->priv->id, id) != 0))
- || (lbc->priv->text_flag != text_flag)
- || (lbc->priv->checksum_flag != checksum_flag)
- || (lbc->priv->format_digits != format_digits))
+ if ( !gl_label_barcode_style_is_equal (style, lbc->priv->style) )
{
if ( checkpoint )
{
gl_label_checkpoint (label, _("Barcode property"));
}
- lbc->priv->id = g_strdup (id);
- lbc->priv->text_flag = text_flag;
- lbc->priv->checksum_flag = checksum_flag;
- lbc->priv->format_digits = format_digits;
+ gl_label_barcode_style_free (lbc->priv->style);
+ lbc->priv->style = gl_label_barcode_style_dup (style);
+
+ update_barcode (lbc);
gl_label_object_emit_changed (GL_LABEL_OBJECT(lbc));
}
}
-void
-gl_label_barcode_get_props (glLabelBarcode *lbc,
- gchar **id,
- gboolean *text_flag,
- gboolean *checksum_flag,
- guint *format_digits)
+glLabelBarcodeStyle *
+gl_label_barcode_get_style (glLabelBarcode *lbc)
{
- g_return_if_fail (lbc && GL_IS_LABEL_BARCODE (lbc));
+ g_return_val_if_fail (lbc && GL_IS_LABEL_BARCODE (lbc), NULL);
- *id = g_strdup (lbc->priv->id);
- *text_flag = lbc->priv->text_flag;
- *checksum_flag = lbc->priv->checksum_flag;
- *format_digits = lbc->priv->format_digits;
+ return gl_label_barcode_style_dup (lbc->priv->style);
}
/*---------------------------------------------------------------------------*/
-/* PRIVATE. Get object size method. */
+/* PRIVATE. Update cached lglBarcode. */
/*---------------------------------------------------------------------------*/
static void
-get_size (glLabelObject *object,
- gdouble *w,
- gdouble *h)
+update_barcode (glLabelBarcode *lbc)
{
- glLabelBarcode *lbc = (glLabelBarcode *)object;
+ gdouble w_raw, h_raw;
gchar *data;
- gdouble w_parent, h_parent;
- glBarcode *gbc;
gl_debug (DEBUG_LABEL, "START");
g_return_if_fail (lbc && GL_IS_LABEL_BARCODE (lbc));
- gl_label_object_get_raw_size (object, &w_parent, &h_parent);
+ gl_label_object_get_raw_size (GL_LABEL_OBJECT (lbc), &w_raw, &h_raw);
+
+ lgl_barcode_free (lbc->priv->display_gbc);
- if (lbc->priv->text_node->field_flag) {
- data = gl_barcode_backends_default_digits (lbc->priv->id,
- lbc->priv->format_digits);
- } else {
+ if (lbc->priv->text_node->field_flag)
+ {
+ data = gl_barcode_backends_style_default_digits (lbc->priv->style->backend_id,
+ lbc->priv->style->id,
+ lbc->priv->style->format_digits);
+ }
+ else
+ {
data = gl_text_node_expand (lbc->priv->text_node, NULL);
}
- gbc = gl_barcode_backends_new_barcode (lbc->priv->id,
- lbc->priv->text_flag,
- lbc->priv->checksum_flag,
- w_parent,
- h_parent,
- data);
+ lbc->priv->display_gbc = gl_barcode_backends_new_barcode (lbc->priv->style->backend_id,
+ lbc->priv->style->id,
+ lbc->priv->style->text_flag,
+ lbc->priv->style->checksum_flag,
+ w_raw,
+ h_raw,
+ data);
g_free (data);
- if ( gbc == NULL ) {
- /* Try again with default digits. */
- data = gl_barcode_backends_default_digits (lbc->priv->id,
- lbc->priv->format_digits);
- gbc = gl_barcode_backends_new_barcode (lbc->priv->id,
- lbc->priv->text_flag,
- lbc->priv->checksum_flag,
- w_parent,
- h_parent,
+ if ( lbc->priv->display_gbc == NULL )
+ {
+ lglBarcode *gbc;
+
+ /* Try again with default digits, but don't save -- just extract size. */
+ data = gl_barcode_backends_style_default_digits (lbc->priv->style->backend_id,
+ lbc->priv->style->id,
+ lbc->priv->style->format_digits);
+ gbc = gl_barcode_backends_new_barcode (lbc->priv->style->backend_id,
+ lbc->priv->style->id,
+ lbc->priv->style->text_flag,
+ lbc->priv->style->checksum_flag,
+ w_raw,
+ h_raw,
data);
g_free (data);
- }
- if ( gbc != NULL )
- {
- *w = gbc->width;
- *h = gbc->height;
+ if ( gbc != NULL )
+ {
+ lbc->priv->w = gbc->width;
+ lbc->priv->h = gbc->height;
+ }
+ else
+ {
+ /* If we still can't render, just set a default size. */
+ lbc->priv->w = 144;
+ lbc->priv->h = 72;
+ }
+
+ lgl_barcode_free (gbc);
}
else
{
- /* If we still can't render, just set a default size. */
- *w = 144;
- *h = 72;
+ lbc->priv->w = lbc->priv->display_gbc->width;
+ lbc->priv->h = lbc->priv->display_gbc->height;
}
- gl_barcode_free (&gbc);
+ gl_debug (DEBUG_LABEL, "END");
+}
+
+
+/*---------------------------------------------------------------------------*/
+/* PRIVATE. Set object size method. */
+/*---------------------------------------------------------------------------*/
+static void
+set_size (glLabelObject *object,
+ gdouble w,
+ gdouble h,
+ gboolean checkpoint)
+{
+ gl_debug (DEBUG_LABEL, "START");
+
+ g_return_if_fail (object && GL_IS_LABEL_BARCODE (object));
+
+ gl_label_object_set_raw_size (object, w, h, checkpoint);
+ update_barcode (GL_LABEL_BARCODE (object));
+
+ gl_debug (DEBUG_LABEL, "END");
+}
+
+
+/*---------------------------------------------------------------------------*/
+/* PRIVATE. Get object size method. */
+/*---------------------------------------------------------------------------*/
+static void
+get_size (glLabelObject *object,
+ gdouble *w,
+ gdouble *h)
+{
+ gl_debug (DEBUG_LABEL, "START");
+
+ g_return_if_fail (object && GL_IS_LABEL_BARCODE (object));
+
+ *w = GL_LABEL_BARCODE (object)->priv->w;
+ *h = GL_LABEL_BARCODE (object)->priv->h;
gl_debug (DEBUG_LABEL, "END");
}
gboolean screen_flag,
glMergeRecord *record)
{
+ glLabelBarcode *lbc = (glLabelBarcode *)object;
gdouble x0, y0;
cairo_matrix_t matrix;
- glBarcode *gbc;
- glBarcodeShape *shape;
- glBarcodeShapeLine *line;
- glBarcodeShapeBox *box;
- glBarcodeShapeRing *ring;
- glBarcodeShapeHexagon *hexagon;
- glBarcodeShapeChar *bchar;
- glBarcodeShapeString *bstring;
- GList *p;
- gdouble x_offset, y_offset;
- PangoLayout *layout;
- PangoFontDescription *desc;
- gchar *text, *cstring;
+ lglBarcode *gbc;
+ gchar *text;
glTextNode *text_node;
- gchar *id;
- gboolean text_flag;
- gboolean checksum_flag;
+ glLabelBarcodeStyle *style;
guint color;
glColorNode *color_node;
- guint format_digits;
gdouble w, h;
- gint iw, ih;
- gdouble layout_width;
gl_debug (DEBUG_LABEL, "START");
gl_label_object_get_matrix (object, &matrix);
text_node = gl_label_barcode_get_data (GL_LABEL_BARCODE (object));
- gl_label_barcode_get_props (GL_LABEL_BARCODE (object),
- &id, &text_flag, &checksum_flag, &format_digits);
+ style = gl_label_barcode_get_style (GL_LABEL_BARCODE (object));
color_node = gl_label_object_get_line_color (object);
color = gl_color_node_expand (color_node, record);
{
color = GL_COLOR_MERGE_DEFAULT;
}
- gl_color_node_free (&color_node);
-
- gl_label_object_get_size (object, &w, &h);
- text_node = gl_label_barcode_get_data(GL_LABEL_BARCODE(object));
- text = gl_text_node_expand (text_node, record);
- if (text_node->field_flag && screen_flag) {
- text = gl_barcode_backends_default_digits (id, format_digits);
- }
+ cairo_set_source_rgba (cr, GL_COLOR_RGBA_ARGS (color));
- gbc = gl_barcode_backends_new_barcode (id, text_flag, checksum_flag, w, h, text);
+ if (text_node->field_flag && !screen_flag) {
- cairo_set_source_rgba (cr, GL_COLOR_RGBA_ARGS (color));
+ gl_label_object_get_raw_size (object, &w, &h);
- if (gbc == NULL) {
+ text = gl_text_node_expand (text_node, record);
+ gbc = gl_barcode_backends_new_barcode (style->backend_id, style->id, style->text_flag, style->checksum_flag, w, h, text);
+ g_free (text);
- layout = pango_cairo_create_layout (cr);
+ if ( gbc != NULL )
+ {
+ lgl_barcode_render_to_cairo (gbc, cr);
+ lgl_barcode_free (gbc);
+ }
- desc = pango_font_description_new ();
- pango_font_description_set_family (desc, GL_BARCODE_FONT_FAMILY);
- pango_font_description_set_size (desc, 12 * PANGO_SCALE * FONT_SCALE);
- pango_layout_set_font_description (layout, desc);
- pango_font_description_free (desc);
+ }
+ else
+ {
- if (text == NULL || *text == '\0')
+ if (lbc->priv->display_gbc == NULL)
{
- pango_layout_set_text (layout, _("Barcode data empty"), -1);
+ create_alt_msg_path (cr, text_node->data);
+ cairo_fill (cr);
}
else
{
- pango_layout_set_text (layout, _("Invalid barcode data"), -1);
+ lgl_barcode_render_to_cairo (lbc->priv->display_gbc, cr);
}
- cairo_move_to (cr, 0, 0);
- pango_cairo_show_layout (cr, layout);
-
- g_object_unref (layout);
-
- } else {
-
- for (p = gbc->shapes; p != NULL; p = p->next) {
- shape = (glBarcodeShape *)p->data;
- switch (shape->type)
- {
+ }
- case GL_BARCODE_SHAPE_LINE:
- line = (glBarcodeShapeLine *) shape;
+ gl_text_node_free (&text_node);
+ gl_label_barcode_style_free (style);
+ gl_color_node_free (&color_node);
- cairo_move_to (cr, line->x, line->y);
- cairo_line_to (cr, line->x, line->y + line->length);
- cairo_set_line_width (cr, line->width);
- cairo_stroke (cr);
+ gl_debug (DEBUG_LABEL, "END");
+}
- break;
- case GL_BARCODE_SHAPE_BOX:
- box = (glBarcodeShapeBox *) shape;
+/*****************************************************************************/
+/* Is object at coordinates? */
+/*****************************************************************************/
+static gboolean
+object_at (glLabelObject *object,
+ cairo_t *cr,
+ gdouble x,
+ gdouble y)
+{
+ glLabelBarcode *lbc = (glLabelBarcode *)object;
+ gdouble w, h;
+ glTextNode *text_node;
+ gdouble scale_x, scale_y;
- cairo_rectangle (cr, box->x, box->y, box->width, box->height);
- cairo_fill (cr);
+ gl_label_object_get_size (object, &w, &h);
- break;
+ if ( (x >= 0) && (x <= w) && (y >= 0) && (y <= h) )
+ {
- case GL_BARCODE_SHAPE_CHAR:
- bchar = (glBarcodeShapeChar *) shape;
+ text_node = gl_label_barcode_get_data(GL_LABEL_BARCODE(object));
- layout = pango_cairo_create_layout (cr);
+ if ( lbc->priv->display_gbc == NULL )
+ {
+ create_alt_msg_path (cr, text_node->data);
+ }
+ else
+ {
+ lgl_barcode_render_to_cairo_path (lbc->priv->display_gbc, cr);
+ }
- desc = pango_font_description_new ();
- pango_font_description_set_family (desc, GL_BARCODE_FONT_FAMILY);
- pango_font_description_set_size (desc, bchar->fsize * PANGO_SCALE * FONT_SCALE);
- pango_layout_set_font_description (layout, desc);
- pango_font_description_free (desc);
+ if (cairo_in_fill (cr, x, y))
+ {
+ return TRUE;
+ }
- cstring = g_strdup_printf ("%c", bchar->c);
- pango_layout_set_text (layout, cstring, -1);
- g_free (cstring);
- y_offset = 0.2 * bchar->fsize;
+ scale_x = 1.0;
+ scale_y = 1.0;
+ cairo_device_to_user_distance (cr, &scale_x, &scale_y);
- cairo_move_to (cr, bchar->x, bchar->y-y_offset);
- pango_cairo_show_layout (cr, layout);
+ cairo_set_line_width (cr, 2*SELECTION_SLOP_PIXELS*scale_x);
- g_object_unref (layout);
+ if (cairo_in_stroke (cr, x, y))
+ {
+ return TRUE;
+ }
- break;
- case GL_BARCODE_SHAPE_STRING:
- bstring = (glBarcodeShapeString *) shape;
+ if (gl_label_object_is_selected (object))
+ {
+ cairo_new_path (cr);
+ cairo_rectangle (cr, 0, 0, w, h);
- layout = pango_cairo_create_layout (cr);
+ scale_x = 1.0;
+ scale_y = 1.0;
+ cairo_device_to_user_distance (cr, &scale_x, &scale_y);
- desc = pango_font_description_new ();
- pango_font_description_set_family (desc, GL_BARCODE_FONT_FAMILY);
- pango_font_description_set_size (desc, bstring->fsize * PANGO_SCALE * FONT_SCALE);
- pango_layout_set_font_description (layout, desc);
- pango_font_description_free (desc);
+ cairo_set_line_width (cr, (HANDLE_OUTLINE_WIDTH_PIXELS + 2*SELECTION_SLOP_PIXELS)*scale_x);
- pango_layout_set_text (layout, bstring->string, -1);
+ if (cairo_in_stroke (cr, x, y))
+ {
+ return TRUE;
+ }
+ }
- pango_layout_get_size (layout, &iw, &ih);
- layout_width = (gdouble)iw / (gdouble)PANGO_SCALE;
+ }
- x_offset = layout_width / 2.0;
- y_offset = 0.2 * bstring->fsize;
+ return FALSE;
+}
- cairo_move_to (cr, (bstring->x - x_offset), (bstring->y - y_offset));
- pango_cairo_show_layout (cr, layout);
- g_object_unref (layout);
+/*****************************************************************************/
+/* Draw barcode style handles. */
+/*****************************************************************************/
+static void
+draw_handles (glLabelObject *object,
+ cairo_t *cr)
+{
+ gdouble w, h;
+ gdouble scale_x, scale_y;
+ gdouble dashes[2] = { 2, 2 };
- break;
+ gl_label_object_get_size (GL_LABEL_OBJECT(object), &w, &h);
- case GL_BARCODE_SHAPE_RING:
- ring = (glBarcodeShapeRing *) shape;
+ cairo_save (cr);
- cairo_arc (cr, ring->x, ring->y, ring->radius, 0.0, 2 * PI);
- cairo_set_line_width (cr, ring->line_width);
- cairo_stroke (cr);
+ cairo_rectangle (cr, 0, 0, w, h);
- break;
+ scale_x = 1.0;
+ scale_y = 1.0;
+ cairo_device_to_user_distance (cr, &scale_x, &scale_y);
+ cairo_scale (cr, scale_x, scale_y);
- case GL_BARCODE_SHAPE_HEXAGON:
- hexagon = (glBarcodeShapeHexagon *) shape;
+ cairo_set_dash (cr, dashes, 2, 0);
+ cairo_set_line_width (cr, HANDLE_OUTLINE_WIDTH_PIXELS);
+ cairo_set_source_rgba (cr, HANDLE_OUTLINE_RGBA_ARGS);
+ cairo_stroke (cr);
- cairo_move_to (cr, hexagon->x, hexagon->y);
- cairo_line_to (cr, hexagon->x + 1.25, hexagon->y + 0.70);
- cairo_line_to (cr, hexagon->x + 1.25, hexagon->y + 2.18);
- cairo_line_to (cr, hexagon->x, hexagon->y + 2.89);
- cairo_line_to (cr, hexagon->x - 1.25, hexagon->y + 2.18);
- cairo_line_to (cr, hexagon->x - 1.25, hexagon->y + 0.70);
- cairo_close_path (cr);
- cairo_fill (cr);
+ cairo_restore (cr);
- break;
+ gl_label_object_draw_handles_box (object, cr);
+}
- default:
- g_assert_not_reached ();
- break;
- }
+/*****************************************************************************/
+/* Create a cairo path with apropos message. */
+/*****************************************************************************/
+static void
+create_alt_msg_path (cairo_t *cr,
+ gchar *text)
+{
+ PangoLayout *layout;
+ PangoFontDescription *desc;
- }
+ layout = pango_cairo_create_layout (cr);
- gl_barcode_free (&gbc);
+ desc = pango_font_description_new ();
+ pango_font_description_set_family (desc, GL_BARCODE_FONT_FAMILY);
+ pango_font_description_set_size (desc, 12 * PANGO_SCALE * FONT_SCALE);
+ pango_layout_set_font_description (layout, desc);
+ pango_font_description_free (desc);
+ if (text == NULL || *text == '\0')
+ {
+ pango_layout_set_text (layout, _("Barcode data empty"), -1);
+ }
+ else
+ {
+ pango_layout_set_text (layout, _("Invalid barcode data"), -1);
}
- g_free (text);
- gl_text_node_free (&text_node);
- g_free (id);
+ cairo_move_to (cr, 0, 0);
+ pango_cairo_layout_path (cr, layout);
- gl_debug (DEBUG_LABEL, "END");
+ g_object_unref (layout);
}
/*****************************************************************************/
-/* Is object at coordinates? */
+/* Barcode style utilities. */
/*****************************************************************************/
-static gboolean
-object_at (glLabelObject *object,
- cairo_t *cr,
- gdouble x,
- gdouble y)
+glLabelBarcodeStyle *
+gl_label_barcode_style_new (void)
{
- gdouble w, h;
+ return g_new0 (glLabelBarcodeStyle, 1);
+}
- gl_label_object_get_size (object, &w, &h);
- cairo_new_path (cr);
- cairo_rectangle (cr, 0.0, 0.0, w, h);
+glLabelBarcodeStyle *
+gl_label_barcode_style_dup (const glLabelBarcodeStyle *style)
+{
+ glLabelBarcodeStyle *style2;
+
+ style2 = gl_label_barcode_style_new ();
- if (cairo_in_fill (cr, x, y))
+ /* Shallow copy first. */
+ *style2 = *style;
+
+ /* Now go deep. */
+ style2->backend_id = g_strdup (style->backend_id);
+ style2->id = g_strdup (style->id);
+
+ return style2;
+}
+
+
+void
+gl_label_barcode_style_free (glLabelBarcodeStyle *style)
+{
+ if ( style )
{
- return TRUE;
+ g_free (style->backend_id);
+ g_free (style->id);
+
+ g_free (style);
}
+}
- return FALSE;
+
+gboolean
+gl_label_barcode_style_is_equal (const glLabelBarcodeStyle *style1,
+ const glLabelBarcodeStyle *style2)
+{
+
+ /* First take care of the case of either or both being NULL. */
+ if ( style1 == NULL )
+ {
+ return ( style2 == NULL );
+ }
+ else
+ {
+ if ( style2 == NULL )
+ {
+ return FALSE;
+ }
+ }
+
+ /* Compare field by field, bail on first difference. */
+ if ( style1->text_flag != style2->text_flag )
+ {
+ return FALSE;
+ }
+ if ( style1->checksum_flag != style2->checksum_flag )
+ {
+ return FALSE;
+ }
+ if ( style1->format_digits != style2->format_digits )
+ {
+ return FALSE;
+ }
+ if ( style1->backend_id && style2->backend_id )
+ {
+ if ( strcmp (style1->backend_id, style2->backend_id) != 0 )
+ {
+ return FALSE;
+ }
+ }
+ else
+ {
+ if ( style1->backend_id != style2->backend_id )
+ {
+ return FALSE;
+ }
+ }
+ if ( style1->id && style2->id )
+ {
+ if ( strcmp (style1->id, style2->id) != 0 )
+ {
+ return FALSE;
+ }
+ }
+ else
+ {
+ if ( style1->id != style2->id )
+ {
+ return FALSE;
+ }
+ }
+
+ /* Passed all tests. */
+ return TRUE;
+}
+
+
+void
+gl_label_barcode_style_set_backend_id (glLabelBarcodeStyle *style,
+ const gchar *backend_id)
+{
+ style->backend_id = g_strdup (backend_id);
}
+void
+gl_label_barcode_style_set_style_id (glLabelBarcodeStyle *style,
+ const gchar *id)
+{
+ style->id = g_strdup (id);
+}
+
+
+
/*