mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
c2de5980d3
All of these existed because MSVC 2013 was unable to synthesize default move ctors. We recently dropped support for it so all that error-prone boilerplate can go. No functionality change intended. llvm-svn: 284721
46 lines
1.2 KiB
C++
46 lines
1.2 KiB
C++
//===- llvm/IR/UseListOrder.h - LLVM Use List Order -------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file has structures and command-line options for preserving use-list
|
|
// order.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_IR_USELISTORDER_H
|
|
#define LLVM_IR_USELISTORDER_H
|
|
|
|
#include <cstddef>
|
|
#include <vector>
|
|
|
|
namespace llvm {
|
|
|
|
class Module;
|
|
class Function;
|
|
class Value;
|
|
|
|
/// \brief Structure to hold a use-list order.
|
|
struct UseListOrder {
|
|
const Value *V;
|
|
const Function *F;
|
|
std::vector<unsigned> Shuffle;
|
|
|
|
UseListOrder(const Value *V, const Function *F, size_t ShuffleSize)
|
|
: V(V), F(F), Shuffle(ShuffleSize) {}
|
|
|
|
UseListOrder() : V(nullptr), F(nullptr) {}
|
|
UseListOrder(UseListOrder &&) = default;
|
|
UseListOrder &operator=(UseListOrder &&) = default;
|
|
};
|
|
|
|
typedef std::vector<UseListOrder> UseListOrderStack;
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_IR_USELISTORDER_H
|