Files
swift-mirror/include/swift/Frontend/FrontendOptions.h
Connor Wakamo e9cc548765 [frontend] Added support in FrontendOptions for denoting the primary input.
When a primary input is specified, output will only be generated for that input. (If a primary input is not specified, output will be generated for the whole module.)
This commit only adds the storage for the primary input; the primary input is not yet honored by the frontend, nor is it possible to specify the primary input.

Swift SVN r12148
2014-01-10 22:39:04 +00:00

130 lines
3.7 KiB
C++

//===--- FrontendOptions.h --------------------------------------*- 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_FRONTEND_FRONTENDOPTIONS_H
#define SWIFT_FRONTEND_FRONTENDOPTIONS_H
#include "llvm/ADT/Optional.h"
#include <string>
#include <vector>
namespace llvm {
class MemoryBuffer;
}
namespace swift {
class SelectedInput {
public:
/// The index of the input, in either FrontendOptions::InputFilenames or
/// FrontendOptions::InputBuffers, depending on this SelectedInput's
/// InputKind.
unsigned Index;
enum class InputKind {
/// Denotes a file input, in FrontendOptions::InputFilenames
Filename,
/// Denotes a buffer input, in FrontendOptions::InputBuffers
Buffer,
};
/// The kind of input which this SelectedInput represents.
InputKind Kind;
SelectedInput(unsigned Index, InputKind Kind) : Index(Index), Kind(Kind) {}
};
/// Options for controlling the behavior of the frontend.
class FrontendOptions {
public:
/// The names of input files to the frontend.
std::vector<std::string> InputFilenames;
/// Input buffers which may override the file contents of input files.
std::vector<llvm::MemoryBuffer *> InputBuffers;
/// The input for which output should be generated. If not set, output will
/// be generated for the whole module.
llvm::Optional<SelectedInput> PrimaryInput;
/// The name of the primary output file which should be created
/// by the frontend.
std::string OutputFilename;
/// The name of the module which the frontend is building.
std::string ModuleName;
enum ActionType {
Parse, ///< Parse and type-check only
DumpParse, ///< Parse only and dump AST
DumpAST, ///< Parse, type-check, and dump AST
PrintAST, ///< Parse, type-check, and pretty-print AST
EmitSILGen, ///< Emit raw SIL
EmitSIL, ///< Emit canonical SIL
EmitModuleOnly, ///< Emit module only
Immediate, ///< Immediate mode
REPL, ///< REPL mode
EmitAssembly, ///< Emit assembly
EmitIR, ///< Emit LLVM IR
EmitBC, ///< Emit LLVM BC
EmitObject, ///< Emit object file
};
/// Indicates the action the user requested that the frontend perform.
ActionType RequestedAction = Parse;
/// Indicates that type-checking should be disabled.
bool ParseOnly = false;
/// Indicates whether function body parsing should be delayed
/// until the end of all files.
bool DelayedFunctionBodyParsing = false;
/// Indicates that the frontend should emit "verbose" SIL
/// (if asked to emit SIL).
bool EmitVerboseSIL = false;
/// Path to a "module source list", which lists all files in the module.
/// Currently unused.
std::string ModuleSourceListPath;
/// Path to a file which should contain serialized diagnostics for this
/// frontend invocation.
std::string SerializedDiagnosticsPath;
/// Arguments which should be passed in immediate mode.
std::vector<std::string> ImmediateArgv;
/// Indicates whether or not the frontend should print statistics upon
/// termination.
bool PrintStats = false;
/// Indicates whether standard help should be shown.
bool PrintHelp = false;
/// Indicates whether full help (including "hidden" options) should be shown.
bool PrintHelpHidden = false;
/// Indicates whether the RequestedAction has output.
bool actionHasOutput();
};
}
#endif