summaryrefslogtreecommitdiff
path: root/src/analysis/types/override.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/analysis/types/override.c')
-rw-r--r--src/analysis/types/override.c120
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. *