svf-lib 1.0.2319 → 1.0.2321
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/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/WorkList.h +0 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
- package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
- package/SVF-linux-aarch64/Release-build/lib/libSvfCore.so.3.1 +0 -0
- package/SVF-linux-aarch64/Release-build/lib/libSvfLLVM.so.3.1 +0 -0
- package/SVF-linux-aarch64/Release-build/lib/pkgconfig/SVF.pc +12 -0
- package/SVF-osx/Release-build/bin/ae +0 -0
- package/SVF-osx/Release-build/bin/cfl +0 -0
- package/SVF-osx/Release-build/bin/dvf +0 -0
- package/SVF-osx/Release-build/bin/llvm2svf +0 -0
- package/SVF-osx/Release-build/bin/mta +0 -0
- package/SVF-osx/Release-build/bin/saber +0 -0
- package/SVF-osx/Release-build/bin/svf-ex +0 -0
- package/SVF-osx/Release-build/bin/wpa +0 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractState.h +425 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractValue.h +157 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/AddressValue.h +225 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/ICFGWTO.h +135 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/IntervalValue.h +1055 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/NumericValue.h +1292 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/RelExeState.h +226 -0
- package/SVF-osx/Release-build/include/SVF/AE/Core/RelationSolver.h +91 -0
- package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AEDetector.h +439 -0
- package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbsExtAPI.h +138 -0
- package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbstractInterpretation.h +384 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFGNormalizer.h +84 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFGrammar.h +468 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLAlias.h +168 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLBase.h +118 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLGramGraphChecker.h +74 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLGraphBuilder.h +168 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLSVFGBuilder.h +58 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLSolver.h +374 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLStat.h +67 -0
- package/SVF-osx/Release-build/include/SVF/CFL/CFLVF.h +68 -0
- package/SVF-osx/Release-build/include/SVF/CFL/GrammarBuilder.h +100 -0
- package/SVF-osx/Release-build/include/SVF/DDA/ContextDDA.h +230 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAClient.h +163 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAPass.h +102 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAStat.h +121 -0
- package/SVF-osx/Release-build/include/SVF/DDA/DDAVFSolver.h +794 -0
- package/SVF-osx/Release-build/include/SVF/DDA/FlowDDA.h +178 -0
- package/SVF-osx/Release-build/include/SVF/FastCluster/fastcluster.h +80 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/BasicBlockG.h +318 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CDG.h +482 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CFLGraph.h +232 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CHG.h +368 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/CallGraph.h +497 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ConsG.h +402 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ConsGEdge.h +355 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ConsGNode.h +418 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/DOTGraphTraits.h +188 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GenericGraph.h +628 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GraphPrinter.h +111 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GraphTraits.h +150 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/GraphWriter.h +380 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFG.h +331 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFGEdge.h +281 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFGNode.h +669 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ICFGStat.h +164 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/IRGraph.h +398 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SCC.h +375 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFG.h +491 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGEdge.h +237 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGNode.h +501 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGOPT.h +372 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/SVFGStat.h +273 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/ThreadCallGraph.h +399 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/VFG.h +726 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/VFGEdge.h +295 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/VFGNode.h +1266 -0
- package/SVF-osx/Release-build/include/SVF/Graphs/WTO.h +872 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MSSAMuChi.h +722 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MemPartition.h +169 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MemRegion.h +489 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/MemSSA.h +452 -0
- package/SVF-osx/Release-build/include/SVF/MSSA/SVFGBuilder.h +104 -0
- package/SVF-osx/Release-build/include/SVF/MTA/LockAnalysis.h +533 -0
- package/SVF-osx/Release-build/include/SVF/MTA/MHP.h +546 -0
- package/SVF-osx/Release-build/include/SVF/MTA/MTA.h +97 -0
- package/SVF-osx/Release-build/include/SVF/MTA/MTAStat.h +73 -0
- package/SVF-osx/Release-build/include/SVF/MTA/TCT.h +620 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/AbstractPointsToDS.h +316 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/AccessPath.h +194 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/ConditionalPT.h +878 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/MutablePointsToDS.h +1025 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToCache.h +463 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToDS.h +955 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysis.h +428 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysisImpl.h +602 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/PointsTo.h +255 -0
- package/SVF-osx/Release-build/include/SVF/MemoryModel/SVFLoop.h +167 -0
- package/SVF-osx/Release-build/include/SVF/SABER/DoubleFreeChecker.h +76 -0
- package/SVF-osx/Release-build/include/SVF/SABER/FileChecker.h +80 -0
- package/SVF-osx/Release-build/include/SVF/SABER/LeakChecker.h +122 -0
- package/SVF-osx/Release-build/include/SVF/SABER/ProgSlice.h +327 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SaberCheckerAPI.h +151 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SaberCondAllocator.h +317 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SaberSVFGBuilder.h +114 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkDDA.h +327 -0
- package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkSolver.h +186 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BasicTypes.h +280 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BreakConstantExpr.h +93 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CHGBuilder.h +78 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CppUtil.h +184 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/DCHG.h +474 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/GEPTypeBridgeIterator.h +183 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ICFGBuilder.h +160 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMLoopAnalysis.h +60 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMModule.h +527 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMUtil.h +433 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ObjTypeInference.h +129 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SVFIRBuilder.h +523 -0
- package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SymbolTableBuilder.h +132 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/ObjTypeInfo.h +224 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/PAGBuilderFromFile.h +80 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFIR.h +856 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFStatements.h +1330 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFType.h +606 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFValue.h +338 -0
- package/SVF-osx/Release-build/include/SVF/SVFIR/SVFVariables.h +2212 -0
- package/SVF-osx/Release-build/include/SVF/Util/Annotator.h +180 -0
- package/SVF-osx/Release-build/include/SVF/Util/BitVector.h +55 -0
- package/SVF-osx/Release-build/include/SVF/Util/CDGBuilder.h +107 -0
- package/SVF-osx/Release-build/include/SVF/Util/CallGraphBuilder.h +61 -0
- package/SVF-osx/Release-build/include/SVF/Util/Casting.h +426 -0
- package/SVF-osx/Release-build/include/SVF/Util/CommandLine.h +530 -0
- package/SVF-osx/Release-build/include/SVF/Util/CoreBitVector.h +214 -0
- package/SVF-osx/Release-build/include/SVF/Util/CxtStmt.h +502 -0
- package/SVF-osx/Release-build/include/SVF/Util/DPItem.h +618 -0
- package/SVF-osx/Release-build/include/SVF/Util/ExtAPI.h +117 -0
- package/SVF-osx/Release-build/include/SVF/Util/GeneralType.h +127 -0
- package/SVF-osx/Release-build/include/SVF/Util/GraphReachSolver.h +186 -0
- package/SVF-osx/Release-build/include/SVF/Util/NodeIDAllocator.h +203 -0
- package/SVF-osx/Release-build/include/SVF/Util/Options.h +273 -0
- package/SVF-osx/Release-build/include/SVF/Util/PTAStat.h +83 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFBugReport.h +427 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFLoopAndDomInfo.h +169 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFStat.h +103 -0
- package/SVF-osx/Release-build/include/SVF/Util/SVFUtil.h +478 -0
- package/SVF-osx/Release-build/include/SVF/Util/SparseBitVector.h +1252 -0
- package/SVF-osx/Release-build/include/SVF/Util/ThreadAPI.h +188 -0
- package/SVF-osx/Release-build/include/SVF/Util/WorkList.h +317 -0
- package/SVF-osx/Release-build/include/SVF/Util/Z3Expr.h +325 -0
- package/SVF-osx/Release-build/include/SVF/Util/cJSON.h +300 -0
- package/SVF-osx/Release-build/include/SVF/Util/config.h +46 -0
- package/SVF-osx/Release-build/include/SVF/Util/iterator.h +407 -0
- package/SVF-osx/Release-build/include/SVF/Util/iterator_range.h +76 -0
- package/SVF-osx/Release-build/include/SVF/WPA/Andersen.h +434 -0
- package/SVF-osx/Release-build/include/SVF/WPA/AndersenPWC.h +160 -0
- package/SVF-osx/Release-build/include/SVF/WPA/CSC.h +95 -0
- package/SVF-osx/Release-build/include/SVF/WPA/FlowSensitive.h +322 -0
- package/SVF-osx/Release-build/include/SVF/WPA/Steensgaard.h +131 -0
- package/SVF-osx/Release-build/include/SVF/WPA/TypeAnalysis.h +90 -0
- package/SVF-osx/Release-build/include/SVF/WPA/VersionedFlowSensitive.h +295 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPAFSSolver.h +246 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPAPass.h +115 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPASolver.h +205 -0
- package/SVF-osx/Release-build/include/SVF/WPA/WPAStat.h +222 -0
- package/SVF-osx/Release-build/include/SVF/extapi.bc +2384 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
- package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
- package/SVF-osx/Release-build/lib/libSvfCore.3.1.dylib +0 -0
- package/SVF-osx/Release-build/lib/libSvfLLVM.3.1.dylib +0 -0
- package/SVF-osx/Release-build/lib/pkgconfig/SVF.pc +12 -0
- package/package.json +1 -1
- package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PAGGrammar.txt +0 -15
- package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PEGGrammar.txt +0 -11
- package/SVF-linux-aarch64/Release-build/include/CFL/grammar/VFGGrammar.txt +0 -7
- package/SVF-linux-aarch64/Release-build/include/FastCluster/LICENSE.TXT +0 -13
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractState.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AddressValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/ICFGWTO.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/IntervalValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/NumericValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelExeState.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelationSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AEDetector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbsExtAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbstractInterpretation.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGNormalizer.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGrammar.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLAlias.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLBase.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGramGraphChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGraphBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSVFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLVF.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/GrammarBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/ContextDDA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAClient.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAPass.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAVFSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/FlowDDA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{FastCluster → SVF/FastCluster}/fastcluster.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/BasicBlockG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CDG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CFLGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CHG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CallGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/DOTGraphTraits.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GenericGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphPrinter.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphTraits.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphWriter.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/IRGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SCC.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGOPT.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ThreadCallGraph.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGEdge.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGNode.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/WTO.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MSSAMuChi.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemPartition.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemRegion.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemSSA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/SVFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/LockAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MHP.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/TCT.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AbstractPointsToDS.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AccessPath.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/ConditionalPT.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/MutablePointsToDS.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToCache.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToDS.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysisImpl.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointsTo.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/SVFLoop.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/DoubleFreeChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/FileChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/LeakChecker.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/ProgSlice.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCheckerAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCondAllocator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberSVFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkDDA.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BasicTypes.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BreakConstantExpr.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CHGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CppUtil.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/DCHG.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/GEPTypeBridgeIterator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ICFGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMLoopAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMModule.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMUtil.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ObjTypeInference.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SVFIRBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SymbolTableBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/ObjTypeInfo.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/PAGBuilderFromFile.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFIR.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFStatements.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFType.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFValue.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFVariables.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Annotator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/BitVector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CDGBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CallGraphBuilder.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Casting.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CommandLine.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CoreBitVector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CxtStmt.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/DPItem.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ExtAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GeneralType.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GraphReachSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/NodeIDAllocator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Options.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/PTAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFBugReport.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFLoopAndDomInfo.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFUtil.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SparseBitVector.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ThreadAPI.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Z3Expr.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/cJSON.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator_range.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Andersen.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/AndersenPWC.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/CSC.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/FlowSensitive.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Steensgaard.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/TypeAnalysis.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/VersionedFlowSensitive.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAFSSolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAPass.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPASolver.h +0 -0
- /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAStat.h +0 -0
- /package/SVF-linux-aarch64/Release-build/{lib → include/SVF}/extapi.bc +0 -0
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
//===- GraphPrinter.h -- Print Generic Graph---------------------//
|
|
2
|
+
//
|
|
3
|
+
// SVF: Static Value-Flow Analysis
|
|
4
|
+
//
|
|
5
|
+
// Copyright (C) <2013-2017> <Yulei Sui>
|
|
6
|
+
//
|
|
7
|
+
|
|
8
|
+
// This program is free software: you can redistribute it and/or modify
|
|
9
|
+
// it under the terms of the GNU Affero General Public License as published by
|
|
10
|
+
// the Free Software Foundation, either version 3 of the License, or
|
|
11
|
+
// (at your option) any later version.
|
|
12
|
+
|
|
13
|
+
// This program is distributed in the hope that it will be useful,
|
|
14
|
+
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
15
|
+
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
16
|
+
// GNU Affero General Public License for more details.
|
|
17
|
+
|
|
18
|
+
// You should have received a copy of the GNU Affero General Public License
|
|
19
|
+
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
20
|
+
//
|
|
21
|
+
//===----------------------------------------------------------------------===//
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
/*
|
|
25
|
+
* GraphPrinter.h
|
|
26
|
+
*
|
|
27
|
+
* Created on: 19.Sep.,2018
|
|
28
|
+
* Author: Yulei
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
#ifndef INCLUDE_GRAPHS_GRAPHPRINTER_H_
|
|
32
|
+
#define INCLUDE_GRAPHS_GRAPHPRINTER_H_
|
|
33
|
+
|
|
34
|
+
#include <system_error>
|
|
35
|
+
#include "Graphs/GraphWriter.h" // for graph write
|
|
36
|
+
#include <fstream>
|
|
37
|
+
|
|
38
|
+
namespace SVF
|
|
39
|
+
{
|
|
40
|
+
|
|
41
|
+
/*
|
|
42
|
+
* Dump and print the graph for debugging
|
|
43
|
+
*/
|
|
44
|
+
class GraphPrinter
|
|
45
|
+
{
|
|
46
|
+
|
|
47
|
+
public:
|
|
48
|
+
GraphPrinter()
|
|
49
|
+
{
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/*!
|
|
53
|
+
* Write the graph into dot file for debugging purpose
|
|
54
|
+
*/
|
|
55
|
+
template<class GraphType>
|
|
56
|
+
static void WriteGraphToFile(SVF::OutStream &O,
|
|
57
|
+
const std::string &GraphName, const GraphType >, bool simple = false)
|
|
58
|
+
{
|
|
59
|
+
// Filename of the output dot file
|
|
60
|
+
std::string Filename = GraphName + ".dot";
|
|
61
|
+
std::ofstream outFile(Filename);
|
|
62
|
+
if (outFile.fail())
|
|
63
|
+
{
|
|
64
|
+
O << " error opening file for writing!\n";
|
|
65
|
+
outFile.close();
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
O << "Writing '" << Filename << "'...";
|
|
70
|
+
|
|
71
|
+
WriteGraph(outFile, GT, simple);
|
|
72
|
+
outFile.close();
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/*!
|
|
76
|
+
* Print the graph to command line
|
|
77
|
+
*/
|
|
78
|
+
template<class GraphType>
|
|
79
|
+
static void PrintGraph(SVF::OutStream &O, const std::string &GraphName,
|
|
80
|
+
const GraphType >)
|
|
81
|
+
{
|
|
82
|
+
///Define the GTraits and node iterator for printing
|
|
83
|
+
typedef GenericGraphTraits<GraphType> GTraits;
|
|
84
|
+
|
|
85
|
+
typedef typename GTraits::NodeRef NodeRef;
|
|
86
|
+
typedef typename GTraits::nodes_iterator node_iterator;
|
|
87
|
+
typedef typename GTraits::ChildIteratorType child_iterator;
|
|
88
|
+
|
|
89
|
+
O << "Printing VFG Graph" << "'...\n";
|
|
90
|
+
// Print each node name and its edges
|
|
91
|
+
node_iterator I = GTraits::nodes_begin(GT);
|
|
92
|
+
node_iterator E = GTraits::nodes_end(GT);
|
|
93
|
+
for (; I != E; ++I)
|
|
94
|
+
{
|
|
95
|
+
NodeRef *Node = *I;
|
|
96
|
+
O << "node :" << Node << "'\n";
|
|
97
|
+
child_iterator EI = GTraits::child_begin(Node);
|
|
98
|
+
child_iterator EE = GTraits::child_end(Node);
|
|
99
|
+
for (unsigned i = 0; EI != EE && i != 64; ++EI, ++i)
|
|
100
|
+
{
|
|
101
|
+
O << "child :" << *EI << "'\n";
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
} // End namespace llvm
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
#endif /* INCLUDE_GRAPHS_GRAPHPRINTER_H_ */
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
//===- llvm/ADT/GenericGraphTraits.h - Graph traits template -----------*- C++ -*-===//
|
|
2
|
+
//
|
|
3
|
+
// From the LLVM Project with some modifications, under the Apache License v2.0
|
|
4
|
+
// with LLVM Exceptions. See https://llvm.org/LICENSE.txt for license information.
|
|
5
|
+
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
6
|
+
//
|
|
7
|
+
//===----------------------------------------------------------------------===//
|
|
8
|
+
//
|
|
9
|
+
// This file defines the little GenericGraphTraits<X> template class that should be
|
|
10
|
+
// specialized by classes that want to be iterable by generic graph iterators.
|
|
11
|
+
//
|
|
12
|
+
// This file also defines the marker class Inverse that is used to iterate over
|
|
13
|
+
// graphs in a graph defined, inverse ordering...
|
|
14
|
+
//
|
|
15
|
+
//===----------------------------------------------------------------------===//
|
|
16
|
+
|
|
17
|
+
#ifndef GRAPHS_GRAPHTRAITS_H
|
|
18
|
+
#define GRAPHS_GRAPHTRAITS_H
|
|
19
|
+
|
|
20
|
+
#include "Util/iterator_range.h"
|
|
21
|
+
|
|
22
|
+
namespace SVF
|
|
23
|
+
{
|
|
24
|
+
|
|
25
|
+
// GenericGraphTraits - This class should be specialized by different graph types...
|
|
26
|
+
// which is why the default version is empty.
|
|
27
|
+
//
|
|
28
|
+
// This template evolved from supporting `BasicBlock` to also later supporting
|
|
29
|
+
// more complex types (e.g. CFG and DomTree).
|
|
30
|
+
//
|
|
31
|
+
// GenericGraphTraits can be used to create a view over a graph interpreting it
|
|
32
|
+
// differently without requiring a copy of the original graph. This could
|
|
33
|
+
// be achieved by carrying more data in NodeRef. See LoopBodyTraits for one
|
|
34
|
+
// example.
|
|
35
|
+
template<class GraphType>
|
|
36
|
+
struct GenericGraphTraits
|
|
37
|
+
{
|
|
38
|
+
// Elements to provide:
|
|
39
|
+
|
|
40
|
+
// typedef NodeRef - Type of Node token in the graph, which should
|
|
41
|
+
// be cheap to copy.
|
|
42
|
+
// typedef ChildIteratorType - Type used to iterate over children in graph,
|
|
43
|
+
// dereference to a NodeRef.
|
|
44
|
+
|
|
45
|
+
// static NodeRef getEntryNode(const GraphType &)
|
|
46
|
+
// Return the entry node of the graph
|
|
47
|
+
|
|
48
|
+
// static ChildIteratorType child_begin(NodeRef)
|
|
49
|
+
// static ChildIteratorType child_end (NodeRef)
|
|
50
|
+
// Return iterators that point to the beginning and ending of the child
|
|
51
|
+
// node list for the specified node.
|
|
52
|
+
|
|
53
|
+
// typedef ...iterator nodes_iterator; - dereference to a NodeRef
|
|
54
|
+
// static nodes_iterator nodes_begin(GraphType *G)
|
|
55
|
+
// static nodes_iterator nodes_end (GraphType *G)
|
|
56
|
+
// nodes_iterator/begin/end - Allow iteration over all nodes in the graph
|
|
57
|
+
|
|
58
|
+
// typedef EdgeRef - Type of Edge token in the graph, which should
|
|
59
|
+
// be cheap to copy.
|
|
60
|
+
// typedef ChildEdgeIteratorType - Type used to iterate over children edges in
|
|
61
|
+
// graph, dereference to a EdgeRef.
|
|
62
|
+
|
|
63
|
+
// static ChildEdgeIteratorType child_edge_begin(NodeRef)
|
|
64
|
+
// static ChildEdgeIteratorType child_edge_end(NodeRef)
|
|
65
|
+
// Return iterators that point to the beginning and ending of the
|
|
66
|
+
// edge list for the given callgraph node.
|
|
67
|
+
//
|
|
68
|
+
// static NodeRef edge_dest(EdgeRef)
|
|
69
|
+
// Return the destination node of an edge.
|
|
70
|
+
|
|
71
|
+
// static unsigned size (GraphType *G)
|
|
72
|
+
// Return total number of nodes in the graph
|
|
73
|
+
|
|
74
|
+
// If anyone tries to use this class without having an appropriate
|
|
75
|
+
// specialization, make an error. If you get this error, it's because you
|
|
76
|
+
// need to include the appropriate specialization of GenericGraphTraits<> for your
|
|
77
|
+
// graph, or you need to define it for a new graph type. Either that or
|
|
78
|
+
// your argument to XXX_begin(...) is unknown or needs to have the proper .h
|
|
79
|
+
// file #include'd.
|
|
80
|
+
using NodeRef = typename GraphType::UnknownGraphTypeError;
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
// Inverse - This class is used as a little marker class to tell the graph
|
|
84
|
+
// iterator to iterate over the graph in a graph defined "Inverse" ordering.
|
|
85
|
+
// Not all graphs define an inverse ordering, and if they do, it depends on
|
|
86
|
+
// the graph exactly what that is. Here's an example of usage with the
|
|
87
|
+
// df_iterator:
|
|
88
|
+
//
|
|
89
|
+
// idf_iterator<Method*> I = idf_begin(M), E = idf_end(M);
|
|
90
|
+
// for (; I != E; ++I) { ... }
|
|
91
|
+
//
|
|
92
|
+
// Which is equivalent to:
|
|
93
|
+
// df_iterator<Inverse<Method*>> I = idf_begin(M), E = idf_end(M);
|
|
94
|
+
// for (; I != E; ++I) { ... }
|
|
95
|
+
//
|
|
96
|
+
template <class GraphType>
|
|
97
|
+
struct Inverse
|
|
98
|
+
{
|
|
99
|
+
const GraphType &Graph;
|
|
100
|
+
|
|
101
|
+
inline Inverse(const GraphType &G) : Graph(G) {}
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
// Provide a partial specialization of GenericGraphTraits so that the inverse of an
|
|
105
|
+
// inverse falls back to the original graph.
|
|
106
|
+
template <class T> struct GenericGraphTraits<Inverse<Inverse<T>>> : GenericGraphTraits<T> {};
|
|
107
|
+
|
|
108
|
+
// Provide iterator ranges for the graph traits nodes and children
|
|
109
|
+
template <class GraphType>
|
|
110
|
+
iter_range<typename GenericGraphTraits<GraphType>::nodes_iterator>
|
|
111
|
+
nodes(const GraphType &G)
|
|
112
|
+
{
|
|
113
|
+
return make_range(GenericGraphTraits<GraphType>::nodes_begin(G),
|
|
114
|
+
GenericGraphTraits<GraphType>::nodes_end(G));
|
|
115
|
+
}
|
|
116
|
+
template <class GraphType>
|
|
117
|
+
iter_range<typename GenericGraphTraits<Inverse<GraphType>>::nodes_iterator>
|
|
118
|
+
inverse_nodes(const GraphType &G)
|
|
119
|
+
{
|
|
120
|
+
return make_range(GenericGraphTraits<Inverse<GraphType>>::nodes_begin(G),
|
|
121
|
+
GenericGraphTraits<Inverse<GraphType>>::nodes_end(G));
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
template <class GraphType>
|
|
125
|
+
iter_range<typename GenericGraphTraits<GraphType>::ChildIteratorType>
|
|
126
|
+
children(const typename GenericGraphTraits<GraphType>::NodeRef &G)
|
|
127
|
+
{
|
|
128
|
+
return make_range(GenericGraphTraits<GraphType>::child_begin(G),
|
|
129
|
+
GenericGraphTraits<GraphType>::child_end(G));
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
template <class GraphType>
|
|
133
|
+
iter_range<typename GenericGraphTraits<Inverse<GraphType>>::ChildIteratorType>
|
|
134
|
+
inverse_children(const typename GenericGraphTraits<GraphType>::NodeRef &G)
|
|
135
|
+
{
|
|
136
|
+
return make_range(GenericGraphTraits<Inverse<GraphType>>::child_begin(G),
|
|
137
|
+
GenericGraphTraits<Inverse<GraphType>>::child_end(G));
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
template <class GraphType>
|
|
141
|
+
iter_range<typename GenericGraphTraits<GraphType>::ChildEdgeIteratorType>
|
|
142
|
+
children_edges(const typename GenericGraphTraits<GraphType>::NodeRef &G)
|
|
143
|
+
{
|
|
144
|
+
return make_range(GenericGraphTraits<GraphType>::child_edge_begin(G),
|
|
145
|
+
GenericGraphTraits<GraphType>::child_edge_end(G));
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
} // end namespace llvm
|
|
149
|
+
|
|
150
|
+
#endif // LLVM_ADT_GRAPHTRAITS_H
|
|
@@ -0,0 +1,380 @@
|
|
|
1
|
+
//===- Graphs/GraphWriter.h - Write graph to a .dot file --*- C++ -*-===//
|
|
2
|
+
//
|
|
3
|
+
// From the LLVM Project with some modifications, under the Apache License v2.0
|
|
4
|
+
// with LLVM Exceptions. See https://llvm.org/LICENSE.txt for license information.
|
|
5
|
+
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
6
|
+
//
|
|
7
|
+
//===----------------------------------------------------------------------===//
|
|
8
|
+
//
|
|
9
|
+
// This file defines a simple interface that can be used to print out generic
|
|
10
|
+
// LLVM graphs to ".dot" files. "dot" is a tool that is part of the AT&T
|
|
11
|
+
// graphviz package (http://www.research.att.com/sw/tools/graphviz/) which can
|
|
12
|
+
// be used to turn the files output by this interface into a variety of
|
|
13
|
+
// different graphics formats.
|
|
14
|
+
//
|
|
15
|
+
// Graphs do not need to implement any interface past what is already required
|
|
16
|
+
// by the GraphTraits template, but they can choose to implement specializations
|
|
17
|
+
// of the DOTGraphTraits template if they want to customize the graphs output in
|
|
18
|
+
// any way.
|
|
19
|
+
//
|
|
20
|
+
//===----------------------------------------------------------------------===//
|
|
21
|
+
|
|
22
|
+
#ifndef GRAPHS_GRAPHWRITER_H
|
|
23
|
+
#define GRAPHS_GRAPHWRITER_H
|
|
24
|
+
|
|
25
|
+
#include "Graphs/GraphTraits.h"
|
|
26
|
+
#include "Graphs/DOTGraphTraits.h"
|
|
27
|
+
#include <algorithm>
|
|
28
|
+
#include <cstddef>
|
|
29
|
+
#include <iterator>
|
|
30
|
+
#include <string>
|
|
31
|
+
#include <type_traits>
|
|
32
|
+
#include <vector>
|
|
33
|
+
#include <fstream>
|
|
34
|
+
#include <sstream>
|
|
35
|
+
#include <iostream>
|
|
36
|
+
|
|
37
|
+
namespace SVF
|
|
38
|
+
{
|
|
39
|
+
|
|
40
|
+
namespace DOT // Private functions...
|
|
41
|
+
{
|
|
42
|
+
|
|
43
|
+
std::string EscapeStr(const std::string &Label);
|
|
44
|
+
|
|
45
|
+
} // end namespace DOT
|
|
46
|
+
|
|
47
|
+
namespace GraphProgram
|
|
48
|
+
{
|
|
49
|
+
|
|
50
|
+
enum Name
|
|
51
|
+
{
|
|
52
|
+
DOT,
|
|
53
|
+
FDP,
|
|
54
|
+
NEATO,
|
|
55
|
+
TWOPI,
|
|
56
|
+
CIRCO
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
} // end namespace GraphProgram
|
|
60
|
+
|
|
61
|
+
template<typename GraphType>
|
|
62
|
+
class GraphWriter
|
|
63
|
+
{
|
|
64
|
+
std::ofstream &O;
|
|
65
|
+
const GraphType &G;
|
|
66
|
+
|
|
67
|
+
using DOTTraits = DOTGraphTraits<GraphType>;
|
|
68
|
+
using GTraits = GenericGraphTraits<GraphType>;
|
|
69
|
+
using NodeRef = typename GTraits::NodeRef;
|
|
70
|
+
using node_iterator = typename GTraits::nodes_iterator;
|
|
71
|
+
using child_iterator = typename GTraits::ChildIteratorType;
|
|
72
|
+
DOTTraits DTraits;
|
|
73
|
+
|
|
74
|
+
static_assert(std::is_pointer<NodeRef>::value,
|
|
75
|
+
"FIXME: Currently GraphWriter requires the NodeRef type to be "
|
|
76
|
+
"a pointer.\nThe pointer usage should be moved to "
|
|
77
|
+
"DOTGraphTraits, and removed from GraphWriter itself.");
|
|
78
|
+
|
|
79
|
+
// Writes the edge labels of the node to O and returns true if there are any
|
|
80
|
+
// edge labels not equal to the empty string "".
|
|
81
|
+
bool getEdgeSourceLabels(std::stringstream &O2, NodeRef Node)
|
|
82
|
+
{
|
|
83
|
+
child_iterator EI = GTraits::child_begin(Node);
|
|
84
|
+
child_iterator EE = GTraits::child_end(Node);
|
|
85
|
+
bool hasEdgeSourceLabels = false;
|
|
86
|
+
|
|
87
|
+
for (unsigned i = 0; EI != EE && i != 64; ++EI, ++i)
|
|
88
|
+
{
|
|
89
|
+
std::string label = DTraits.getEdgeSourceLabel(Node, EI);
|
|
90
|
+
|
|
91
|
+
if (label.empty())
|
|
92
|
+
continue;
|
|
93
|
+
|
|
94
|
+
hasEdgeSourceLabels = true;
|
|
95
|
+
|
|
96
|
+
if (i)
|
|
97
|
+
O2 << "|";
|
|
98
|
+
|
|
99
|
+
O2 << "<s" << i << ">" << DOT::EscapeStr(label);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
if (EI != EE && hasEdgeSourceLabels)
|
|
103
|
+
O2 << "|<s64>truncated...";
|
|
104
|
+
|
|
105
|
+
return hasEdgeSourceLabels;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
public:
|
|
109
|
+
GraphWriter(std::ofstream &o, const GraphType &g, bool SN) : O(o), G(g)
|
|
110
|
+
{
|
|
111
|
+
DTraits = DOTTraits(SN);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
void writeGraph(const std::string &Title = "")
|
|
115
|
+
{
|
|
116
|
+
// Output the header for the graph...
|
|
117
|
+
writeHeader(Title);
|
|
118
|
+
|
|
119
|
+
// Emit all of the nodes in the graph...
|
|
120
|
+
writeNodes();
|
|
121
|
+
|
|
122
|
+
// Output any customizations on the graph
|
|
123
|
+
DOTGraphTraits<GraphType>::addCustomGraphFeatures(G, *this);
|
|
124
|
+
|
|
125
|
+
// Output the end of the graph
|
|
126
|
+
writeFooter();
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
void writeHeader(const std::string &Title)
|
|
130
|
+
{
|
|
131
|
+
std::string GraphName(DTraits.getGraphName(G));
|
|
132
|
+
|
|
133
|
+
if (!Title.empty())
|
|
134
|
+
O << "digraph \"" << DOT::EscapeStr(Title) << "\" {\n";
|
|
135
|
+
else if (!GraphName.empty())
|
|
136
|
+
O << "digraph \"" << DOT::EscapeStr(GraphName) << "\" {\n";
|
|
137
|
+
else
|
|
138
|
+
O << "digraph unnamed {\n";
|
|
139
|
+
|
|
140
|
+
if (DTraits.renderGraphFromBottomUp())
|
|
141
|
+
O << "\trankdir=\"BT\";\n";
|
|
142
|
+
|
|
143
|
+
if (!Title.empty())
|
|
144
|
+
O << "\tlabel=\"" << DOT::EscapeStr(Title) << "\";\n";
|
|
145
|
+
else if (!GraphName.empty())
|
|
146
|
+
O << "\tlabel=\"" << DOT::EscapeStr(GraphName) << "\";\n";
|
|
147
|
+
O << DTraits.getGraphProperties(G);
|
|
148
|
+
O << "\n";
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
void writeFooter()
|
|
152
|
+
{
|
|
153
|
+
// Finish off the graph
|
|
154
|
+
O << "}\n";
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
void writeNodes()
|
|
158
|
+
{
|
|
159
|
+
// Loop over the graph, printing it out...
|
|
160
|
+
for (const auto Node : nodes<GraphType>(G))
|
|
161
|
+
if (!isNodeHidden(Node))
|
|
162
|
+
writeNode(Node);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
bool isNodeHidden(NodeRef Node)
|
|
166
|
+
{
|
|
167
|
+
return DTraits.isNodeHidden(Node, G);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
void writeNode(NodeRef Node)
|
|
171
|
+
{
|
|
172
|
+
std::string NodeAttributes = DTraits.getNodeAttributes(Node, G);
|
|
173
|
+
|
|
174
|
+
O << "\tNode" << static_cast<const void*>(Node) << " [shape=record,";
|
|
175
|
+
if (!NodeAttributes.empty()) O << NodeAttributes << ",";
|
|
176
|
+
O << "label=\"{";
|
|
177
|
+
|
|
178
|
+
if (!DTraits.renderGraphFromBottomUp())
|
|
179
|
+
{
|
|
180
|
+
O << DOT::EscapeStr(DTraits.getNodeLabel(Node, G));
|
|
181
|
+
|
|
182
|
+
// If we should include the address of the node in the label, do so now.
|
|
183
|
+
std::string Id = DTraits.getNodeIdentifierLabel(Node, G);
|
|
184
|
+
if (!Id.empty())
|
|
185
|
+
O << "|" << DOT::EscapeStr(Id);
|
|
186
|
+
|
|
187
|
+
std::string NodeDesc = DTraits.getNodeDescription(Node, G);
|
|
188
|
+
if (!NodeDesc.empty())
|
|
189
|
+
O << "|" << DOT::EscapeStr(NodeDesc);
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
std::string edgeSourceLabels;
|
|
193
|
+
std::stringstream EdgeSourceLabels(edgeSourceLabels);
|
|
194
|
+
bool hasEdgeSourceLabels = getEdgeSourceLabels(EdgeSourceLabels, Node);
|
|
195
|
+
|
|
196
|
+
if (hasEdgeSourceLabels)
|
|
197
|
+
{
|
|
198
|
+
if (!DTraits.renderGraphFromBottomUp()) O << "|";
|
|
199
|
+
|
|
200
|
+
O << "{" << EdgeSourceLabels.str() << "}";
|
|
201
|
+
|
|
202
|
+
if (DTraits.renderGraphFromBottomUp()) O << "|";
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
if (DTraits.renderGraphFromBottomUp())
|
|
206
|
+
{
|
|
207
|
+
O << DOT::EscapeStr(DTraits.getNodeLabel(Node, G));
|
|
208
|
+
|
|
209
|
+
// If we should include the address of the node in the label, do so now.
|
|
210
|
+
std::string Id = DTraits.getNodeIdentifierLabel(Node, G);
|
|
211
|
+
if (!Id.empty())
|
|
212
|
+
O << "|" << DOT::EscapeStr(Id);
|
|
213
|
+
|
|
214
|
+
std::string NodeDesc = DTraits.getNodeDescription(Node, G);
|
|
215
|
+
if (!NodeDesc.empty())
|
|
216
|
+
O << "|" << DOT::EscapeStr(NodeDesc);
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
if (DTraits.hasEdgeDestLabels())
|
|
220
|
+
{
|
|
221
|
+
O << "|{";
|
|
222
|
+
|
|
223
|
+
unsigned i = 0, e = DTraits.numEdgeDestLabels(Node);
|
|
224
|
+
for (; i != e && i != 64; ++i)
|
|
225
|
+
{
|
|
226
|
+
if (i) O << "|";
|
|
227
|
+
O << "<d" << i << ">"
|
|
228
|
+
<< DOT::EscapeStr(DTraits.getEdgeDestLabel(Node, i));
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
if (i != e)
|
|
232
|
+
O << "|<d64>truncated...";
|
|
233
|
+
O << "}";
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
O << "}\"];\n"; // Finish printing the "node" line
|
|
237
|
+
|
|
238
|
+
// Output all of the edges now
|
|
239
|
+
child_iterator EI = GTraits::child_begin(Node);
|
|
240
|
+
child_iterator EE = GTraits::child_end(Node);
|
|
241
|
+
for (unsigned i = 0; EI != EE && i != 64; ++EI, ++i)
|
|
242
|
+
if (!DTraits.isNodeHidden(*EI, G))
|
|
243
|
+
writeEdge(Node, i, EI);
|
|
244
|
+
for (; EI != EE; ++EI)
|
|
245
|
+
if (!DTraits.isNodeHidden(*EI, G))
|
|
246
|
+
writeEdge(Node, 64, EI);
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
void writeEdge(NodeRef Node, unsigned edgeidx, child_iterator EI)
|
|
250
|
+
{
|
|
251
|
+
if (NodeRef TargetNode = *EI)
|
|
252
|
+
{
|
|
253
|
+
int DestPort = -1;
|
|
254
|
+
if (DTraits.edgeTargetsEdgeSource(Node, EI))
|
|
255
|
+
{
|
|
256
|
+
child_iterator TargetIt = DTraits.getEdgeTarget(Node, EI);
|
|
257
|
+
|
|
258
|
+
// Figure out which edge this targets...
|
|
259
|
+
unsigned Offset =
|
|
260
|
+
(unsigned)std::distance(GTraits::child_begin(TargetNode), TargetIt);
|
|
261
|
+
DestPort = static_cast<int>(Offset);
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
if (DTraits.getEdgeSourceLabel(Node, EI).empty())
|
|
265
|
+
edgeidx = -1;
|
|
266
|
+
|
|
267
|
+
emitEdge(static_cast<const void*>(Node), edgeidx,
|
|
268
|
+
static_cast<const void*>(TargetNode), DestPort,
|
|
269
|
+
DTraits.getEdgeAttributes(Node, EI, G));
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
/// emitSimpleNode - Outputs a simple (non-record) node
|
|
274
|
+
void emitSimpleNode(const void *ID, const std::string &Attr,
|
|
275
|
+
const std::string &Label, unsigned NumEdgeSources = 0,
|
|
276
|
+
const std::vector<std::string> *EdgeSourceLabels = nullptr)
|
|
277
|
+
{
|
|
278
|
+
O << "\tNode" << ID << "[ ";
|
|
279
|
+
if (!Attr.empty())
|
|
280
|
+
O << Attr << ",";
|
|
281
|
+
O << " label =\"";
|
|
282
|
+
if (NumEdgeSources) O << "{";
|
|
283
|
+
O << DOT::EscapeStr(Label);
|
|
284
|
+
if (NumEdgeSources)
|
|
285
|
+
{
|
|
286
|
+
O << "|{";
|
|
287
|
+
|
|
288
|
+
for (unsigned i = 0; i != NumEdgeSources; ++i)
|
|
289
|
+
{
|
|
290
|
+
if (i) O << "|";
|
|
291
|
+
O << "<s" << i << ">";
|
|
292
|
+
if (EdgeSourceLabels) O << DOT::EscapeStr((*EdgeSourceLabels)[i]);
|
|
293
|
+
}
|
|
294
|
+
O << "}}";
|
|
295
|
+
}
|
|
296
|
+
O << "\"];\n";
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
/// emitEdge - Output an edge from a simple node into the graph...
|
|
300
|
+
void emitEdge(const void *SrcNodeID, int SrcNodePort,
|
|
301
|
+
const void *DestNodeID, int DestNodePort,
|
|
302
|
+
const std::string &Attrs)
|
|
303
|
+
{
|
|
304
|
+
if (SrcNodePort > 64) return; // Emanating from truncated part?
|
|
305
|
+
if (DestNodePort > 64) DestNodePort = 64; // Targeting the truncated part?
|
|
306
|
+
|
|
307
|
+
O << "\tNode" << SrcNodeID;
|
|
308
|
+
if (SrcNodePort >= 0)
|
|
309
|
+
O << ":s" << SrcNodePort;
|
|
310
|
+
O << " -> Node" << DestNodeID;
|
|
311
|
+
if (DestNodePort >= 0 && DTraits.hasEdgeDestLabels())
|
|
312
|
+
O << ":d" << DestNodePort;
|
|
313
|
+
|
|
314
|
+
if (!Attrs.empty())
|
|
315
|
+
O << "[" << Attrs << "]";
|
|
316
|
+
O << ";\n";
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
/// getOStream - Get the raw output stream into the graph file. Useful to
|
|
320
|
+
/// write fancy things using addCustomGraphFeatures().
|
|
321
|
+
std::ofstream &getOStream()
|
|
322
|
+
{
|
|
323
|
+
return O;
|
|
324
|
+
}
|
|
325
|
+
};
|
|
326
|
+
|
|
327
|
+
template<typename GraphType>
|
|
328
|
+
std::ofstream &WriteGraph(std::ofstream &O, const GraphType &G,
|
|
329
|
+
bool ShortNames = false)
|
|
330
|
+
{
|
|
331
|
+
// Start the graph emission process...
|
|
332
|
+
GraphWriter<GraphType> W(O, G, ShortNames);
|
|
333
|
+
|
|
334
|
+
// Emit the graph.
|
|
335
|
+
W.writeGraph("");
|
|
336
|
+
|
|
337
|
+
return O;
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
/// Writes graph into a provided @c Filename.
|
|
341
|
+
/// If @c Filename is empty, generates a random one.
|
|
342
|
+
/// \return The resulting filename, or an empty string if writing
|
|
343
|
+
/// failed.
|
|
344
|
+
template <typename GraphType>
|
|
345
|
+
std::string WriteGraph(const GraphType &G,
|
|
346
|
+
bool ShortNames = false,
|
|
347
|
+
std::string Filename = "")
|
|
348
|
+
{
|
|
349
|
+
|
|
350
|
+
std::ofstream O(Filename);
|
|
351
|
+
|
|
352
|
+
if (O.fail())
|
|
353
|
+
{
|
|
354
|
+
std::cerr << "error opening file '" << Filename << "' for writing!\n";
|
|
355
|
+
O.close();
|
|
356
|
+
return "";
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
SVF::WriteGraph(O, G, ShortNames);
|
|
360
|
+
O.close();
|
|
361
|
+
|
|
362
|
+
std::cerr << " done. \n";
|
|
363
|
+
|
|
364
|
+
return Filename;
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
/// ViewGraph - Emit a dot graph, run 'dot', run gv on the postscript file,
|
|
368
|
+
/// then cleanup. For use from the debugger.
|
|
369
|
+
///
|
|
370
|
+
template<typename GraphType>
|
|
371
|
+
void ViewGraph(const GraphType &G,const std::string& name,
|
|
372
|
+
bool ShortNames = false,
|
|
373
|
+
GraphProgram::Name Program = GraphProgram::DOT)
|
|
374
|
+
{
|
|
375
|
+
SVF::WriteGraph(G, ShortNames);
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
} // end namespace llvm
|
|
379
|
+
|
|
380
|
+
#endif // LLVM_SUPPORT_GRAPHWRITER_H
|