/* Chrysalide - Outil d'analyse de fichiers binaires
* global.c - conservation et accès aux variables globales
*
* Copyright (C) 2017-2024 Cyrille Bagard
*
* This file is part of Chrysalide.
*
* Chrysalide is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* Chrysalide is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Chrysalide. If not, see .
*/
#include "global.h"
#include "../glibext/helpers.h"
/* Décompte des émissions et réceptions */
static GMutex _network_mutex;
static size_t _bytes_received = 0;
static size_t _bytes_sent = 0;
/* Gestionnaire de tâches parallèles */
static GWorkQueue *_queue = NULL;
/******************************************************************************
* *
* Paramètres : received = quantité d'octets reçus jusqu'à présent. [OUT] *
* sent = quantité d'octets émis jusqu'à présent. [OUT] *
* *
* Description : Fournit les volumes d'octets échangés sur le réseau. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void get_network_stats(size_t *received, size_t *sent)
{
g_mutex_lock(&_network_mutex);
*received = _bytes_received;
*sent = _bytes_sent;
g_mutex_unlock(&_network_mutex);
}
/******************************************************************************
* *
* Paramètres : received = quantité d'octets reçus supplémentaire. *
* sent = quantité d'octets émis supplémentaire. *
* *
* Description : Augmente les volumes d'octets échangés sur le réseau. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void update_network_stats(size_t received, size_t sent)
{
g_mutex_lock(&_network_mutex);
_bytes_received += received;
_bytes_sent += sent;
g_mutex_unlock(&_network_mutex);
}
/******************************************************************************
* *
* Paramètres : queue = nouveau gestionnaire à mémoriser ou NULL. *
* *
* Description : Définit le gestionnaire de traitements parallèles courant. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void set_work_queue(/* __steal */GWorkQueue *queue)
{
if (_queue != NULL)
unref_object(_queue);
_queue = queue;
}
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Fournit le gestionnaire de traitements parallèles courant. *
* *
* Retour : Gestionnaire de traitements parallèles courant. *
* *
* Remarques : - *
* *
******************************************************************************/
GWorkQueue *get_work_queue(void)
{
ref_object(_queue);
return _queue;
}
#if 0
#include
/* Mode de fonctionnement */
static bool _batch_mode = false;
/* Gestionnaire de tâches parallèles */
//static GWorkQueue *_queue = NULL;
/* Explorateur de contenus */
static GContentExplorer *_explorer = NULL;
/* Résolveur de contenus */
static GContentResolver *_resolver = NULL;
/* Espace de noms racine pour ROST */
static GScanNamespace *_rost_root_ns = NULL;
/* Projet global actif */
static GStudyProject *_project = NULL;
/* Avertisseur de changement de projet principal */
static current_project_change_cb _project_notify = NULL;
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Note un mode d'exécution sans interface. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void set_batch_mode(void)
{
_batch_mode = true;
}
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Indique le mode d'exécution courant du programme. *
* *
* Retour : true si le fonctionnement est sans interface. *
* *
* Remarques : - *
* *
******************************************************************************/
bool is_batch_mode(void)
{
return _batch_mode;
}
/******************************************************************************
* *
* Paramètres : explorer = éventuelle adresse du nouveau gestionnaire. *
* *
* Description : Définit l'adresse de l'explorateur de contenus courant. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void set_current_content_explorer(GContentExplorer *explorer)
{
if (_explorer != NULL)
g_object_unref(G_OBJECT(_explorer));
_explorer = explorer;
if (explorer != NULL)
g_object_ref_sink(G_OBJECT(explorer));
}
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Fournit l'adresse de l'explorateur de contenus courant. *
* *
* Retour : Adresse de l'explorateur global ou NULL si aucun (!). *
* *
* Remarques : - *
* *
******************************************************************************/
GContentExplorer *get_current_content_explorer(void)
{
assert(_explorer != NULL);
g_object_ref(G_OBJECT(_explorer));
return _explorer;
}
/******************************************************************************
* *
* Paramètres : resolver = éventuelle adresse du nouveau gestionnaire. *
* *
* Description : Définit l'adresse du résolveur de contenus courant. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void set_current_content_resolver(GContentResolver *resolver)
{
if (_resolver != NULL)
g_object_unref(G_OBJECT(_resolver));
_resolver = resolver;
if (resolver != NULL)
g_object_ref_sink(G_OBJECT(resolver));
}
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Fournit l'adresse du résolveur de contenus courant. *
* *
* Retour : Adresse du résolveur global ou NULL si aucun (!). *
* *
* Remarques : - *
* *
******************************************************************************/
GContentResolver *get_current_content_resolver(void)
{
assert(_resolver != NULL);
g_object_ref(G_OBJECT(_resolver));
return _resolver;
}
/******************************************************************************
* *
* Paramètres : ns = espace de noms racine de ROST. *
* *
* Description : Définit l'adresse de l'espace de noms principal pour ROST. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void set_rost_root_namespace(GScanNamespace *ns)
{
if (_rost_root_ns != NULL)
g_object_unref(G_OBJECT(_rost_root_ns));
_rost_root_ns = ns;
if (ns != NULL)
g_object_ref_sink(G_OBJECT(ns));
}
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Fournit l'adresse de l'espace de noms principal pour ROST. *
* *
* Retour : Espace de noms racine de ROST ou NULL si aucun (!). *
* *
* Remarques : - *
* *
******************************************************************************/
GScanNamespace *get_rost_root_namespace(void)
{
assert(_rost_root_ns != NULL);
g_object_ref(G_OBJECT(_rost_root_ns));
return _rost_root_ns;
}
/******************************************************************************
* *
* Paramètres : project = éventuelle adresse du nouveau projet principal. *
* *
* Description : Définit l'adresse du projet courant. *
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void set_current_project(GStudyProject *project)
{
if (_project != NULL)
{
if (_project_notify != NULL)
_project_notify(_project, false);
g_object_unref(G_OBJECT(_project));
}
_project = project;
if (_project != NULL && _project_notify != NULL)
_project_notify(_project, true);
}
/******************************************************************************
* *
* Paramètres : - *
* *
* Description : Fournit l'adresse du projet courant. *
* *
* Retour : Adresse du projet ouvert ou NULL si aucun (!). *
* *
* Remarques : - *
* *
******************************************************************************/
GStudyProject *get_current_project(void)
{
if (_project != NULL)
g_object_ref(G_OBJECT(_project));
return _project;
}
/******************************************************************************
* *
* Paramètres : notify = procédure à appeler à chaque changement de project. *
* *
* Description : Enregistre une partie de code à avertir en cas de changement.*
* *
* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
void register_project_change_notification(current_project_change_cb notify)
{
_project_notify = notify;
}
#endif