1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
/* $Id$
*
* Copyright (C) 2007-2009 FAUmachine Team <info@faumachine.org>.
* This program is free software. You can redistribute it and/or modify it
* under the terms of the GNU General Public License, either version 2 of
* the License, or (at your option) any later version. See COPYING.
*/
#ifndef __ERROR_REGISTRY_HPP_INCLUDED
#define __ERROR_REGISTRY_HPP_INCLUDED
#include <list>
#include "frontend/reporting/CompileError.hpp"
namespace ast {
//! register errors or warnings
/** register errors or warnings during a SemanticCheck. */
class ErrorRegistry {
public:
/** register an error
* @param error error that should get registered.
*/
static void addError(CompileError *error);
/** register a warning.
* @param warning warning that should get registered.
*/
static void addWarning(CompileError *warning);
/** register a potential error
* @param error potential error
*/
static void addPotentialError(CompileError* error);
/** clear all potential errors.
*/
static void rejectPotentials(void);
/** move all potential to the error queue, which means that these
* have indeed been errors.
*/
static void acceptPotentials(void);
/** have any errors been reported yet?
* @return true if errors have been reported.
*/
static bool hasErrors(void);
/** have any warnings been reported yet?
* @return true, if there were warnings.
*/
static bool hasWarnings(void);
/** put all warnings to stream.
* @param stream stream to which warnings should get put to.
*/
static void putWarnings(std::ostream &stream);
/** put all errors to stream.
* @param stream stream to which errors should get put to.
*/
static void putErrors(std::ostream &stream);
/** release all reported errors and warnings and free memory. */
static void flushAll(void);
/** treat Warnings as errors (-Werror). Must only be set if no
* warnings have been registered yet.
* @param val true, to treat Warnings as errors, false otherwise.
*/
static void setWerror(bool val);
private:
/** compile errors */
static std::list<CompileError*> errors;
/** compile warnings */
static std::list<CompileError*> warnings;
/** potential errors */
static std::list<CompileError*> potentialErrors;
/** -Werror set? */
static bool werror;
};
}; /* namespace ast */
#endif /* __ERROR_REGISTRY_HPP_INCLUDED */
|