mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
Add a generic 'capacity_in_bytes' function to allow inspection of memory usage of various data structures.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@136233 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
766c63e78b
commit
18dceba0bb
@ -540,6 +540,12 @@ private:
|
|||||||
++Ptr;
|
++Ptr;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template<typename KeyT, typename ValueT, typename KeyInfoT, typename ValueInfoT>
|
||||||
|
static inline size_t
|
||||||
|
capacity_in_bytes(const DenseMap<KeyT, ValueT, KeyInfoT, ValueInfoT> &X) {
|
||||||
|
return X.getMemorySize();
|
||||||
|
}
|
||||||
|
|
||||||
} // end namespace llvm
|
} // end namespace llvm
|
||||||
|
|
||||||
|
@ -78,21 +78,21 @@ protected:
|
|||||||
return BeginX == static_cast<const void*>(&FirstEl);
|
return BeginX == static_cast<const void*>(&FirstEl);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// size_in_bytes - This returns size()*sizeof(T).
|
|
||||||
size_t size_in_bytes() const {
|
|
||||||
return size_t((char*)EndX - (char*)BeginX);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// capacity_in_bytes - This returns capacity()*sizeof(T).
|
|
||||||
size_t capacity_in_bytes() const {
|
|
||||||
return size_t((char*)CapacityX - (char*)BeginX);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// grow_pod - This is an implementation of the grow() method which only works
|
/// grow_pod - This is an implementation of the grow() method which only works
|
||||||
/// on POD-like data types and is out of line to reduce code duplication.
|
/// on POD-like data types and is out of line to reduce code duplication.
|
||||||
void grow_pod(size_t MinSizeInBytes, size_t TSize);
|
void grow_pod(size_t MinSizeInBytes, size_t TSize);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
/// size_in_bytes - This returns size()*sizeof(T).
|
||||||
|
size_t size_in_bytes() const {
|
||||||
|
return size_t((char*)EndX - (char*)BeginX);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// capacity_in_bytes - This returns capacity()*sizeof(T).
|
||||||
|
size_t capacity_in_bytes() const {
|
||||||
|
return size_t((char*)CapacityX - (char*)BeginX);
|
||||||
|
}
|
||||||
|
|
||||||
bool empty() const { return BeginX == EndX; }
|
bool empty() const { return BeginX == EndX; }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -738,6 +738,11 @@ public:
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template<typename T, unsigned N>
|
||||||
|
static inline size_t capacity_in_bytes(const SmallVector<T, N> &X) {
|
||||||
|
return X.capacity_in_bytes();
|
||||||
|
}
|
||||||
|
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
|
||||||
namespace std {
|
namespace std {
|
||||||
|
30
include/llvm/Support/Capacity.h
Normal file
30
include/llvm/Support/Capacity.h
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
//===--- Capacity.h - Generic computation of ADT memory use -----*- 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 the capacity function that computes the amount of
|
||||||
|
// memory used by an ADT.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef LLVM_SUPPORT_CAPACITY_H
|
||||||
|
#define LLVM_SUPPORT_CAPACITY_H
|
||||||
|
|
||||||
|
namespace llvm {
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
static inline size_t capacity_in_bytes(const T &x) {
|
||||||
|
// This default definition of capacity should work for things like std::vector
|
||||||
|
// and friends. More specialized versions will work for others.
|
||||||
|
return x.capacity() * sizeof(typename T::value_type);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // end namespace llvm
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue
Block a user