diff options
-rw-r--r-- | src/module.c | 21 | ||||
-rw-r--r-- | src/node.c | 6 |
2 files changed, 23 insertions, 4 deletions
diff --git a/src/module.c b/src/module.c index a6fe461..d3ae675 100644 --- a/src/module.c +++ b/src/module.c @@ -526,6 +526,26 @@ ganv_module_update(GanvItem* item, int flags) } static void +ganv_module_draw(GanvItem* item, + cairo_t* cr, + int cx, int cy, + int width, int height) +{ + GanvModule* module = GANV_MODULE(item); + + // Draw box and label + if (GANV_ITEM_CLASS(parent_class)->draw) { + (*GANV_ITEM_CLASS(parent_class)->draw)(item, cr, cx, cy, width, height); + } + + // Draw ports + FOREACH_PORT(module->impl->ports, p) { + GANV_ITEM_GET_CLASS(GANV_ITEM(*p))->draw( + GANV_ITEM(*p), cr, cx, cy, width, height); + } +} + +static void ganv_module_move_to(GanvNode* node, double x, double y) @@ -567,6 +587,7 @@ ganv_module_class_init(GanvModuleClass* class) object_class->destroy = ganv_module_destroy; item_class->update = ganv_module_update; + item_class->draw = ganv_module_draw; node_class->move = ganv_module_move; node_class->move_to = ganv_module_move_to; @@ -108,11 +108,9 @@ ganv_node_draw(GanvItem* item, int cx, int cy, int width, int height) { - if (GANV_ITEM_CLASS(parent_class)->draw) { - (*GANV_ITEM_CLASS(parent_class)->draw)(item, cr, cx, cy, width, height); - } - GanvNode* node = GANV_NODE(item); + + // Draw label if (node->impl->label) { GanvItem* label_item = GANV_ITEM(node->impl->label); GANV_ITEM_GET_CLASS(label_item)->draw(label_item, cr, cx, cy, width, height); |