2010-09-20 18:18:30 +02:00
|
|
|
/*
|
|
|
|
* ld-symbol.c
|
|
|
|
*
|
|
|
|
* This file is a part of logdiag.
|
|
|
|
* Copyright Přemysl Janouch 2010. All rights reserved.
|
|
|
|
*
|
|
|
|
* See the file LICENSE for licensing information.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <gtk/gtk.h>
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "ld-symbol.h"
|
2010-09-30 05:19:31 +02:00
|
|
|
#include "ld-symbol-category.h"
|
|
|
|
#include "ld-library.h"
|
2010-09-20 18:18:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* SECTION:ld-symbol
|
|
|
|
* @short_description: A symbol.
|
|
|
|
* @see_also: #LdDocument, #LdCanvas
|
|
|
|
*
|
|
|
|
* #LdSymbol represents a symbol in the #LdDocument that is in turn
|
|
|
|
* drawn onto the #LdCanvas.
|
|
|
|
*/
|
|
|
|
|
2010-09-25 20:59:20 +02:00
|
|
|
G_DEFINE_ABSTRACT_TYPE (LdSymbol, ld_symbol, G_TYPE_OBJECT);
|
2010-09-20 18:18:30 +02:00
|
|
|
|
2010-10-24 13:43:41 +02:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
PROP_0,
|
2010-10-27 15:52:36 +02:00
|
|
|
PROP_NAME,
|
|
|
|
PROP_HUMAN_NAME,
|
|
|
|
/* TODO: Property for the area. */
|
2010-10-24 13:43:41 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
static void
|
|
|
|
ld_symbol_get_property (GObject *object, guint property_id,
|
|
|
|
GValue *value, GParamSpec *pspec);
|
|
|
|
|
|
|
|
static void
|
|
|
|
ld_symbol_set_property (GObject *object, guint property_id,
|
|
|
|
const GValue *value, GParamSpec *pspec);
|
|
|
|
|
2010-09-25 20:59:20 +02:00
|
|
|
static void ld_symbol_finalize (GObject *gobject);
|
2010-09-20 18:18:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
ld_symbol_class_init (LdSymbolClass *klass)
|
|
|
|
{
|
|
|
|
GObjectClass *object_class;
|
2010-10-24 13:43:41 +02:00
|
|
|
GParamSpec *pspec;
|
2010-09-20 18:18:30 +02:00
|
|
|
|
|
|
|
object_class = G_OBJECT_CLASS (klass);
|
2010-10-24 13:43:41 +02:00
|
|
|
object_class->get_property = ld_symbol_get_property;
|
|
|
|
object_class->set_property = ld_symbol_set_property;
|
2010-09-20 18:18:30 +02:00
|
|
|
|
2010-10-24 13:43:41 +02:00
|
|
|
/**
|
|
|
|
* LdSymbol:name:
|
|
|
|
*
|
|
|
|
* The name of this symbol.
|
|
|
|
*/
|
|
|
|
pspec = g_param_spec_string ("name", "Name",
|
|
|
|
"The name of this symbol.",
|
2010-10-27 15:52:36 +02:00
|
|
|
"", G_PARAM_READABLE);
|
2010-10-24 13:43:41 +02:00
|
|
|
g_object_class_install_property (object_class, PROP_NAME, pspec);
|
|
|
|
|
2010-10-27 15:52:36 +02:00
|
|
|
/**
|
|
|
|
* LdSymbol:human-name:
|
|
|
|
*
|
|
|
|
* The localized human name of this symbol.
|
|
|
|
*/
|
|
|
|
pspec = g_param_spec_string ("human-name", "Human name",
|
|
|
|
"The localized human name of this symbol.",
|
|
|
|
"", G_PARAM_READABLE);
|
|
|
|
g_object_class_install_property (object_class, PROP_HUMAN_NAME, pspec);
|
2010-09-20 18:18:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
ld_symbol_init (LdSymbol *self)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-10-24 13:43:41 +02:00
|
|
|
static void
|
|
|
|
ld_symbol_get_property (GObject *object, guint property_id,
|
|
|
|
GValue *value, GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
LdSymbol *self;
|
|
|
|
|
|
|
|
self = LD_SYMBOL (object);
|
|
|
|
switch (property_id)
|
|
|
|
{
|
|
|
|
case PROP_NAME:
|
|
|
|
g_value_set_string (value, ld_symbol_get_name (self));
|
|
|
|
break;
|
2010-10-27 15:52:36 +02:00
|
|
|
case PROP_HUMAN_NAME:
|
|
|
|
g_value_set_string (value, ld_symbol_get_human_name (self));
|
|
|
|
break;
|
2010-10-24 13:43:41 +02:00
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
ld_symbol_set_property (GObject *object, guint property_id,
|
|
|
|
const GValue *value, GParamSpec *pspec)
|
|
|
|
{
|
2010-10-27 15:52:36 +02:00
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
2010-10-24 13:43:41 +02:00
|
|
|
}
|
|
|
|
|
2010-09-20 18:18:30 +02:00
|
|
|
|
2010-10-27 15:52:36 +02:00
|
|
|
/**
|
|
|
|
* ld_symbol_get_name:
|
|
|
|
* @self: An #LdSymbol object.
|
|
|
|
*
|
|
|
|
* Return value: The name of the symbol.
|
|
|
|
*/
|
|
|
|
const gchar *
|
|
|
|
ld_symbol_get_name (LdSymbol *self)
|
|
|
|
{
|
|
|
|
LdSymbolClass *klass;
|
2010-09-20 18:18:30 +02:00
|
|
|
|
2010-10-27 15:52:36 +02:00
|
|
|
g_return_if_fail (LD_IS_SYMBOL (self));
|
2010-10-24 13:43:41 +02:00
|
|
|
|
2010-10-27 15:52:36 +02:00
|
|
|
klass = LD_SYMBOL_GET_CLASS (self);
|
|
|
|
g_return_val_if_fail (klass->get_name != NULL, NULL);
|
|
|
|
return klass->get_name (self);
|
2010-09-20 18:18:30 +02:00
|
|
|
}
|
|
|
|
|
2010-10-24 13:43:41 +02:00
|
|
|
/**
|
2010-10-27 15:52:36 +02:00
|
|
|
* ld_symbol_get_human_name:
|
2010-10-24 13:43:41 +02:00
|
|
|
* @self: An #LdSymbol object.
|
|
|
|
*
|
2010-10-27 15:52:36 +02:00
|
|
|
* Return value: The localised human name of the symbol.
|
2010-10-24 13:43:41 +02:00
|
|
|
*/
|
2010-10-27 15:52:36 +02:00
|
|
|
const gchar *
|
|
|
|
ld_symbol_get_human_name (LdSymbol *self)
|
2010-10-24 13:43:41 +02:00
|
|
|
{
|
2010-10-27 15:52:36 +02:00
|
|
|
LdSymbolClass *klass;
|
|
|
|
|
2010-10-24 13:43:41 +02:00
|
|
|
g_return_if_fail (LD_IS_SYMBOL (self));
|
|
|
|
|
2010-10-27 15:52:36 +02:00
|
|
|
klass = LD_SYMBOL_GET_CLASS (self);
|
|
|
|
g_return_val_if_fail (klass->get_human_name != NULL, NULL);
|
|
|
|
return klass->get_human_name (self);
|
2010-10-24 13:43:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-10-27 15:52:36 +02:00
|
|
|
* ld_symbol_get_area:
|
|
|
|
* @self: A symbol object.
|
|
|
|
* @area: Where the area of the symbol will be returned.
|
2010-10-24 13:43:41 +02:00
|
|
|
*
|
2010-10-27 15:52:36 +02:00
|
|
|
* Get the area of the symbol.
|
2010-10-24 13:43:41 +02:00
|
|
|
*/
|
2010-10-27 15:52:36 +02:00
|
|
|
void
|
|
|
|
ld_symbol_get_area (LdSymbol *self, LdSymbolArea *area)
|
2010-10-24 13:43:41 +02:00
|
|
|
{
|
2010-10-27 15:52:36 +02:00
|
|
|
LdSymbolClass *klass;
|
|
|
|
|
2010-10-24 13:43:41 +02:00
|
|
|
g_return_if_fail (LD_IS_SYMBOL (self));
|
2010-10-27 15:52:36 +02:00
|
|
|
g_return_if_fail (area != NULL);
|
|
|
|
|
|
|
|
klass = LD_SYMBOL_GET_CLASS (self);
|
|
|
|
g_return_if_fail (klass->get_area != NULL);
|
|
|
|
klass->get_area (self, area);
|
2010-10-24 13:43:41 +02:00
|
|
|
}
|
|
|
|
|
2010-09-20 18:18:30 +02:00
|
|
|
/**
|
|
|
|
* ld_symbol_draw:
|
|
|
|
* @self: A symbol object.
|
2010-09-25 16:03:48 +02:00
|
|
|
* @cr: A cairo surface to be drawn on.
|
2010-09-20 18:18:30 +02:00
|
|
|
*
|
|
|
|
* Draw the symbol onto a Cairo surface.
|
|
|
|
*/
|
|
|
|
void
|
2010-09-25 20:59:20 +02:00
|
|
|
ld_symbol_draw (LdSymbol *self, cairo_t *cr)
|
2010-09-20 18:18:30 +02:00
|
|
|
{
|
2010-09-25 20:59:20 +02:00
|
|
|
LdSymbolClass *klass;
|
|
|
|
|
|
|
|
g_return_if_fail (LD_IS_SYMBOL (self));
|
|
|
|
g_return_if_fail (cr != NULL);
|
|
|
|
|
|
|
|
klass = LD_SYMBOL_GET_CLASS (self);
|
2010-10-27 15:52:36 +02:00
|
|
|
g_return_if_fail (klass->draw != NULL);
|
|
|
|
klass->draw (self, cr);
|
2010-09-20 18:18:30 +02:00
|
|
|
}
|