svf-tools 1.0.1135 → 1.0.1137

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svf-tools",
3
- "version": "1.0.1135",
3
+ "version": "1.0.1137",
4
4
  "description": "* <b>[TypeClone](https://github.com/SVF-tools/SVF/wiki/TypeClone) published in our [ECOOP paper](https://yuleisui.github.io/publications/ecoop20.pdf) is now available in SVF </b> * <b>SVF now uses a single script for its build. Just type [`source ./build.sh`](https://github.com/SVF-tools/SVF/blob/master/build.sh) in your terminal, that's it!</b> * <b>SVF now supports LLVM-10.0.0! </b> * <b>We thank [bsauce](https://github.com/bsauce) for writing a user manual of SVF ([link1](https://www.jianshu.com/p/068a08ec749c) and [link2](https://www.jianshu.com/p/777c30d4240e)) in Chinese </b> * <b>SVF now supports LLVM-9.0.0 (Thank [Byoungyoung Lee](https://github.com/SVF-tools/SVF/issues/142) for his help!). </b> * <b>SVF now supports a set of [field-sensitive pointer analyses](https://yuleisui.github.io/publications/sas2019a.pdf). </b> * <b>[Use SVF as an external lib](https://github.com/SVF-tools/SVF/wiki/Using-SVF-as-a-lib-in-your-own-tool) for your own project (Contributed by [Hongxu Chen](https://github.com/HongxuChen)). </b> * <b>SVF now supports LLVM-7.0.0. </b> * <b>SVF now supports Docker. [Try SVF in Docker](https://github.com/SVF-tools/SVF/wiki/Try-SVF-in-Docker)! </b> * <b>SVF now supports [LLVM-6.0.0](https://github.com/svf-tools/SVF/pull/38) (Contributed by [Jack Anthony](https://github.com/jackanth)). </b> * <b>SVF now supports [LLVM-4.0.0](https://github.com/svf-tools/SVF/pull/23) (Contributed by Jared Carlson. Thank [Jared](https://github.com/jcarlson23) and [Will](https://github.com/dtzWill) for their in-depth [discussions](https://github.com/svf-tools/SVF/pull/18) about updating SVF!) </b> * <b>SVF now supports analysis for C++ programs.</b> <br />",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -62,6 +62,9 @@ public:
62
62
  /// Allocate an object ID as determined by the strategy.
63
63
  NodeID allocateObjectId(void);
64
64
 
65
+ /// Allocate an type ID as determined by the strategy.
66
+ NodeID allocateTypeId(void);
67
+
65
68
  /// Allocate a GEP object ID as determined by the strategy.
66
69
  /// allocateObjectId is still fine for GEP objects, but
67
70
  /// for some strategies (DBUG, namely), GEP objects can
@@ -103,6 +106,8 @@ private:
103
106
  NodeID numSymbols;
104
107
  /// Total number of objects and values allocated.
105
108
  NodeID numNodes;
109
+ /// Total number of svftypes
110
+ NodeID numType;
106
111
  ///@}
107
112
 
108
113
  /// Strategy to allocate with.
@@ -44,7 +44,7 @@ void NodeIDAllocator::unset(void)
44
44
 
45
45
  // Initialise counts to 4 because that's how many special nodes we have.
46
46
  NodeIDAllocator::NodeIDAllocator(void)
47
- : numObjects(4), numValues(4), numSymbols(4), numNodes(4), strategy(Options::NodeAllocStrat())
47
+ : numObjects(4), numValues(4), numSymbols(4), numNodes(4), numType(0), strategy(Options::NodeAllocStrat())
48
48
  { }
49
49
 
50
50
  NodeID NodeIDAllocator::allocateObjectId(void)
@@ -83,6 +83,11 @@ NodeID NodeIDAllocator::allocateObjectId(void)
83
83
  return id;
84
84
  }
85
85
 
86
+
87
+ NodeID NodeIDAllocator::allocateTypeId() {
88
+ return numType++;
89
+ }
90
+
86
91
  NodeID NodeIDAllocator::allocateGepObjectId(NodeID base, u32_t offset, u32_t maxFieldLimit)
87
92
  {
88
93
  NodeID id = 0;
@@ -1277,7 +1277,7 @@ SVFType* LLVMModuleSet::addSVFTypeInfo(const Type* T)
1277
1277
 
1278
1278
  SVFType* svftype;
1279
1279
 
1280
- u32_t id = svfir->getSVFTypes().size();
1280
+ u32_t id = NodeIDAllocator::get()->allocateTypeId();
1281
1281
  if (SVFUtil::isa<PointerType>(T))
1282
1282
  {
1283
1283
  svftype = new SVFPointerType(id, byteSize);