/* 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 <http://www.gnu.org/licenses/>.
 */


#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 <assert.h>



/* 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