//===--- BasicBlockUtils.h - Utilities for SILBasicBlock -------*- 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 // //===----------------------------------------------------------------------===// #ifndef SWIFT_SIL_DEADENDBLOCKS_H #define SWIFT_SIL_DEADENDBLOCKS_H #include "llvm/ADT/SetVector.h" namespace swift { class SILFunction; class SILBasicBlock; /// A utility for finding dead-end blocks. /// /// Dead-end blocks are blocks from which there is no path to the function exit /// (either return or throw). These are blocks which end with an unreachable /// instruction and blocks from which all paths end in "unreachable" blocks. /// This utility is needed to determine if the a value definition can have a /// lack of users ignored along a specific path. class DeadEndBlocks { llvm::SetVector ReachableBlocks; const SILFunction *F; bool isComputed = false; void compute(); public: DeadEndBlocks(const SILFunction *F) : F(F) {} /// Returns true if \p BB is a dead-end block. bool isDeadEnd(SILBasicBlock *BB) { if (!isComputed) { // Lazily compute the dataflow. compute(); isComputed = true; } return ReachableBlocks.count(BB) == 0; } }; } // namespace swift #endif