diff options
author | Nandor Licker <n@ndor.email> | 2019-08-30 15:41:45 +0000 |
---|---|---|
committer | Nandor Licker <n@ndor.email> | 2019-08-30 15:41:45 +0000 |
commit | 5c8b94a672e78d92d058f146741277228f28f9dd (patch) | |
tree | f8d0851637cb87afc6da1f0149d47d0e395e614f /clang/lib/AST/Interp/Record.cpp | |
parent | 3fac668d837a92bfbabb1205027b830d709a3c42 (diff) | |
download | bcm5719-llvm-5c8b94a672e78d92d058f146741277228f28f9dd.tar.gz bcm5719-llvm-5c8b94a672e78d92d058f146741277228f28f9dd.zip |
Revert [Clang Interpreter] Initial patch for the constexpr interpreter
This reverts r370476 (git commit a5590950549719d0d9ea69ed164b0c8c0f4e02e6)
llvm-svn: 370481
Diffstat (limited to 'clang/lib/AST/Interp/Record.cpp')
-rw-r--r-- | clang/lib/AST/Interp/Record.cpp | 46 |
1 files changed, 0 insertions, 46 deletions
diff --git a/clang/lib/AST/Interp/Record.cpp b/clang/lib/AST/Interp/Record.cpp deleted file mode 100644 index 163d2376556..00000000000 --- a/clang/lib/AST/Interp/Record.cpp +++ /dev/null @@ -1,46 +0,0 @@ -//===--- Record.cpp - struct and class metadata for the VM ------*- C++ -*-===// -// -// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. -// See https://llvm.org/LICENSE.txt for license information. -// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception -// -//===----------------------------------------------------------------------===// - -#include "Record.h" - -using namespace clang; -using namespace clang::interp; - -Record::Record(const RecordDecl *Decl, BaseList &&SrcBases, - FieldList &&SrcFields, VirtualBaseList &&SrcVirtualBases, - unsigned VirtualSize, unsigned BaseSize) - : Decl(Decl), Bases(std::move(SrcBases)), Fields(std::move(SrcFields)), - BaseSize(BaseSize), VirtualSize(VirtualSize) { - for (Base &V : SrcVirtualBases) - VirtualBases.push_back({ V.Decl, V.Offset + BaseSize, V.Desc, V.Record }); - - for (Base &B : Bases) - BaseMap[B.Decl] = &B; - for (Field &F : Fields) - FieldMap[F.Decl] = &F; - for (Base &V : VirtualBases) - VirtualBaseMap[V.Decl] = &V; -} - -const Record::Field *Record::getField(const FieldDecl *FD) const { - auto It = FieldMap.find(FD); - assert(It != FieldMap.end() && "Missing field"); - return It->second; -} - -const Record::Base *Record::getBase(const RecordDecl *FD) const { - auto It = BaseMap.find(FD); - assert(It != BaseMap.end() && "Missing base"); - return It->second; -} - -const Record::Base *Record::getVirtualBase(const RecordDecl *FD) const { - auto It = VirtualBaseMap.find(FD); - assert(It != VirtualBaseMap.end() && "Missing virtual base"); - return It->second; -} |