diff options
Diffstat (limited to 'src/analysis/types/override.c')
-rw-r--r-- | src/analysis/types/override.c | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/src/analysis/types/override.c b/src/analysis/types/override.c index 841f10c..2beb934 100644 --- a/src/analysis/types/override.c +++ b/src/analysis/types/override.c @@ -65,6 +65,12 @@ static void g_override_type_dispose(GOverrideType *); /* Procède à la libération totale de la mémoire. */ static void g_override_type_finalize(GOverrideType *); +/* Charge un objet depuis une mémoire tampon. */ +static bool g_override_type_load(GOverrideType *, GObjectStorage *, packed_buffer *); + +/* Sauvegarde un objet dans une mémoire tampon. */ +static bool g_override_type_store(const GOverrideType *, GObjectStorage *, packed_buffer *); + /* Calcule une empreinte pour un type de données. */ static guint g_override_type_hash(const GOverrideType *); @@ -104,6 +110,9 @@ static void g_override_type_class_init(GOverrideTypeClass *klass) type = G_DATA_TYPE_CLASS(klass); + type->load = (type_load_fc)g_override_type_load; + type->store = (type_store_fc)g_override_type_store; + type->hash = (type_hash_fc)g_override_type_hash; type->dup = (type_dup_fc)g_override_type_dup; type->to_string = (type_to_string_fc)g_override_type_to_string; @@ -233,6 +242,117 @@ GDataType *g_override_type_new_with_covariant(GDataType *base, const call_offset /****************************************************************************** * * +* Paramètres : type = type de données à constuire. * +* storage = conservateur de données à manipuler ou NULL. * +* pbuf = zone tampon à remplir. * +* * +* Description : Charge un objet depuis une mémoire tampon. * +* * +* Retour : Bilan de l'opération. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static bool g_override_type_load(GOverrideType *type, GObjectStorage *storage, packed_buffer *pbuf) +{ + bool result; /* Bilan à retourner */ + size_t i; /* Boucle de parcours */ + call_offset_t *offset; /* Décalage à traiter */ + leb128_t value; /* Valeur à dépiler */ + bool status; /* Valeur booléenne */ + + result = G_DATA_TYPE_CLASS(g_override_type_parent_class)->load(G_DATA_TYPE(type), storage, pbuf); + if (!result) goto exit; + + result = g_serializable_object_load(G_SERIALIZABLE_OBJECT(type->base), storage, pbuf); + if (!result) goto exit; + + for (i = 0; i < 2; i++) + { + offset = &type->offsets[i]; + + result = unpack_leb128(&value, pbuf); + if (!result) goto exit; + + offset->values[0] = value; + + result = unpack_leb128(&value, pbuf); + if (!result) goto exit; + + offset->values[1] = value; + + result = extract_packed_buffer(pbuf, &status, sizeof(uint8_t), false); + if (!result) goto exit; + + offset->virtual = (status == 0x01); + + } + + result = extract_packed_buffer(pbuf, &status, sizeof(uint8_t), false); + if (!result) goto exit; + + type->with_covariant = (status == 0x01); + + exit: + + return result; + +} + + +/****************************************************************************** +* * +* Paramètres : type = type de données à consulter. * +* storage = conservateur de données à manipuler ou NULL. * +* pbuf = zone tampon à remplir. * +* * +* Description : Sauvegarde un objet dans une mémoire tampon. * +* * +* Retour : Bilan de l'opération. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static bool g_override_type_store(const GOverrideType *type, GObjectStorage *storage, packed_buffer *pbuf) +{ + bool result; /* Bilan à retourner */ + size_t i; /* Boucle de parcours */ + const call_offset_t *offset; /* Décalage à traiter */ + + result = G_DATA_TYPE_CLASS(g_override_type_parent_class)->store(G_DATA_TYPE(type), storage, pbuf); + if (!result) goto exit; + + result = g_serializable_object_store(G_SERIALIZABLE_OBJECT(type->base), storage, pbuf); + if (!result) goto exit; + + for (i = 0; i < 2; i++) + { + offset = &type->offsets[i]; + + result = pack_leb128((leb128_t []){ offset->values[0] }, pbuf); + if (!result) goto exit; + + result = pack_leb128((leb128_t []){ offset->values[1] }, pbuf); + if (!result) goto exit; + + result = extend_packed_buffer(pbuf, (uint8_t []){ offset->virtual ? 0x01 : 0x00 }, sizeof(uint8_t), false); + if (!result) goto exit; + + } + + result = extend_packed_buffer(pbuf, (uint8_t []){ type->with_covariant ? 0x01 : 0x00 }, sizeof(uint8_t), false); + + exit: + + return result; + +} + + +/****************************************************************************** +* * * Paramètres : type = type à consulter. * * * * Description : Calcule une empreinte pour un type de données. * |