[llvm] r186006 - Remove llvm/ADT/NullablePtr.h, there are no uses of it in-tree.
Argyrios Kyrtzidis
akyrtzi at gmail.com
Wed Jul 10 08:33:20 PDT 2013
Author: akirtzidis
Date: Wed Jul 10 10:33:20 2013
New Revision: 186006
URL: http://llvm.org/viewvc/llvm-project?rev=186006&view=rev
Log:
Remove llvm/ADT/NullablePtr.h, there are no uses of it in-tree.
Removed:
llvm/trunk/include/llvm/ADT/NullablePtr.h
Removed: llvm/trunk/include/llvm/ADT/NullablePtr.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/ADT/NullablePtr.h?rev=186005&view=auto
==============================================================================
--- llvm/trunk/include/llvm/ADT/NullablePtr.h (original)
+++ llvm/trunk/include/llvm/ADT/NullablePtr.h (removed)
@@ -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 <cassert>
-#include <cstddef>
-
-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 T>
-class NullablePtr {
- T *Ptr;
- struct PlaceHolder {};
-
-public:
- NullablePtr(T *P = 0) : Ptr(P) {}
-
- template<typename OtherT>
- NullablePtr(NullablePtr<OtherT> Other,
- typename enable_if<
- is_base_of<T, OtherT>,
- 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
More information about the llvm-commits
mailing list