Files
swift-mirror/include/swift/AST/DiagnosticsCommon.def
Alex Hoppen faa1720c48 [Diagnostics] Adjustments for DeclBaseName
Adjust the definition of some diagnostics that are already called with
DeclBaseNames so that the implicit conversion from DeclBaseName to
Identifier is no longer needed.

Adjust the call side of diagnostics which don't have to deal with
special names to pass an Identifier to the diagnostic.
2017-05-31 15:58:46 +02:00

93 lines
3.0 KiB
C++

//===--- DiagnosticsCommon.def - Diagnostics Text ---------------*- C++ -*-===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2017 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
//
// This file defines diagnostics that can be emitted across the whole compiler.
// Each diagnostic is described using one of three kinds (error, warning, or
// note) along with a unique identifier, category, options, and text, and is
// followed by a signature describing the diagnostic argument kinds.
//
//===----------------------------------------------------------------------===//
#if !(defined(DIAG) || (defined(ERROR) && defined(WARNING) && defined(NOTE)))
# error Must define either DIAG or the set {ERROR,WARNING,NOTE}
#endif
#ifndef ERROR
# define ERROR(ID,Options,Text,Signature) \
DIAG(ERROR,ID,Options,Text,Signature)
#endif
#ifndef WARNING
# define WARNING(ID,Options,Text,Signature) \
DIAG(WARNING,ID,Options,Text,Signature)
#endif
#ifndef NOTE
# define NOTE(ID,Options,Text,Signature) \
DIAG(NOTE,ID,Options,Text,Signature)
#endif
ERROR(invalid_diagnostic,none,
"INTERNAL ERROR: this diagnostic should not be produced", ())
ERROR(not_implemented,none,
"INTERNAL ERROR: feature not implemented: %0", (StringRef))
ERROR(error_opening_output,none,
"error opening '%0' for output: %1", (StringRef, StringRef))
ERROR(error_no_group_info,none,
"no group info found for file: '%0'", (StringRef))
NOTE(previous_decldef,none,
"previous %select{declaration|definition}0 of %1 is here",
(bool, DeclBaseName))
NOTE(brace_stmt_suggest_do,none,
"did you mean to use a 'do' statement?", ())
// Generic disambiguation
NOTE(while_parsing_as_left_angle_bracket,none,
"while parsing this '<' as a type parameter bracket", ())
// FIXME: This is used both as a parse error (a literal "super" outside a
// method) and a type-checker error ("super" in a method of a non-class type).
ERROR(super_not_in_class_method,none,
"'super' cannot be used outside of class members", ())
ERROR(class_func_not_in_class,none,
"class methods are only allowed within classes; "
"use 'static' to declare a static method", ())
ERROR(class_var_not_in_class,none,
"class properties are only allowed within classes; "
"use 'static' to declare a static property", ())
// FIXME: Used by both the parser and the type-checker.
ERROR(func_decl_without_brace,PointsToFirstBadToken,
"expected '{' in body of function declaration", ())
NOTE(convert_let_to_var,none,
"change 'let' to 'var' to make it mutable", ())
NOTE(note_typo_candidate,none,
"did you mean '%0'?", (StringRef))
#ifndef DIAG_NO_UNDEF
# if defined(DIAG)
# undef DIAG
# endif
# undef NOTE
# undef WARNING
# undef ERROR
#endif