/* Chrysalide - Outil d'analyse de fichiers binaires * global.c - conservation et accès aux variables globales * * Copyright (C) 2017 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 /* 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; /* 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 : queue = nouveau gestionnaire à mémoriser ou NULL. * * * * Description : Définit le gestionnaire de traitements parallèles courant. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void set_work_queue(GWorkQueue *queue) { assert(_queue == NULL); _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) { return _queue; } /****************************************************************************** * * * 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; } /****************************************************************************** * * * 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; } /****************************************************************************** * * * 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 : 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) { assert(_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) { assert(_project_notify == NULL); _project_notify = notify; }