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.
Files changed (320) hide show
  1. package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/WorkList.h +0 -0
  2. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
  3. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
  4. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
  5. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
  6. package/SVF-linux-aarch64/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
  7. package/SVF-linux-aarch64/Release-build/lib/libSvfCore.so.3.1 +0 -0
  8. package/SVF-linux-aarch64/Release-build/lib/libSvfLLVM.so.3.1 +0 -0
  9. package/SVF-linux-aarch64/Release-build/lib/pkgconfig/SVF.pc +12 -0
  10. package/SVF-osx/Release-build/bin/ae +0 -0
  11. package/SVF-osx/Release-build/bin/cfl +0 -0
  12. package/SVF-osx/Release-build/bin/dvf +0 -0
  13. package/SVF-osx/Release-build/bin/llvm2svf +0 -0
  14. package/SVF-osx/Release-build/bin/mta +0 -0
  15. package/SVF-osx/Release-build/bin/saber +0 -0
  16. package/SVF-osx/Release-build/bin/svf-ex +0 -0
  17. package/SVF-osx/Release-build/bin/wpa +0 -0
  18. package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractState.h +425 -0
  19. package/SVF-osx/Release-build/include/SVF/AE/Core/AbstractValue.h +157 -0
  20. package/SVF-osx/Release-build/include/SVF/AE/Core/AddressValue.h +225 -0
  21. package/SVF-osx/Release-build/include/SVF/AE/Core/ICFGWTO.h +135 -0
  22. package/SVF-osx/Release-build/include/SVF/AE/Core/IntervalValue.h +1055 -0
  23. package/SVF-osx/Release-build/include/SVF/AE/Core/NumericValue.h +1292 -0
  24. package/SVF-osx/Release-build/include/SVF/AE/Core/RelExeState.h +226 -0
  25. package/SVF-osx/Release-build/include/SVF/AE/Core/RelationSolver.h +91 -0
  26. package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AEDetector.h +439 -0
  27. package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbsExtAPI.h +138 -0
  28. package/SVF-osx/Release-build/include/SVF/AE/Svfexe/AbstractInterpretation.h +384 -0
  29. package/SVF-osx/Release-build/include/SVF/CFL/CFGNormalizer.h +84 -0
  30. package/SVF-osx/Release-build/include/SVF/CFL/CFGrammar.h +468 -0
  31. package/SVF-osx/Release-build/include/SVF/CFL/CFLAlias.h +168 -0
  32. package/SVF-osx/Release-build/include/SVF/CFL/CFLBase.h +118 -0
  33. package/SVF-osx/Release-build/include/SVF/CFL/CFLGramGraphChecker.h +74 -0
  34. package/SVF-osx/Release-build/include/SVF/CFL/CFLGraphBuilder.h +168 -0
  35. package/SVF-osx/Release-build/include/SVF/CFL/CFLSVFGBuilder.h +58 -0
  36. package/SVF-osx/Release-build/include/SVF/CFL/CFLSolver.h +374 -0
  37. package/SVF-osx/Release-build/include/SVF/CFL/CFLStat.h +67 -0
  38. package/SVF-osx/Release-build/include/SVF/CFL/CFLVF.h +68 -0
  39. package/SVF-osx/Release-build/include/SVF/CFL/GrammarBuilder.h +100 -0
  40. package/SVF-osx/Release-build/include/SVF/DDA/ContextDDA.h +230 -0
  41. package/SVF-osx/Release-build/include/SVF/DDA/DDAClient.h +163 -0
  42. package/SVF-osx/Release-build/include/SVF/DDA/DDAPass.h +102 -0
  43. package/SVF-osx/Release-build/include/SVF/DDA/DDAStat.h +121 -0
  44. package/SVF-osx/Release-build/include/SVF/DDA/DDAVFSolver.h +794 -0
  45. package/SVF-osx/Release-build/include/SVF/DDA/FlowDDA.h +178 -0
  46. package/SVF-osx/Release-build/include/SVF/FastCluster/fastcluster.h +80 -0
  47. package/SVF-osx/Release-build/include/SVF/Graphs/BasicBlockG.h +318 -0
  48. package/SVF-osx/Release-build/include/SVF/Graphs/CDG.h +482 -0
  49. package/SVF-osx/Release-build/include/SVF/Graphs/CFLGraph.h +232 -0
  50. package/SVF-osx/Release-build/include/SVF/Graphs/CHG.h +368 -0
  51. package/SVF-osx/Release-build/include/SVF/Graphs/CallGraph.h +497 -0
  52. package/SVF-osx/Release-build/include/SVF/Graphs/ConsG.h +402 -0
  53. package/SVF-osx/Release-build/include/SVF/Graphs/ConsGEdge.h +355 -0
  54. package/SVF-osx/Release-build/include/SVF/Graphs/ConsGNode.h +418 -0
  55. package/SVF-osx/Release-build/include/SVF/Graphs/DOTGraphTraits.h +188 -0
  56. package/SVF-osx/Release-build/include/SVF/Graphs/GenericGraph.h +628 -0
  57. package/SVF-osx/Release-build/include/SVF/Graphs/GraphPrinter.h +111 -0
  58. package/SVF-osx/Release-build/include/SVF/Graphs/GraphTraits.h +150 -0
  59. package/SVF-osx/Release-build/include/SVF/Graphs/GraphWriter.h +380 -0
  60. package/SVF-osx/Release-build/include/SVF/Graphs/ICFG.h +331 -0
  61. package/SVF-osx/Release-build/include/SVF/Graphs/ICFGEdge.h +281 -0
  62. package/SVF-osx/Release-build/include/SVF/Graphs/ICFGNode.h +669 -0
  63. package/SVF-osx/Release-build/include/SVF/Graphs/ICFGStat.h +164 -0
  64. package/SVF-osx/Release-build/include/SVF/Graphs/IRGraph.h +398 -0
  65. package/SVF-osx/Release-build/include/SVF/Graphs/SCC.h +375 -0
  66. package/SVF-osx/Release-build/include/SVF/Graphs/SVFG.h +491 -0
  67. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGEdge.h +237 -0
  68. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGNode.h +501 -0
  69. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGOPT.h +372 -0
  70. package/SVF-osx/Release-build/include/SVF/Graphs/SVFGStat.h +273 -0
  71. package/SVF-osx/Release-build/include/SVF/Graphs/ThreadCallGraph.h +399 -0
  72. package/SVF-osx/Release-build/include/SVF/Graphs/VFG.h +726 -0
  73. package/SVF-osx/Release-build/include/SVF/Graphs/VFGEdge.h +295 -0
  74. package/SVF-osx/Release-build/include/SVF/Graphs/VFGNode.h +1266 -0
  75. package/SVF-osx/Release-build/include/SVF/Graphs/WTO.h +872 -0
  76. package/SVF-osx/Release-build/include/SVF/MSSA/MSSAMuChi.h +722 -0
  77. package/SVF-osx/Release-build/include/SVF/MSSA/MemPartition.h +169 -0
  78. package/SVF-osx/Release-build/include/SVF/MSSA/MemRegion.h +489 -0
  79. package/SVF-osx/Release-build/include/SVF/MSSA/MemSSA.h +452 -0
  80. package/SVF-osx/Release-build/include/SVF/MSSA/SVFGBuilder.h +104 -0
  81. package/SVF-osx/Release-build/include/SVF/MTA/LockAnalysis.h +533 -0
  82. package/SVF-osx/Release-build/include/SVF/MTA/MHP.h +546 -0
  83. package/SVF-osx/Release-build/include/SVF/MTA/MTA.h +97 -0
  84. package/SVF-osx/Release-build/include/SVF/MTA/MTAStat.h +73 -0
  85. package/SVF-osx/Release-build/include/SVF/MTA/TCT.h +620 -0
  86. package/SVF-osx/Release-build/include/SVF/MemoryModel/AbstractPointsToDS.h +316 -0
  87. package/SVF-osx/Release-build/include/SVF/MemoryModel/AccessPath.h +194 -0
  88. package/SVF-osx/Release-build/include/SVF/MemoryModel/ConditionalPT.h +878 -0
  89. package/SVF-osx/Release-build/include/SVF/MemoryModel/MutablePointsToDS.h +1025 -0
  90. package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToCache.h +463 -0
  91. package/SVF-osx/Release-build/include/SVF/MemoryModel/PersistentPointsToDS.h +955 -0
  92. package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysis.h +428 -0
  93. package/SVF-osx/Release-build/include/SVF/MemoryModel/PointerAnalysisImpl.h +602 -0
  94. package/SVF-osx/Release-build/include/SVF/MemoryModel/PointsTo.h +255 -0
  95. package/SVF-osx/Release-build/include/SVF/MemoryModel/SVFLoop.h +167 -0
  96. package/SVF-osx/Release-build/include/SVF/SABER/DoubleFreeChecker.h +76 -0
  97. package/SVF-osx/Release-build/include/SVF/SABER/FileChecker.h +80 -0
  98. package/SVF-osx/Release-build/include/SVF/SABER/LeakChecker.h +122 -0
  99. package/SVF-osx/Release-build/include/SVF/SABER/ProgSlice.h +327 -0
  100. package/SVF-osx/Release-build/include/SVF/SABER/SaberCheckerAPI.h +151 -0
  101. package/SVF-osx/Release-build/include/SVF/SABER/SaberCondAllocator.h +317 -0
  102. package/SVF-osx/Release-build/include/SVF/SABER/SaberSVFGBuilder.h +114 -0
  103. package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkDDA.h +327 -0
  104. package/SVF-osx/Release-build/include/SVF/SABER/SrcSnkSolver.h +186 -0
  105. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BasicTypes.h +280 -0
  106. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/BreakConstantExpr.h +93 -0
  107. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CHGBuilder.h +78 -0
  108. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/CppUtil.h +184 -0
  109. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/DCHG.h +474 -0
  110. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/GEPTypeBridgeIterator.h +183 -0
  111. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ICFGBuilder.h +160 -0
  112. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMLoopAnalysis.h +60 -0
  113. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMModule.h +527 -0
  114. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/LLVMUtil.h +433 -0
  115. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/ObjTypeInference.h +129 -0
  116. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SVFIRBuilder.h +523 -0
  117. package/SVF-osx/Release-build/include/SVF/SVF-LLVM/SymbolTableBuilder.h +132 -0
  118. package/SVF-osx/Release-build/include/SVF/SVFIR/ObjTypeInfo.h +224 -0
  119. package/SVF-osx/Release-build/include/SVF/SVFIR/PAGBuilderFromFile.h +80 -0
  120. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFIR.h +856 -0
  121. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFStatements.h +1330 -0
  122. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFType.h +606 -0
  123. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFValue.h +338 -0
  124. package/SVF-osx/Release-build/include/SVF/SVFIR/SVFVariables.h +2212 -0
  125. package/SVF-osx/Release-build/include/SVF/Util/Annotator.h +180 -0
  126. package/SVF-osx/Release-build/include/SVF/Util/BitVector.h +55 -0
  127. package/SVF-osx/Release-build/include/SVF/Util/CDGBuilder.h +107 -0
  128. package/SVF-osx/Release-build/include/SVF/Util/CallGraphBuilder.h +61 -0
  129. package/SVF-osx/Release-build/include/SVF/Util/Casting.h +426 -0
  130. package/SVF-osx/Release-build/include/SVF/Util/CommandLine.h +530 -0
  131. package/SVF-osx/Release-build/include/SVF/Util/CoreBitVector.h +214 -0
  132. package/SVF-osx/Release-build/include/SVF/Util/CxtStmt.h +502 -0
  133. package/SVF-osx/Release-build/include/SVF/Util/DPItem.h +618 -0
  134. package/SVF-osx/Release-build/include/SVF/Util/ExtAPI.h +117 -0
  135. package/SVF-osx/Release-build/include/SVF/Util/GeneralType.h +127 -0
  136. package/SVF-osx/Release-build/include/SVF/Util/GraphReachSolver.h +186 -0
  137. package/SVF-osx/Release-build/include/SVF/Util/NodeIDAllocator.h +203 -0
  138. package/SVF-osx/Release-build/include/SVF/Util/Options.h +273 -0
  139. package/SVF-osx/Release-build/include/SVF/Util/PTAStat.h +83 -0
  140. package/SVF-osx/Release-build/include/SVF/Util/SVFBugReport.h +427 -0
  141. package/SVF-osx/Release-build/include/SVF/Util/SVFLoopAndDomInfo.h +169 -0
  142. package/SVF-osx/Release-build/include/SVF/Util/SVFStat.h +103 -0
  143. package/SVF-osx/Release-build/include/SVF/Util/SVFUtil.h +478 -0
  144. package/SVF-osx/Release-build/include/SVF/Util/SparseBitVector.h +1252 -0
  145. package/SVF-osx/Release-build/include/SVF/Util/ThreadAPI.h +188 -0
  146. package/SVF-osx/Release-build/include/SVF/Util/WorkList.h +317 -0
  147. package/SVF-osx/Release-build/include/SVF/Util/Z3Expr.h +325 -0
  148. package/SVF-osx/Release-build/include/SVF/Util/cJSON.h +300 -0
  149. package/SVF-osx/Release-build/include/SVF/Util/config.h +46 -0
  150. package/SVF-osx/Release-build/include/SVF/Util/iterator.h +407 -0
  151. package/SVF-osx/Release-build/include/SVF/Util/iterator_range.h +76 -0
  152. package/SVF-osx/Release-build/include/SVF/WPA/Andersen.h +434 -0
  153. package/SVF-osx/Release-build/include/SVF/WPA/AndersenPWC.h +160 -0
  154. package/SVF-osx/Release-build/include/SVF/WPA/CSC.h +95 -0
  155. package/SVF-osx/Release-build/include/SVF/WPA/FlowSensitive.h +322 -0
  156. package/SVF-osx/Release-build/include/SVF/WPA/Steensgaard.h +131 -0
  157. package/SVF-osx/Release-build/include/SVF/WPA/TypeAnalysis.h +90 -0
  158. package/SVF-osx/Release-build/include/SVF/WPA/VersionedFlowSensitive.h +295 -0
  159. package/SVF-osx/Release-build/include/SVF/WPA/WPAFSSolver.h +246 -0
  160. package/SVF-osx/Release-build/include/SVF/WPA/WPAPass.h +115 -0
  161. package/SVF-osx/Release-build/include/SVF/WPA/WPASolver.h +205 -0
  162. package/SVF-osx/Release-build/include/SVF/WPA/WPAStat.h +222 -0
  163. package/SVF-osx/Release-build/include/SVF/extapi.bc +2384 -0
  164. package/SVF-osx/Release-build/lib/cmake/SVF/Modules/FindZ3.cmake +93 -0
  165. package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfig.cmake +106 -0
  166. package/SVF-osx/Release-build/lib/cmake/SVF/SVFConfigVersion.cmake +43 -0
  167. package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets-release.cmake +101 -0
  168. package/SVF-osx/Release-build/lib/cmake/SVF/SVFTargets.cmake +180 -0
  169. package/SVF-osx/Release-build/lib/libSvfCore.3.1.dylib +0 -0
  170. package/SVF-osx/Release-build/lib/libSvfLLVM.3.1.dylib +0 -0
  171. package/SVF-osx/Release-build/lib/pkgconfig/SVF.pc +12 -0
  172. package/package.json +1 -1
  173. package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PAGGrammar.txt +0 -15
  174. package/SVF-linux-aarch64/Release-build/include/CFL/grammar/PEGGrammar.txt +0 -11
  175. package/SVF-linux-aarch64/Release-build/include/CFL/grammar/VFGGrammar.txt +0 -7
  176. package/SVF-linux-aarch64/Release-build/include/FastCluster/LICENSE.TXT +0 -13
  177. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractState.h +0 -0
  178. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AbstractValue.h +0 -0
  179. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/AddressValue.h +0 -0
  180. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/ICFGWTO.h +0 -0
  181. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/IntervalValue.h +0 -0
  182. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/NumericValue.h +0 -0
  183. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelExeState.h +0 -0
  184. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Core/RelationSolver.h +0 -0
  185. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AEDetector.h +0 -0
  186. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbsExtAPI.h +0 -0
  187. /package/SVF-linux-aarch64/Release-build/include/{AE → SVF/AE}/Svfexe/AbstractInterpretation.h +0 -0
  188. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGNormalizer.h +0 -0
  189. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFGrammar.h +0 -0
  190. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLAlias.h +0 -0
  191. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLBase.h +0 -0
  192. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGramGraphChecker.h +0 -0
  193. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLGraphBuilder.h +0 -0
  194. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSVFGBuilder.h +0 -0
  195. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLSolver.h +0 -0
  196. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLStat.h +0 -0
  197. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/CFLVF.h +0 -0
  198. /package/SVF-linux-aarch64/Release-build/include/{CFL → SVF/CFL}/GrammarBuilder.h +0 -0
  199. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/ContextDDA.h +0 -0
  200. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAClient.h +0 -0
  201. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAPass.h +0 -0
  202. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAStat.h +0 -0
  203. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/DDAVFSolver.h +0 -0
  204. /package/SVF-linux-aarch64/Release-build/include/{DDA → SVF/DDA}/FlowDDA.h +0 -0
  205. /package/SVF-linux-aarch64/Release-build/include/{FastCluster → SVF/FastCluster}/fastcluster.h +0 -0
  206. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/BasicBlockG.h +0 -0
  207. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CDG.h +0 -0
  208. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CFLGraph.h +0 -0
  209. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CHG.h +0 -0
  210. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/CallGraph.h +0 -0
  211. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsG.h +0 -0
  212. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGEdge.h +0 -0
  213. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ConsGNode.h +0 -0
  214. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/DOTGraphTraits.h +0 -0
  215. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GenericGraph.h +0 -0
  216. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphPrinter.h +0 -0
  217. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphTraits.h +0 -0
  218. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/GraphWriter.h +0 -0
  219. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFG.h +0 -0
  220. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGEdge.h +0 -0
  221. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGNode.h +0 -0
  222. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ICFGStat.h +0 -0
  223. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/IRGraph.h +0 -0
  224. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SCC.h +0 -0
  225. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFG.h +0 -0
  226. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGEdge.h +0 -0
  227. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGNode.h +0 -0
  228. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGOPT.h +0 -0
  229. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/SVFGStat.h +0 -0
  230. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/ThreadCallGraph.h +0 -0
  231. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFG.h +0 -0
  232. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGEdge.h +0 -0
  233. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/VFGNode.h +0 -0
  234. /package/SVF-linux-aarch64/Release-build/include/{Graphs → SVF/Graphs}/WTO.h +0 -0
  235. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MSSAMuChi.h +0 -0
  236. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemPartition.h +0 -0
  237. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemRegion.h +0 -0
  238. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/MemSSA.h +0 -0
  239. /package/SVF-linux-aarch64/Release-build/include/{MSSA → SVF/MSSA}/SVFGBuilder.h +0 -0
  240. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/LockAnalysis.h +0 -0
  241. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MHP.h +0 -0
  242. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTA.h +0 -0
  243. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/MTAStat.h +0 -0
  244. /package/SVF-linux-aarch64/Release-build/include/{MTA → SVF/MTA}/TCT.h +0 -0
  245. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AbstractPointsToDS.h +0 -0
  246. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/AccessPath.h +0 -0
  247. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/ConditionalPT.h +0 -0
  248. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/MutablePointsToDS.h +0 -0
  249. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToCache.h +0 -0
  250. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PersistentPointsToDS.h +0 -0
  251. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysis.h +0 -0
  252. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointerAnalysisImpl.h +0 -0
  253. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/PointsTo.h +0 -0
  254. /package/SVF-linux-aarch64/Release-build/include/{MemoryModel → SVF/MemoryModel}/SVFLoop.h +0 -0
  255. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/DoubleFreeChecker.h +0 -0
  256. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/FileChecker.h +0 -0
  257. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/LeakChecker.h +0 -0
  258. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/ProgSlice.h +0 -0
  259. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCheckerAPI.h +0 -0
  260. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberCondAllocator.h +0 -0
  261. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SaberSVFGBuilder.h +0 -0
  262. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkDDA.h +0 -0
  263. /package/SVF-linux-aarch64/Release-build/include/{SABER → SVF/SABER}/SrcSnkSolver.h +0 -0
  264. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BasicTypes.h +0 -0
  265. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/BreakConstantExpr.h +0 -0
  266. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CHGBuilder.h +0 -0
  267. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/CppUtil.h +0 -0
  268. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/DCHG.h +0 -0
  269. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/GEPTypeBridgeIterator.h +0 -0
  270. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ICFGBuilder.h +0 -0
  271. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMLoopAnalysis.h +0 -0
  272. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMModule.h +0 -0
  273. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/LLVMUtil.h +0 -0
  274. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/ObjTypeInference.h +0 -0
  275. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SVFIRBuilder.h +0 -0
  276. /package/SVF-linux-aarch64/Release-build/include/{SVF-LLVM → SVF/SVF-LLVM}/SymbolTableBuilder.h +0 -0
  277. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/ObjTypeInfo.h +0 -0
  278. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/PAGBuilderFromFile.h +0 -0
  279. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFIR.h +0 -0
  280. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFStatements.h +0 -0
  281. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFType.h +0 -0
  282. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFValue.h +0 -0
  283. /package/SVF-linux-aarch64/Release-build/include/{SVFIR → SVF/SVFIR}/SVFVariables.h +0 -0
  284. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Annotator.h +0 -0
  285. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/BitVector.h +0 -0
  286. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CDGBuilder.h +0 -0
  287. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CallGraphBuilder.h +0 -0
  288. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Casting.h +0 -0
  289. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CommandLine.h +0 -0
  290. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CoreBitVector.h +0 -0
  291. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/CxtStmt.h +0 -0
  292. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/DPItem.h +0 -0
  293. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ExtAPI.h +0 -0
  294. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GeneralType.h +0 -0
  295. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/GraphReachSolver.h +0 -0
  296. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/NodeIDAllocator.h +0 -0
  297. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Options.h +0 -0
  298. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/PTAStat.h +0 -0
  299. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFBugReport.h +0 -0
  300. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFLoopAndDomInfo.h +0 -0
  301. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFStat.h +0 -0
  302. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SVFUtil.h +0 -0
  303. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/SparseBitVector.h +0 -0
  304. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/ThreadAPI.h +0 -0
  305. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/Z3Expr.h +0 -0
  306. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/cJSON.h +0 -0
  307. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator.h +0 -0
  308. /package/SVF-linux-aarch64/Release-build/include/{Util → SVF/Util}/iterator_range.h +0 -0
  309. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Andersen.h +0 -0
  310. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/AndersenPWC.h +0 -0
  311. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/CSC.h +0 -0
  312. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/FlowSensitive.h +0 -0
  313. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/Steensgaard.h +0 -0
  314. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/TypeAnalysis.h +0 -0
  315. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/VersionedFlowSensitive.h +0 -0
  316. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAFSSolver.h +0 -0
  317. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAPass.h +0 -0
  318. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPASolver.h +0 -0
  319. /package/SVF-linux-aarch64/Release-build/include/{WPA → SVF/WPA}/WPAStat.h +0 -0
  320. /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 &GT, 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 &GT)
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