svf-tools 1.0.661 → 1.0.662

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.661",
3
+ "version": "1.0.662",
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": {
@@ -690,11 +690,22 @@ bool SVFIR::isNonPointerObj(NodeID id) const
690
690
  }
691
691
  }
692
692
  /*
693
- * If this is a dummy node or node does not have incoming edges we assume it is not a pointer here
693
+ * If this is a dummy node or node does not have incoming edges and outcoming edges we assume it is not a pointer here.
694
+ * However, if it is a pointer and it is an argument of a function definition, we assume it is a pointer here.
694
695
  */
695
696
  bool SVFIR::isValidPointer(NodeID nodeId) const
696
697
  {
697
698
  SVFVar* node = pag->getGNode(nodeId);
699
+
700
+ if (node->hasValue() && node->isPointer())
701
+ {
702
+ if(const SVFArgument* arg = SVFUtil::dyn_cast<SVFArgument>(node->getValue()))
703
+ {
704
+ if (!(arg->getParent()->isDeclaration()))
705
+ return true;
706
+ }
707
+ }
708
+
698
709
  if ((node->getInEdges().empty() && node->getOutEdges().empty()))
699
710
  return false;
700
711
  return node->isPointer();