Files
swift-mirror/include/swift/AST/PrintOptions.h
Argyrios Kyrtzidis 442f34378f [ASTPrinter] Avoid printing @effects attribute by default.
We don't want to expose this attribute currently.
Test on the SourceKit side.

rdar://18262482

Swift SVN r21774
2014-09-08 16:29:56 +00:00

184 lines
6.0 KiB
C++

//===--- PrintOptions.h - AST printing options ------------------*- C++ -*-===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2015 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See http://swift.org/LICENSE.txt for license information
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
#ifndef SWIFT_AST_PRINTOPTIONS_H
#define SWIFT_AST_PRINTOPTIONS_H
#include "swift/AST/Attr.h"
#include <vector>
namespace swift {
class GenericParamList;
enum DeclAttrKind : unsigned;
/// Options for printing AST nodes.
///
/// A default-constructed PrintOptions is suitable for printing to users;
/// there are also factory methods for specific use cases.
struct PrintOptions {
/// \brief The indentation width.
unsigned Indent = 2;
/// \brief Whether to print function definitions.
bool FunctionDefinitions = false;
/// \brief Whether to print '{ get set }' on readwrite computed properties.
bool PrintGetSetOnRWProperties = true;
/// \brief Whether to print type definitions.
bool TypeDefinitions = false;
/// \brief Whether to print variable initializers.
bool VarInitializers = false;
/// \brief Whether to print a placeholder for default parameters.
bool PrintDefaultParameterPlaceholder = true;
/// \brief Whether to prefer printing TypeReprs instead of Types,
/// if a TypeRepr is available. This allows us to print the original
/// spelling of the type name.
///
/// \note This should be \c true when printing AST with the intention show
/// it to the user.
bool PreferTypeRepr = true;
/// \brief Whether to print fully qualified Types.
bool FullyQualifiedTypes = false;
/// \brief Print fully qualified types if our heuristics say that a certain
/// type might be ambiguous.
bool FullyQualifiedTypesIfAmbiguous = false;
/// \brief Print Swift.Array and Swift.Optional with sugared syntax
/// ([] and ?), even if there are no sugar type nodes.
bool SynthesizeSugarOnTypes = false;
/// \brief If true, the printer will explode a pattern like this:
/// \code
/// var (a, b) = f()
/// \endcode
/// into multiple variable declarations.
///
/// For this option to work correctly, \c VarInitializers should be
/// \c false.
bool ExplodePatternBindingDecls = false;
/// \brief Whether to print implicit parts of the AST.
bool SkipImplicit = false;
/// \brief Whether to print unavailable parts of the AST.
bool SkipUnavailable = false;
/// Whether to skip internal stdlib declarations.
bool SkipPrivateStdlibDecls = false;
/// Whether to print attributes.
bool SkipAttributes = false;
/// Whether to print keywords like 'func'.
bool SkipIntroducerKeywords = false;
/// Whether to print a long attribute like '\@availability' on a separate line
/// from the declaration or other attributes.
bool PrintLongAttrsOnSeparateLines = false;
bool PrintImplicitAttrs = true;
/// List of attribute kinds that should not be printed.
std::vector<DeclAttrKind> ExcludeAttrList = { DAK_Transparent, DAK_Effects };
/// List of attribute kinds that should be printed exclusively.
/// Empty means allow all.
std::vector<DeclAttrKind> ExclusiveAttrList;
/// Whether to print function representation attributes on function types:
/// '@thin' or '@objc_block'.
bool PrintFunctionRepresentationAttrs = true;
/// Whether to print storage representation attributes on types, e.g.
/// '@sil_weak', '@sil_unmanaged'.
bool PrintStorageRepresentationAttrs = false;
/// Whether to print 'override' keyword on overridden decls.
bool PrintOverrideKeyword = true;
/// Whether to print accessibility information on all value decls.
bool PrintAccessibility = false;
/// Print all decls that have at least this level of access.
Accessibility AccessibilityFilter = Accessibility::Private;
/// Whether we are printing for sil.
bool PrintForSIL = false;
/// Whether we are printing part of SIL body.
bool PrintInSILBody = false;
enum class ArgAndParamPrintingMode {
ArgumentOnly,
BothIfDifferent,
BothAlways,
};
/// How to print the keyword argument and parameter name in functions.
ArgAndParamPrintingMode ArgAndParamPrinting =
ArgAndParamPrintingMode::BothIfDifferent;
/// \brief Whether to print documentation comments attached to declarations.
/// Note that this may print documentation comments from related declarations
/// (e.g. the overridden method in the superclass) if such comment is found.
bool PrintDocumentationComments = false;
/// \brief Whether to print regular comments from clang module headers.
bool PrintRegularClangComments = false;
/// \brief Print dependent types as references into this generic parameter
/// list.
GenericParamList *ContextGenericParams = nullptr;
/// Retrieve the set of options for verbose printing to users.
static PrintOptions printVerbose() {
PrintOptions result;
result.TypeDefinitions = true;
result.VarInitializers = true;
result.PrintDefaultParameterPlaceholder = true;
result.PrintDocumentationComments = true;
result.PrintRegularClangComments = true;
result.PrintLongAttrsOnSeparateLines = true;
return result;
}
/// Retrieve the set of options suitable for printing SIL functions.
static PrintOptions printSIL() {
PrintOptions result;
result.PrintLongAttrsOnSeparateLines = true;
result.PrintStorageRepresentationAttrs = true;
result.PrintForSIL = true;
result.PrintInSILBody = true;
return result;
}
/// \brief Retrieve the set of options that prints everything.
///
/// This is only intended for debug output.
static PrintOptions printEverything() {
PrintOptions result = printVerbose();
result.ExcludeAttrList.clear();
result.PrintStorageRepresentationAttrs = true;
result.PrintAccessibility = true;
return result;
}
};
}
#endif // LLVM_SWIFT_AST_PRINTOPTIONS_H