summaryrefslogtreecommitdiff
path: root/src/format
diff options
context:
space:
mode:
Diffstat (limited to 'src/format')
-rw-r--r--src/format/format-int.h5
-rw-r--r--src/format/format.c35
2 files changed, 34 insertions, 6 deletions
diff --git a/src/format/format-int.h b/src/format/format-int.h
index 6a3be81..eb1d0d2 100644
--- a/src/format/format-int.h
+++ b/src/format/format-int.h
@@ -119,6 +119,11 @@ struct _GBinFormatClass
format_complete_analysis_fc complete; /* Terminaison d'analyse */
+ /* Signaux */
+
+ void (* symbol_added) (GBinFormat *, GBinSymbol *);
+ void (* symbol_removed) (GBinFormat *, GBinSymbol *);
+
};
diff --git a/src/format/format.c b/src/format/format.c
index 05e4597..b43f78f 100644
--- a/src/format/format.c
+++ b/src/format/format.c
@@ -93,6 +93,22 @@ static void g_binary_format_class_init(GBinFormatClass *klass)
object->dispose = (GObjectFinalizeFunc/* ! */)g_binary_format_dispose;
object->finalize = (GObjectFinalizeFunc)g_binary_format_finalize;
+ g_signal_new("symbol-added",
+ G_TYPE_BIN_FORMAT,
+ G_SIGNAL_RUN_LAST,
+ G_STRUCT_OFFSET(GBinFormatClass, symbol_added),
+ NULL, NULL,
+ g_cclosure_marshal_VOID__OBJECT,
+ G_TYPE_NONE, 1, G_TYPE_OBJECT);
+
+ g_signal_new("symbol-removed",
+ G_TYPE_BIN_FORMAT,
+ G_SIGNAL_RUN_LAST,
+ G_STRUCT_OFFSET(GBinFormatClass, symbol_removed),
+ NULL, NULL,
+ g_cclosure_marshal_VOID__OBJECT,
+ G_TYPE_NONE, 1, G_TYPE_OBJECT);
+
}
@@ -835,6 +851,9 @@ bool g_binary_format_add_symbol(GBinFormat *format, GBinSymbol *symbol)
g_binary_format_lock_unlock_symbols_wr(format, false);
+ if (result)
+ g_signal_emit_by_name(format, "symbol-added", symbol);
+
return result;
}
@@ -855,20 +874,17 @@ bool g_binary_format_add_symbol(GBinFormat *format, GBinSymbol *symbol)
static void _g_binary_format_remove_symbol(GBinFormat *format, size_t index)
{
- /**
- * TODO : envoyer un signal pour avertir les opérandes concernées.
- */
-
assert(g_atomic_int_get(&format->sym_locked) == 1);
assert(index < format->sym_count);
+ g_object_unref(G_OBJECT(format->symbols[index]));
+
if ((index + 1) < format->sym_count)
memmove(&format->symbols[index], &format->symbols[index + 1],
(format->sym_count - index - 1) * sizeof(GBinSymbol *));
- format->symbols = (GBinSymbol **)realloc(format->symbols,
- --format->sym_count * sizeof(GBinSymbol *));
+ format->symbols = realloc(format->symbols, --format->sym_count * sizeof(GBinSymbol *));
}
@@ -891,6 +907,8 @@ void g_binary_format_remove_symbol(GBinFormat *format, GBinSymbol *symbol)
bool found; /* Jeton de présence */
size_t index; /* Indice du point de retrait */
+ g_object_ref(G_OBJECT(symbol));
+
g_binary_format_lock_unlock_symbols_wr(format, true);
found = bsearch_index(&symbol, format->symbols, format->sym_count,
@@ -901,6 +919,11 @@ void g_binary_format_remove_symbol(GBinFormat *format, GBinSymbol *symbol)
g_binary_format_lock_unlock_symbols_wr(format, false);
+ if (found)
+ g_signal_emit_by_name(format, "symbol-removed", symbol);
+
+ g_object_unref(G_OBJECT(symbol));
+
}