#静态分析

gptlint - 通过LLM强化代码质量的先进静态分析工具
GPTLint代码质量LLM静态分析ESLintGithub开源项目
GPTLint利用大语言模型(LLMs)在代码库中应用高级最佳实践,超过传统静态分析工具如ESLint。它支持自定义和项目专用规则以及内容缓存,兼容主要LLM提供商和本地模型,提供详尽的运行统计。目前,仅支持JS/TS和单文件上下文,不支持自动修复。
phpat - PHP架构测试工具,支持自定义规则和合规检查
PHP Architecture TesterPHP静态分析架构测试开源Github开源项目
这是一款易于使用的静态分析工具,用于验证PHP代码的架构要求,支持用户使用自然语言定义和检查代码的架构规则。适合开发人员在日常使用和项目中的架构治理。需要注意,0.x.x版本可能会有不兼容的变更,直到稳定的1.0.0版本发布。
ast-grep - 基于AST的代码结构搜索和重构工具
ast-grep代码搜索代码重写静态分析抽象语法树Github开源项目
ast-grep是一个基于抽象语法树的代码搜索和重构工具。它支持多种编程语言,提供类似jQuery的API进行AST遍历和操作。通过直观的模式匹配语法,ast-grep可用于大规模代码分析和修改。该工具具有高性能、跨平台特性,适用于代码重构、静态分析和自定义lint规则开发等场景。
nilaway - 编译时捕获Go代码nil指针异常
NilAwayGo语言静态分析空指针检测编译时检查Github开源项目
NilAway是一款静态分析工具,专门用于在编译时检测Go代码中的nil指针异常。它无需额外注释,能够跨包分析nil流,并提供详细错误报告。NilAway以低开销和高精度著称,适合大型Go项目使用。该工具支持独立运行,也可与golangci-lint和Bazel/nogo集成,为开发者提供灵活的使用方式。
seahorn - 基于LLVM的开源软件验证与分析框架
SeaHorn软件验证LLVM静态分析模型检查Github开源项目
SeaHorn是一个基于LLVM的开源软件验证和分析框架。它集成了抽象解释、指针分析、约束求解等多种技术,可用于检测程序错误、生成反例和推导不变式。SeaHorn采用模块化设计,提供可组合的分析组件,适用于各类自动化验证研究。该框架支持多种编码方式和分析精度,能够灵活应对不同的验证需求。
type-guard - PHP类型断言与缩小的开源库
Type GuardPinkary ProjectPHP类型检查静态分析Github开源项目
type-guard是Pinkary Project的一个开源模块,用于PHP变量类型的缩小和断言。它提供type函数进行对象类型检查,支持PHPStan和Psalm静态分析。该库包含多种类型断言方法,如asInt()和asString(),有助于增强PHP代码的类型安全性。
phpstorm-attributes - PhpStorm中的PHP 8属性集优化代码分析与完成
PhpStormPHP属性代码补全静态分析开发工具Github开源项目
phpstorm-attributes项目为PhpStorm提供了一套PHP 8属性,用于增强代码完成和静态分析功能。这些属性包括Deprecated、ArrayShape、ObjectShape、Immutable、Pure、ExpectedValues、NoReturn和Language,能够帮助开发者更准确地定义和分析代码结构。通过使用这些属性,开发者可以提高代码质量,优化开发体验,从而提升PHP编程的效率和准确性。
SwiftLint - Swift代码风格和规范自动化检查工具
SwiftLintSwift代码规范静态分析开源工具Github开源项目
SwiftLint是一款自动化执行Swift代码风格和规范的开源工具,借鉴GitHub Swift风格指南。通过Clang和SourceKit分析源代码AST,提供精准检查结果。支持Swift Package Manager、Homebrew等多种安装方式,可集成至Xcode、VS Code和CI/CD流程,提高代码质量和一致性。
compose-rules - Jetpack Compose静态分析规则集
Jetpack Compose静态分析ktlintdetektAndroid开发Github开源项目
compose-rules为Jetpack Compose开发提供静态分析规则集,支持ktlint和detekt工具。该项目旨在提升大型团队采用Compose的效率,通过检测常见问题优化代码质量。规则集涵盖Compose开发中的多种陷阱,为开发者提供及时的错误提示和编码指导。
refurb - 智能优化和现代化Python代码库的工具
RefurbPython代码优化静态分析重构Github开源项目
Refurb是一款用于优化和现代化Python代码库的开源工具。它能智能分析代码结构,识别可改进的部分,并给出具体建议,协助开发者编写更简洁、易读的代码。Refurb提供多种检查规则,支持通过命令行或配置文件自定义。其插件系统允许用户扩展功能。Refurb适用于新旧项目,有助于提高代码质量和可维护性。
CodeAnalysis - 开源综合代码分析和问题追踪平台
代码分析TCA静态分析代码质量开源项目Github
TCA是一个开源的综合代码分析和问题追踪平台,集成多种分析工具。支持Java、C++等主流编程语言,可发现代码质量问题、规范缺陷和安全漏洞。平台提供代码检查、度量功能,支持DevOps集成,并开放API便于系统对接。TCA有助于团队持续监控和改进代码质量,适用于各类软件开发项目。
checkstyle - Java源代码规范检查工具 提升代码质量与可维护性
CheckstyleJava代码检查代码规范静态分析开源项目Github
Checkstyle是一个开源的Java源代码检查工具,用于验证代码是否符合指定的编码标准和规则。该工具有助于保持代码风格一致性,提升代码质量。Checkstyle支持自定义规则配置,可与多种持续集成工具集成,并提供完善的文档。它的灵活性和功能性使其成为Java项目代码质量管理的有力工具。
gigahorse-toolchain - 开源智能合约反编译和分析框架
GigahorseEVM智能合约反编译静态分析Github开源项目
Gigahorse是一个开源的以太坊智能合约反编译和分析工具链。它将低级EVM代码转换为类似LLVM IR的高级三地址表示。该工具提供多种上下文敏感性配置,支持函数内联,可与各类客户端分析工具集成。Gigahorse为智能合约研究和安全分析奠定了基础,已在多个学术项目和实时分析平台中得到应用。
slither - 智能合约静态分析框架 检测漏洞提升代码质量
Slither智能合约静态分析漏洞检测SolidityGithub开源项目
Slither是一个开源的智能合约静态分析框架,支持Solidity和Vyper语言。它能够检测常见漏洞,生成合约报告,并允许开发自定义分析。Slither具有低误报、快速分析、易于集成等特点,可帮助开发者提高代码质量,增强对合约的理解。该工具支持Solidity 0.4及以上版本,平均分析时间不到1秒。
diktat - 严格的Kotlin代码规范与自动修复工具
diKTatKotlin代码风格静态分析CI/CDGithub开源项目
diKTat是一款严格的Kotlin代码规范工具,基于KTlint开发。它提供100多项代码风格检查和自动修复功能,可集成到CI/CD流程中检测和修复代码异味。diKTat具有独特的检查项、高度可配置性和详细的代码风格指南,适合需要执行统一编码标准的团队使用。工具支持Maven、Gradle等构建系统,并能与GitHub Actions集成,提供原生问题报告。
eslint-plugin-import-x - 优化ES6+模块导入导出语法的ESLint扩展
ESLint插件import语法静态分析模块导入代码规范Github开源项目
eslint-plugin-import-x是一个ESLint插件,专注于ES2015+模块语法的检查和优化。它能够检测文件路径和导入名称的拼写错误,确保模块导入的准确性。该插件提供多种规则,包括警告提示、模块系统检查、静态分析和代码风格指南,有助于开发者更好地利用ES2015+静态模块语法,提升代码质量。
pyre-check - 高性能Python类型检查器 支持大规模代码增量分析
PyrePython类型检查静态分析PysaGithub开源项目
Pyre是一款符合PEP 484标准的高性能Python类型检查器,能对大规模代码库进行增量分析,为开发者提供即时反馈。项目还包含Pysa,一个基于Pyre的安全导向静态分析工具。Pyre支持Python 3.8及以上版本,安装配置简便。通过命令行接口,Pyre能快速检测类型错误,有助于提升代码质量和安全性。
View8 - 高效反编译V8字节码的静态分析工具
View8V8字节码静态分析反编译命令行工具Github开源项目
View8是一款静态分析工具,专门用于反编译序列化的V8字节码(JSC文件)。通过使用修补的V8二进制文件,View8能够解析和反汇编这些字节码,生成可读性强的类JavaScript代码。工具支持多个V8版本,提供命令行接口,允许用户选择多种输出格式。View8还能自动检测字节码版本,为开发者简化了反编译过程。
ezno - Rust 编写的 JavaScript 编译器与 TypeScript 检查工具
EznoJavaScript编译器TypeScript检查器静态分析性能优化Github开源项目
ezno 是一个 JavaScript 编译器和 TypeScript 检查工具,采用 Rust 语言开发。该项目注重静态分析和运行时性能,提供类型安全检查和命令行接口。ezno 实现了命令式类型系统,能够追踪函数和控制流结构的副作用。作为一个快速、轻量的开源项目,ezno 通过深度静态分析探索类型检查、优化和编译的新方法。
pydocstyle - 已弃用的Python文档风格检查工具
pydocstyle代码风格检查Python文档字符串静态分析Github开源项目
pydocstyle是一个静态分析工具,用于检查Python文档字符串的规范性。该工具支持大部分PEP 257规范,适用于Python 3.6及以上版本。尽管pydocstyle项目已正式停止维护,但其为Python社区贡献的价值仍然显著。目前,官方推荐用户迁移到功能更全面的Ruff工具。pydocstyle的开发历程和社区参与对Python生态系统的完善产生了积极影响。
rust-clippy - Rust代码静态分析工具 助力提升代码质量
ClippyRust代码检查lint静态分析Github开源项目
Clippy是Rust语言的静态代码分析工具,提供超过700个lint规则,用于检测常见错误和优化代码。它可作为cargo子命令运行,支持自动修复建议。Clippy将规则分类,允许用户按需调整lint级别。此外,Clippy支持自定义配置和指定最低兼容的Rust版本。作为开源项目,Clippy为Rust开发者提供了有力的代码质量保障工具。
pybind11-stubgen - 自动生成Python扩展模块类型存根文件的开源工具
pybind11-stubgenPython扩展静态分析存根生成IDE支持Github开源项目
pybind11-stubgen是一个为Python扩展模块生成类型存根文件的开源工具。它可自动创建存根文件,帮助静态分析工具和IDE更好地理解和处理二进制扩展。虽然针对pybind11编译的模块进行了优化,但也适用于其他库构建的模块。通过命令行操作,开发者可以生成存根文件,提高Python项目的开发效率和代码质量。
codechecker - 基于LLVM/Clang的多功能静态代码分析工具
CodeChecker静态分析代码检查C/C++开源工具Github开源项目
CodeChecker是基于LLVM/Clang的静态代码分析工具,提供命令行C/C++分析和Web报告管理功能。它支持多种分析器,可自动分析GCC交叉编译项目,并支持增量分析。其Web应用可视化代码缺陷,支持结果过滤和比较,集成Gerrit和GitLab。CodeChecker还能可视化多种编程语言的分析结果,是一款通用的代码质量保证工具。
periphery - Swift项目未使用代码识别工具
PeripherySwift代码分析未使用代码静态分析Github开源项目
Periphery是一款识别Swift项目中未使用代码的开源工具。它能分析项目结构,找出未引用的声明、未使用的函数参数和冗余协议等。支持Xcode和Swift Package Manager项目,可通过Homebrew或Mint安装。Periphery提供命令行界面和Xcode集成,帮助开发者清理代码。其分析范围涵盖函数参数、协议、枚举和属性等多个方面,适用于Swift项目代码优化。
vermin - 强大的Python代码版本兼容性分析工具
VerminPython版本检测静态分析兼容性Github开源项目
Vermin是一款开源的Python代码分析工具,专门用于检测程序所需的最低Python版本。通过解析抽象语法树和匹配内部规则,它可以识别Python 2.0-2.7和3.0-3.12的语言特性。Vermin能够分析模块、类、函数等多种语言元素,内置了3796条检测规则。此外,它还提供配置文件、多进程分析、lint模式等功能,有助于开发者管理Python项目的版本兼容性。
monitors4codegen - Monitor-Guided Decoding提升代码生成模型性能
Monitor-Guided Decoding静态分析代码生成Language Server Protocol多语言支持Github开源项目
Monitor-Guided Decoding (MGD)是一种创新的代码生成方法,利用静态分析指导语言模型解码。该方法无需额外训练即可提高350M至175B参数规模模型生成代码的编译成功率。项目提供多语言静态分析工具multilspy,支持Java、Rust、C#和Python代码分析,并包含数据集、评估脚本和推理结果,便于复现研究成果。
sonar-cxx - SonarQube C++插件,集成多种代码分析和测试工具
SonarQubeC++代码质量静态分析开源插件Github开源项目
sonar-cxx是一个开源的SonarQube C++插件,旨在集成现有的C++分析工具。该插件支持从C++03到C++20的语法解析,兼容多种编译器扩展,并提供静态和动态代码分析功能。它支持多种测试框架和覆盖率报告工具,允许自定义规则和集成第三方工具。sonar-cxx适用于Windows和Linux环境,为C++项目提供全面的代码质量管理解决方案。
eslint - JavaScript代码检查与质量保证工具
ESLintJavaScript代码质量静态分析开源项目Github
ESLint是一个开源的JavaScript代码检查工具,用于识别和报告代码中的问题。它支持最新的ECMAScript标准,使用抽象语法树进行代码分析,并提供可插拔的架构。ESLint具有灵活的配置选项,允许自定义规则和插件,有助于开发团队维护代码质量和一致性。作为JavaScript生态系统中的重要工具,ESLint通过静态代码分析帮助开发者发现并修复代码中的问题,提高代码质量,增强团队协作效率。
semgrep - 多语言代码扫描工具 快速检测漏洞并执行标准
Semgrep静态分析代码扫描安全漏洞检测开源软件Github开源项目
Semgrep是一款快速开源的静态分析工具,支持30多种编程语言。它使用简单的类代码规则语法,无需复杂的抽象语法树或正则表达式。Semgrep可在编辑器、代码提交和CI阶段进行代码搜索、bug检测和标准执行。该工具提供社区版和企业版,包含代码扫描、供应链安全和秘密检测功能,可在本地或CI/CD环境中部署,有效提升代码质量和安全性。
clair - 开源容器漏洞静态分析工具
Clair容器安全漏洞分析静态分析开源项目Github
Clair是一款开源的容器安全漏洞静态分析工具,支持OCI和Docker格式。它通过API接口使客户端能够索引容器镜像并检测已知漏洞,提升容器基础设施的安全透明度。Clair专注于容器安全分析,鼓励社区参与,设有邮件列表和IRC频道。项目采用Apache 2.0许可证,完整文档可在官方网站查阅。
rubocop - Ruby代码静态分析和自动格式化工具
RuboCopRuby代码分析代码格式化静态分析Github开源项目
RuboCop是一个Ruby静态代码分析和格式化工具。它根据社区Ruby风格指南检查代码,报告并自动修复问题。通过灵活的配置选项可调整大部分功能。支持MRI 2.7+和JRuby 9.4+运行环境,适用于Ruby 2.0+代码分析。RuboCop有助于提高代码质量和一致性,是Ruby开发中常用的辅助工具。
static-analysis - 综合静态分析工具库助力代码质量提升
静态分析代码质量安全检查多语言支持开源工具Github开源项目
static-analysis项目汇集了适用于各类编程语言、构建工具和配置文件的静态分析工具,重点收录代码检查器和格式化工具等提升代码质量的工具。项目官网analysis-tools.dev在此基础上增添了工具排名、用户评论及视频等扩展资源。涵盖ABAP至YAML等多种语言,同时覆盖容器、安全等领域,为开发者提供了全面的静态代码分析工具参考。