Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/github/codeql-coding-standards
This repository contains CodeQL queries and libraries which support various Coding Standards.
https://github.com/github/codeql-coding-standards
autosar cert code-scanning codeql coding-standards cpp14 functional-safety iso26262 misra
Last synced: 1 day ago
JSON representation
This repository contains CodeQL queries and libraries which support various Coding Standards.
- Host: GitHub
- URL: https://github.com/github/codeql-coding-standards
- Owner: github
- License: mit
- Created: 2022-07-12T13:30:35.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2025-01-09T21:22:05.000Z (9 days ago)
- Last Synced: 2025-01-10T16:12:30.641Z (9 days ago)
- Topics: autosar, cert, code-scanning, codeql, coding-standards, cpp14, functional-safety, iso26262, misra
- Language: CodeQL
- Homepage:
- Size: 9.38 MB
- Stars: 128
- Watchers: 6
- Forks: 60
- Open Issues: 120
-
Metadata Files:
- Readme: README.md
- Changelog: change_notes/2021-06-29-remove-incompatability-codeql-cli-2.5.6.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
- Support: supported_codeql_configs.json
Awesome Lists containing this project
- awesome-codeql - GitHub codeql-coding-standards - This repository contains CodeQL queries and libraries which support various Coding Standards. (AUTOSAR C++, CERT-C++,CERT C, MISRA C) (CodeQL [Packs](https://docs.github.com/en/code-security/codeql-cli/using-the-codeql-cli/publishing-and-using-codeql-packs))
README
# CodeQL Coding Standards
This repository contains CodeQL queries and libraries which support various Coding Standards.
## Supported standards
_Carnegie Mellon and CERT are registered trademarks of Carnegie Mellon University._
This repository contains CodeQL queries and libraries which support various Coding Standards for the [C++14](https://www.iso.org/standard/64029.html), [C99](https://www.iso.org/standard/29237.html) and [C11](https://www.iso.org/standard/57853.html) programming languages.
The following coding standards are supported:
- [AUTOSAR - Guidelines for the use of C++14 language in critical and safety-related systems (Releases R22-11, R20-11, R19-11 and R19-03)](https://www.autosar.org/fileadmin/standards/R22-11/AP/AUTOSAR_RS_CPP14Guidelines.pdf).
- [SEI CERT C++ Coding Standard: Rules for Developing Safe, Reliable, and Secure Systems (2016 Edition)](https://resources.sei.cmu.edu/library/asset-view.cfm?assetID=494932)
- [SEI CERT C Coding Standard: Rules for Developing Safe, Reliable, and Secure Systems (2016 Edition)](https://resources.sei.cmu.edu/downloads/secure-coding/assets/sei-cert-c-coding-standard-2016-v01.pdf)
- [MISRA C 2012, 3rd Edition, 1st revision](https://www.misra.org.uk/product/misra-c2012-third-edition-first-revision/) (incoporating Amendment 1 & Technical Corrigendum 1). In addition, we support the following additional amendments and technical corrigendums:
- [MISRA C 2012 Amendment 2](https://misra.org.uk/app/uploads/2021/06/MISRA-C-2012-AMD2.pdf)
- [MISRA C 2012 Technical Corrigendum 2](https://misra.org.uk/app/uploads/2022/04/MISRA-C-2012-TC2.pdf)## :construction: Standards under development :construction:
The following standards are under active development:
- [MISRA C++ 2023](https://misra.org.uk/product/misra-cpp2023/) - under development - _scheduled for release 2025 Q1_
- [MISRA C 2023](https://misra.org.uk/product/misra-c2023/) - under development - _scheduled for release 2025 Q1_
- This includes the development of [MISRA C 2012 Amendment 3](https://misra.org.uk/app/uploads/2021/06/MISRA-C-2012-AMD3.pdf) and [MISRA C 2012 Amendment 4](https://misra.org.uk/app/uploads/2021/06/MISRA-C-2012-AMD4.pdf), which are incorporated into MISRA C 2023.## How do I use the CodeQL Coding Standards Queries?
The use of the CodeQL Coding Standards is extensively documented in the [user manual](docs/user_manual.md).
### Use in a functional safety environment
The CodeQL Coding Standards is qualified as a "software tool" under "Part 8: Supporting processes" of ISO 26262 ("Road vehicles - Functional Safety") as described in our [tool qualification documents](docs/iso_26262_tool_qualification.md).
Use of the CodeQL Coding Standards is only compliant with the qualification if it is used as distributed by GitHub and according to the requirements described in the [user manual](docs/user_manual.md).Any changes to the CodeQL Coding Standards distribution and/or deviations from the requirements and steps described in the [user manual](docs/user_manual.md) runs the risk of non compliance.
## Contributing
We welcome contributions to our standard library and standard checks. Do you have an idea for a new check, or how to improve an existing query? Then please go ahead and open a pull request! Before you do, though, please take the time to read our [contributing guidelines](CONTRIBUTING.md). You can also consult our [development handbook](docs/development_handbook.md) to learn about the requirements for a contribution.
## License
Unless otherwise noted below, the code in this repository is licensed under the [MIT License](LICENSE.md) by [GitHub](https://github.com).
Parts of certain query help files (`.md` extension) are reproduced under the following licenses:
- [SEI CERT® Coding Standards](thirdparty/cert/LICENSE) (_reproduced as of 15th March 2021_).These licenses are directly referenced where applicable.
All code in the [thirdparty](./thirdparty) directory is licensed according to the files present in those sub directories.
All header files in [c/common/test/includes/standard-library](./c/common/test/includes/standard-library) are licensed according to [LICENSE](c/common/test/includes/standard-library/LICENSE)
---
1This repository incorporates portions of the SEI CERT® Coding Standards available at https://wiki.sei.cmu.edu/confluence/display/seccode/SEI+CERT+Coding+Standards; however, such use does not necessarily constitute or imply an endorsement, recommendation, or favoring by Carnegie Mellon University or its Software Engineering Institute.