2016-11-30 10:55:10 +00:00
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @brief Gestion de l'affichage.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __HUFFMAN_DISPLAY_H_INCLUDED__
|
|
|
|
#define __HUFFMAN_DISPLAY_H_INCLUDED__
|
2016-10-25 04:51:07 +00:00
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2016-11-20 13:33:55 +00:00
|
|
|
#include "common.h"
|
|
|
|
|
2016-11-30 10:55:10 +00:00
|
|
|
//! \{
|
2016-11-19 20:40:02 +00:00
|
|
|
typedef struct HufVertex HufVertex;
|
|
|
|
typedef HufVertex* HufTree;
|
2016-11-30 10:55:10 +00:00
|
|
|
//! \}
|
2016-10-28 14:35:50 +00:00
|
|
|
|
|
|
|
/**
|
2016-11-30 10:55:10 +00:00
|
|
|
* @brief Écrire un message de débogage sur la sortie d'erreurs.
|
|
|
|
*
|
|
|
|
* Cette fonction n'a aucun effet si l'affichage des messages de débogage
|
|
|
|
* ne sont pas activés, sinon le message est affiché dans @c stderr.
|
|
|
|
* @param format Format d'affichage à la printf.
|
|
|
|
* @param ... Variables pour l'affichage.
|
2016-10-28 14:35:50 +00:00
|
|
|
*/
|
|
|
|
void printVerbose(const char* format, ...);
|
|
|
|
|
|
|
|
/**
|
2016-11-30 10:55:10 +00:00
|
|
|
* @brief Activer ou désactiver l'affichage des messages de débogage.
|
|
|
|
*
|
|
|
|
* Si le paramètre est vrai, les appels suivants à @c printVerbose seront
|
|
|
|
* affichés sur la sortie d'erreurs. Sinon, ils n'auront aucun effet.
|
|
|
|
* @param enable Activer ou désactiver l'affichage.
|
2016-10-28 14:35:50 +00:00
|
|
|
*/
|
2016-11-30 10:55:10 +00:00
|
|
|
void setVerbose(int enable);
|
2016-10-28 14:35:50 +00:00
|
|
|
|
|
|
|
/**
|
2016-11-30 10:55:10 +00:00
|
|
|
* @brief Vérifie si les messages de débogage sont activés ou non.
|
2016-10-28 14:35:50 +00:00
|
|
|
*/
|
|
|
|
int isVerbose();
|
|
|
|
|
2016-10-25 04:51:07 +00:00
|
|
|
/**
|
2016-11-30 10:55:10 +00:00
|
|
|
* @brief Afficher sur la sortie d'erreurs une représentation de l'arbre
|
|
|
|
* passé en paramètre.
|
|
|
|
*
|
|
|
|
* @param tree L'arbre à afficher.
|
2016-10-25 04:51:07 +00:00
|
|
|
*/
|
|
|
|
void printTree(HufTree tree);
|
|
|
|
|
|
|
|
/**
|
2016-11-30 10:55:10 +00:00
|
|
|
* @brief Afficher sur la sortie d'erreurs le tableau associant les caractères
|
|
|
|
* à leur effectif d'apparition passé en argument.
|
|
|
|
*
|
|
|
|
* @param counts Tableau d'association des effectifs.
|
|
|
|
* @param total Nombre total de caractères.
|
|
|
|
* @param size Taille du tableau @p counts.
|
2016-10-25 04:51:07 +00:00
|
|
|
*/
|
2016-11-30 10:55:10 +00:00
|
|
|
void printCountsTable(bytecount* counts, bytecount total, size_t size);
|
2016-10-25 04:51:07 +00:00
|
|
|
|
|
|
|
/**
|
2016-11-30 10:55:10 +00:00
|
|
|
* *@brief Afficher sur la sortie d'erreurs le tableau associant les caractères
|
|
|
|
* à leur étiquette passé en argument.
|
|
|
|
*
|
|
|
|
* @param labels Tableau d'association des étiquettes.
|
|
|
|
* @param size Taille du tableau @p labels.
|
2016-10-25 04:51:07 +00:00
|
|
|
*/
|
2016-11-30 10:55:10 +00:00
|
|
|
void printLabelsTable(char** labels, size_t size);
|
2016-10-25 04:51:07 +00:00
|
|
|
|
2016-11-30 10:55:10 +00:00
|
|
|
#endif // __HUFFMAN_DISPLAY_H_INCLUDED__
|