Fix spello
authorChris Lattner <sabre@nondot.org>
Tue, 4 Nov 2003 23:37:40 +0000 (23:37 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 4 Nov 2003 23:37:40 +0000 (23:37 +0000)
Add negate overload

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9709 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/ConstantHandling.h
lib/VMCore/ConstantFold.h
lib/VMCore/ConstantFolding.h

index ef19cd257f8fdb360e188782bf0efbbed3e3f97e..a27283c44078038d648aaa932093e197ee13d316 100644 (file)
@@ -134,11 +134,15 @@ private:
 
 // Unary operators...
 inline Constant *operator~(const Constant &V) {
-  assert(V.getType()->isIntegral() && "Cannot invert non-intergral constant!");
+  assert(V.getType()->isIntegral() && "Cannot invert non-integral constant!");
   return ConstRules::get(V, V)->op_xor(&V,
                                     ConstantInt::getAllOnesValue(V.getType()));
 }
 
+inline Constant *operator-(const Constant &V) {
+  return ConstRules::get(V, V)->sub(Constant::getNullValue(V.getType()), &V);
+}
+
 // Standard binary operators...
 inline Constant *operator+(const Constant &V1, const Constant &V2) {
   assert(V1.getType() == V2.getType() && "Constant types must be identical!");
index ef19cd257f8fdb360e188782bf0efbbed3e3f97e..a27283c44078038d648aaa932093e197ee13d316 100644 (file)
@@ -134,11 +134,15 @@ private:
 
 // Unary operators...
 inline Constant *operator~(const Constant &V) {
-  assert(V.getType()->isIntegral() && "Cannot invert non-intergral constant!");
+  assert(V.getType()->isIntegral() && "Cannot invert non-integral constant!");
   return ConstRules::get(V, V)->op_xor(&V,
                                     ConstantInt::getAllOnesValue(V.getType()));
 }
 
+inline Constant *operator-(const Constant &V) {
+  return ConstRules::get(V, V)->sub(Constant::getNullValue(V.getType()), &V);
+}
+
 // Standard binary operators...
 inline Constant *operator+(const Constant &V1, const Constant &V2) {
   assert(V1.getType() == V2.getType() && "Constant types must be identical!");
index ef19cd257f8fdb360e188782bf0efbbed3e3f97e..a27283c44078038d648aaa932093e197ee13d316 100644 (file)
@@ -134,11 +134,15 @@ private:
 
 // Unary operators...
 inline Constant *operator~(const Constant &V) {
-  assert(V.getType()->isIntegral() && "Cannot invert non-intergral constant!");
+  assert(V.getType()->isIntegral() && "Cannot invert non-integral constant!");
   return ConstRules::get(V, V)->op_xor(&V,
                                     ConstantInt::getAllOnesValue(V.getType()));
 }
 
+inline Constant *operator-(const Constant &V) {
+  return ConstRules::get(V, V)->sub(Constant::getNullValue(V.getType()), &V);
+}
+
 // Standard binary operators...
 inline Constant *operator+(const Constant &V1, const Constant &V2) {
   assert(V1.getType() == V2.getType() && "Constant types must be identical!");