From 10b2997913457fe3b00f88a350fa4143dcdc6b1c Mon Sep 17 00:00:00 2001 From: Argyrios Kyrtzidis Date: Wed, 10 Jul 2013 15:33:20 +0000 Subject: Remove llvm/ADT/NullablePtr.h, there are no uses of it in-tree. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186006 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/ADT/NullablePtr.h | 62 ------------------------------------------ 1 file changed, 62 deletions(-) delete mode 100644 include/llvm/ADT/NullablePtr.h (limited to 'include/llvm/ADT') diff --git a/include/llvm/ADT/NullablePtr.h b/include/llvm/ADT/NullablePtr.h deleted file mode 100644 index e66c1d08cd..0000000000 --- a/include/llvm/ADT/NullablePtr.h +++ /dev/null @@ -1,62 +0,0 @@ -//===- llvm/ADT/NullablePtr.h - A pointer that allows null ------*- C++ -*-===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file defines and implements the NullablePtr class. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_ADT_NULLABLEPTR_H -#define LLVM_ADT_NULLABLEPTR_H - -#include "llvm/Support/type_traits.h" -#include -#include - -namespace llvm { -/// NullablePtr pointer wrapper - NullablePtr is used for APIs where a -/// potentially-null pointer gets passed around that must be explicitly handled -/// in lots of places. By putting a wrapper around the null pointer, it makes -/// it more likely that the null pointer case will be handled correctly. -template -class NullablePtr { - T *Ptr; - struct PlaceHolder {}; - -public: - NullablePtr(T *P = 0) : Ptr(P) {} - - template - NullablePtr(NullablePtr Other, - typename enable_if< - is_base_of, - PlaceHolder - >::type = PlaceHolder()) : Ptr(Other.getPtrOrNull()) {} - - bool isNull() const { return Ptr == 0; } - bool isNonNull() const { return Ptr != 0; } - - /// get - Return the pointer if it is non-null. - const T *get() const { - assert(Ptr && "Pointer wasn't checked for null!"); - return Ptr; - } - - /// get - Return the pointer if it is non-null. - T *get() { - assert(Ptr && "Pointer wasn't checked for null!"); - return Ptr; - } - - T *getPtrOrNull() { return Ptr; } - const T *getPtrOrNull() const { return Ptr; } -}; - -} // end namespace llvm - -#endif -- cgit v1.2.3