source: src/Common/SemanticError.h@ 6da49249

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors deferred_resn demangler enum forall-pointer-decay jacob/cs343-translation jenkins-sandbox new-ast new-ast-unique-expr no_list persistent-indexer pthread-emulation qualifiedEnum
Last change on this file since 6da49249 was 2e02851, checked in by Rob Schluntz <rschlunt@…>, 7 years ago

Add temporary warning for deprecated anonymous member declarations

  • Property mode set to 100644
File size: 3.3 KB
Line 
1//
2// Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
7// SemanticError.h --
8//
9// Author : Thierry Delisle
10// Created On : Mon May 18 07:44:20 2015
11// Last Modified By : Peter A. Buhr
12// Last Modified On : Wed May 16 15:01:23 2018
13// Update Count : 30
14//
15
16#pragma once
17
18#include "ErrorObjects.h"
19#include <cstring>
20
21//-----------------------------------------------------------------------------
22// Errors
23
24extern bool SemanticErrorThrow;
25
26__attribute__((noreturn)) void SemanticError( CodeLocation location, std::string error );
27
28template< typename T >
29__attribute__((noreturn)) static inline void SemanticError( const T * obj, const std::string & error ) {
30 SemanticError( obj->location, toString( error, obj ) );
31}
32
33template< typename T >
34__attribute__((noreturn)) static inline void SemanticError( CodeLocation location, const T * obj, const std::string & error ) {
35 SemanticError( location, toString( error, obj ) );
36}
37
38//-----------------------------------------------------------------------------
39// Warnings
40
41enum class Severity {
42 Suppress,
43 Warn,
44 Error,
45 Critical
46};
47
48struct WarningData {
49 const char * const name;
50 const char * const message;
51 const Severity default_severity;
52};
53
54constexpr WarningData WarningFormats[] = {
55 {"self-assign" , "self assignment of expression: %s" , Severity::Warn},
56 {"reference-conversion" , "rvalue to reference conversion of rvalue: %s" , Severity::Warn},
57 {"qualifiers-zero_t-one_t", "questionable use of type qualifier %s with %s", Severity::Warn},
58 {"aggregate-forward-decl" , "forward declaration of nested aggregate: %s" , Severity::Warn},
59};
60
61enum class Warning {
62 SelfAssignment,
63 RvalueToReferenceConversion,
64 BadQualifiersZeroOne,
65 AggrForwardDecl,
66 NUMBER_OF_WARNINGS, //This MUST be the last warning
67};
68
69static_assert(
70 (sizeof(WarningFormats) / sizeof(WarningFormats[0])) == ((unsigned long)Warning::NUMBER_OF_WARNINGS),
71 "Each warning format should have a corresponding warning enum value"
72);
73
74#define SemanticWarning(loc, id, ...) SemanticWarningImpl(loc, id, WarningFormats[(int)id].message, __VA_ARGS__)
75
76void SemanticWarningImpl (CodeLocation loc, Warning warn, const char * const fmt, ...) __attribute__((format(printf, 3, 4)));
77
78void SemanticWarning_SuppressAll ();
79void SemanticWarning_EnableAll ();
80void SemanticWarning_WarningAsError();
81void SemanticWarning_Set (const char * const name, Severity s);
82
83// SKULLDUGGERY: cfa.cc is built before SemanticError.cc but needs this routine.
84static inline bool SemanticWarning_Exist(const char * const name) {
85 for ( const auto & w : WarningFormats ) {
86 if ( std::strcmp( name, w.name ) == 0 ) return true;
87 }
88 return false;
89}
90
91//-----------------------------------------------------------------------------
92// Helpers
93namespace ErrorHelpers {
94 const std::string & error_str();
95 const std::string & warning_str();
96 const std::string & bold_ttycode();
97 const std::string & reset_font_ttycode();
98
99 std::string make_bold( const std::string & str );
100
101 struct bold {};
102 std::ostream & operator<<(std::ostream & os, bold);
103
104 struct reset_font {};
105 std::ostream & operator<<(std::ostream & os, reset_font);
106}
107
108// Local Variables: //
109// tab-width: 4 //
110// mode: c++ //
111// compile-command: "make install" //
112// End: //
Note: See TracBrowser for help on using the repository browser.