svf-tools 1.0.679 → 1.0.681

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.679",
3
+ "version": "1.0.681",
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": {
@@ -409,7 +409,7 @@ void PointerAnalysis::resolveIndCalls(const CallICFGNode* cs, const PointsTo& ta
409
409
  const SVFFunction* callee = calleefun->getDefFunForMultipleModule();
410
410
 
411
411
  /// if the arg size does not match then we do not need to connect this parameter
412
- /// even if the callee is a variadic function (the first parameter of variadic function is its paramter number)
412
+ /// unless the callee is a variadic function (the first parameter of variadic function is its paramter number)
413
413
  if(matchArgs(cs, callee) == false)
414
414
  continue;
415
415
 
@@ -434,7 +434,7 @@ void PointerAnalysis::resolveIndCalls(const CallICFGNode* cs, const PointsTo& ta
434
434
  */
435
435
  bool PointerAnalysis::matchArgs(const CallICFGNode* cs, const SVFFunction* callee)
436
436
  {
437
- if(ThreadAPI::getThreadAPI()->isTDFork(cs->getCallSite()))
437
+ if(callee->isVarArg() || ThreadAPI::getThreadAPI()->isTDFork(cs->getCallSite()))
438
438
  return true;
439
439
  else
440
440
  return SVFUtil::getSVFCallSite(cs->getCallSite()).arg_size() == callee->arg_size();
@@ -1565,7 +1565,7 @@ void SVFIRBuilder::updateCallGraph(PTACallGraph* callgraph)
1565
1565
 
1566
1566
  if (isExtCall(*func_iter))
1567
1567
  {
1568
- setCurrentLocation(callee, &callee->getEntryBlock());
1568
+ setCurrentLocation(callee, callee->empty() ? nullptr : &callee->getEntryBlock());
1569
1569
  handleExtCall(const_cast<CallBase*>(callbase), callee);
1570
1570
  }
1571
1571
  else