svf-tools 1.0.1048 → 1.0.1049

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.1048",
3
+ "version": "1.0.1049",
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": {
@@ -169,7 +169,7 @@ const std::string GepValVar::toString() const
169
169
  if (Options::ShowSVFIRValue())
170
170
  {
171
171
  rawstr << "\n";
172
- rawstr << valueOnlyToString();
172
+ rawstr << getBaseNode()->valueOnlyToString();
173
173
  }
174
174
  return rawstr.str();
175
175
  }
@@ -203,7 +203,7 @@ const std::string GepObjVar::toString() const
203
203
  if (Options::ShowSVFIRValue())
204
204
  {
205
205
  rawstr << "\n";
206
- rawstr << valueOnlyToString();
206
+ rawstr << getBaseObj()->valueOnlyToString();
207
207
  }
208
208
  return rawstr.str();
209
209
  }
@@ -767,33 +767,17 @@ const std::string SVFValue::valueOnlyToString() const
767
767
  {
768
768
  std::string str;
769
769
  llvm::raw_string_ostream rawstr(str);
770
- if (const SVF::CallGraphNode* fun = SVFUtil::dyn_cast<CallGraphNode>(this))
771
- {
772
- rawstr << "Function: " << fun->getFunction()->getName() << " ";
773
- }
770
+ assert(
771
+ !SVFUtil::isa<GepObjVar>(this) && !SVFUtil::isa<GepValVar>(this) &&
772
+ !SVFUtil::isa<DummyObjVar>(this) &&!SVFUtil::isa<DummyValVar>(this) &&
773
+ !SVFUtil::isa<BlackHoleValVar>(this) &&
774
+ "invalid value, refer to their toString method");
775
+ auto llvmVal =
776
+ LLVMModuleSet::getLLVMModuleSet()->getLLVMValue(this);
777
+ if (llvmVal)
778
+ rawstr << " " << *llvmVal << " ";
774
779
  else
775
- {
776
- const SVFValue* baseNode = this;
777
- if (const GepValVar* valVar = SVFUtil::dyn_cast<GepValVar>(this))
778
- {
779
- baseNode = valVar->getBaseNode();
780
- }
781
- else if (const GepObjVar* objVar = SVFUtil::dyn_cast<GepObjVar>(this))
782
- {
783
- baseNode = objVar->getBaseObj();
784
- }
785
- if (SVFUtil::isa<DummyObjVar, DummyValVar, BlackHoleValVar>(baseNode))
786
- rawstr << "";
787
- else
788
- {
789
- auto llvmVal =
790
- LLVMModuleSet::getLLVMModuleSet()->getLLVMValue(baseNode);
791
- if (llvmVal)
792
- rawstr << " " << *llvmVal << " ";
793
- else
794
- rawstr << "";
795
- }
796
- }
780
+ rawstr << "";
797
781
  rawstr << getSourceLoc();
798
782
  return rawstr.str();
799
783
  }
@@ -62,7 +62,7 @@ std::string printPts(PointerAnalysis* pta, const SVFVar* svfval)
62
62
  {
63
63
  rawstr << " " << *ii << " ";
64
64
  PAGNode* targetObj = pta->getPAG()->getGNode(*ii);
65
- rawstr << "(" << targetObj->valueOnlyToString() << ")\t ";
65
+ rawstr << "(" << targetObj->toString() << ")\t ";
66
66
  }
67
67
 
68
68
  return rawstr.str();