Tree-sitter LLVM
A Tree-sitter grammar for LLVM IR assembly (.ll). This parser aims to closely follow LLVM's textual IR as parsed by LLParser, including modules, functions, types, instructions, attributes, metadata, and more.
Highlights and captures are provided in queries/highlights.scm.
Installation
- Node.js
- npm install tree-sitter-llvm
- Usage:
- const Parser = require('tree-sitter');
- const llvm = require('tree-sitter-llvm');
- const parser = new Parser();
- parser.setLanguage(llvm);
- const tree = parser.parse('%x = alloca i32');
- Rust
- Cargo.toml:
- tree-sitter-llvm = "1.1.0"
- Usage:
- let mut parser = tree_sitter::Parser::new();
- let language = tree_sitter_llvm::LANGUAGE;
- parser.set_language(&language.into()).unwrap();
- Python (tree-sitter >= 0.25)
- pip install tree-sitter-llvm
- Usage:
- from tree_sitter import Language, Parser
- import tree_sitter_llvm
- parser = Parser()
- parser.set_language(Language(tree_sitter_llvm.language()))
- C
- Include bindings/c/tree-sitter-llvm.h and link the generated parser in src/.
- The language symbol is: const TSLanguage *tree_sitter_llvm(void);
- Go
- The binding is in bindings/go. Example with go-tree-sitter:
- import (
- "github.com/tree-sitter/go-tree-sitter"
- llvm "path/to/this/repo/bindings/go"
- )
- parser := sitter.NewParser()
- parser.SetLanguage(sitter.NewLanguage(llvm.Language()))
- Swift (SwiftPM)
- Add this repository as a dependency and use TreeSitterLlvm target.
- Example:
- import SwiftTreeSitter
- import TreeSitterLlvm
- let parser = Parser()
- let language = Language(language: tree_sitter_llvm())
- try parser.setLanguage(language)
Status and scope
- Language name: llvm (as used by grammar.js)
- Targets LLVM IR textual format (.ll). MIR is out of scope.
- Grammar rules are modeled after LLVM's LLParser constructs (target definitions, declarations/definitions, instructions incl. alloca, getelementptr, phi, cmpxchg, atomicrmw, br; comdat; metadata; summaries; attributes; etc.).
Queries
- queries/highlights.scm contains basic highlighting captures for common editors that consume Tree-sitter queries.
Development
- Prerequisites: Node.js, npm, and tree-sitter-cli (npx tree-sitter works via devDependencies)
- Generate/rebuild parser C sources:
- npx tree-sitter generate
- Run grammar tests (corpus under test/corpus):
- npx tree-sitter test
- Rust tests (ensures the language loads):
- cargo test
- Python tests:
- pip install -e .[core]
- pytest bindings/python/tests
- Swift tests:
- swift test
Example
- See example/ and test/corpus for sample LLVM IR snippets and expected parses.
Contributing
- Issues and PRs are welcome. Please run tree-sitter tests and format code before submitting.
License
- MIT (see LICENSE)
Acknowledgements
- Based on LLVM's existing bindings and textual IR structure: https://github.com/llvm/llvm-project/blob/main/llvm/utils/
Raw data
{
"_id": null,
"home_page": null,
"name": "tree-sitter-llvm",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.10",
"maintainer_email": null,
"keywords": "incremental, parsing, tree-sitter, llvm",
"author": null,
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/d1/50/2e43a514dbaa5c525d419b22cadaa89b1665590d6bcf7fbb512472aa4002/tree_sitter_llvm-1.1.0.tar.gz",
"platform": null,
"description": "Tree-sitter LLVM\n\nA Tree-sitter grammar for LLVM IR assembly (.ll). This parser aims to closely follow LLVM's textual IR as parsed by LLParser, including modules, functions, types, instructions, attributes, metadata, and more.\n\nHighlights and captures are provided in queries/highlights.scm.\n\nInstallation\n- Node.js\n - npm install tree-sitter-llvm\n - Usage:\n - const Parser = require('tree-sitter');\n - const llvm = require('tree-sitter-llvm');\n - const parser = new Parser();\n - parser.setLanguage(llvm);\n - const tree = parser.parse('%x = alloca i32');\n\n- Rust\n - Cargo.toml:\n - tree-sitter-llvm = \"1.1.0\"\n - Usage:\n - let mut parser = tree_sitter::Parser::new();\n - let language = tree_sitter_llvm::LANGUAGE;\n - parser.set_language(&language.into()).unwrap();\n\n- Python (tree-sitter >= 0.25)\n - pip install tree-sitter-llvm\n - Usage:\n - from tree_sitter import Language, Parser\n - import tree_sitter_llvm\n - parser = Parser()\n - parser.set_language(Language(tree_sitter_llvm.language()))\n\n- C\n - Include bindings/c/tree-sitter-llvm.h and link the generated parser in src/.\n - The language symbol is: const TSLanguage *tree_sitter_llvm(void);\n\n- Go\n - The binding is in bindings/go. Example with go-tree-sitter:\n - import (\n - \"github.com/tree-sitter/go-tree-sitter\"\n - llvm \"path/to/this/repo/bindings/go\"\n - )\n - parser := sitter.NewParser()\n - parser.SetLanguage(sitter.NewLanguage(llvm.Language()))\n\n- Swift (SwiftPM)\n - Add this repository as a dependency and use TreeSitterLlvm target.\n - Example:\n - import SwiftTreeSitter\n - import TreeSitterLlvm\n - let parser = Parser()\n - let language = Language(language: tree_sitter_llvm())\n - try parser.setLanguage(language)\n\nStatus and scope\n- Language name: llvm (as used by grammar.js)\n- Targets LLVM IR textual format (.ll). MIR is out of scope.\n- Grammar rules are modeled after LLVM's LLParser constructs (target definitions, declarations/definitions, instructions incl. alloca, getelementptr, phi, cmpxchg, atomicrmw, br; comdat; metadata; summaries; attributes; etc.).\n\nQueries\n- queries/highlights.scm contains basic highlighting captures for common editors that consume Tree-sitter queries.\n\nDevelopment\n- Prerequisites: Node.js, npm, and tree-sitter-cli (npx tree-sitter works via devDependencies)\n- Generate/rebuild parser C sources:\n - npx tree-sitter generate\n- Run grammar tests (corpus under test/corpus):\n - npx tree-sitter test\n- Rust tests (ensures the language loads):\n - cargo test\n- Python tests:\n - pip install -e .[core]\n - pytest bindings/python/tests\n- Swift tests:\n - swift test\n\nExample\n- See example/ and test/corpus for sample LLVM IR snippets and expected parses.\n\nContributing\n- Issues and PRs are welcome. Please run tree-sitter tests and format code before submitting.\n\nLicense\n- MIT (see LICENSE)\n\nAcknowledgements\n- Based on LLVM's existing bindings and textual IR structure: https://github.com/llvm/llvm-project/blob/main/llvm/utils/\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Llvm grammar for tree-sitter",
"version": "1.1.0",
"project_urls": {
"Homepage": "https://github.com/tree-sitter/tree-sitter-llvm"
},
"split_keywords": [
"incremental",
" parsing",
" tree-sitter",
" llvm"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "6282a5d8aaf650339f196d85b5ed6e8951bb2b96d3013016bc0339835ff820df",
"md5": "3ea3cf224312c7ee2640360d45c07f94",
"sha256": "ee10b08af8c30ec199ffcde6934885f9b375d7e26b0a5364e61e122170ce5701"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-macosx_10_9_x86_64.whl",
"has_sig": false,
"md5_digest": "3ea3cf224312c7ee2640360d45c07f94",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 146294,
"upload_time": "2025-08-20T19:38:22",
"upload_time_iso_8601": "2025-08-20T19:38:22.889751Z",
"url": "https://files.pythonhosted.org/packages/62/82/a5d8aaf650339f196d85b5ed6e8951bb2b96d3013016bc0339835ff820df/tree_sitter_llvm-1.1.0-cp38-abi3-macosx_10_9_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "f07f1d08a444dc7257659e83714b93706b2f5fc886339b7dff6f32df0d87ac81",
"md5": "c4fae19bb927e77eda7c021be7fbbf60",
"sha256": "beb184ad2e7f78e0df79c59ce6d2ac2baf3f0aaaf88abcc4726b37344bd50c3d"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "c4fae19bb927e77eda7c021be7fbbf60",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 160129,
"upload_time": "2025-08-20T19:38:24",
"upload_time_iso_8601": "2025-08-20T19:38:24.376924Z",
"url": "https://files.pythonhosted.org/packages/f0/7f/1d08a444dc7257659e83714b93706b2f5fc886339b7dff6f32df0d87ac81/tree_sitter_llvm-1.1.0-cp38-abi3-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "dbb2b19fa2f2fa73dbab072237401685ce28a7d78a7d8999f1ba7686631770b9",
"md5": "68bf8015fbb52429d88d74c17a95e4c8",
"sha256": "68ece3c0c6cd6f7f3bf259e5d5ff5e47545e878dd8f49458797e708cab22bd39"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-manylinux1_x86_64.manylinux_2_28_x86_64.manylinux_2_5_x86_64.whl",
"has_sig": false,
"md5_digest": "68bf8015fbb52429d88d74c17a95e4c8",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 166301,
"upload_time": "2025-08-20T19:38:25",
"upload_time_iso_8601": "2025-08-20T19:38:25.446051Z",
"url": "https://files.pythonhosted.org/packages/db/b2/b19fa2f2fa73dbab072237401685ce28a7d78a7d8999f1ba7686631770b9/tree_sitter_llvm-1.1.0-cp38-abi3-manylinux1_x86_64.manylinux_2_28_x86_64.manylinux_2_5_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "edfdddbac1ac922b488712061894cb77f9c34477b65880b39265a61175c8a772",
"md5": "976c4fc7b2fbb176d9cd2b21de0632bd",
"sha256": "d81b31b4d2d476db6fa1d92b890564195552673a59c096f590fefc088ceb5885"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl",
"has_sig": false,
"md5_digest": "976c4fc7b2fbb176d9cd2b21de0632bd",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 162408,
"upload_time": "2025-08-20T19:38:26",
"upload_time_iso_8601": "2025-08-20T19:38:26.527244Z",
"url": "https://files.pythonhosted.org/packages/ed/fd/ddbac1ac922b488712061894cb77f9c34477b65880b39265a61175c8a772/tree_sitter_llvm-1.1.0-cp38-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "86ed34fa3e32cf0f262b461d6a3030b42b8eff49fb42847311fadff15c31210f",
"md5": "7abc9a5d49cf8d7fc42229d38102d479",
"sha256": "8045bbe6474c88e6e2e8217a636c8cda0c48d56c9a35af446e27325e9b970585"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-musllinux_1_2_x86_64.whl",
"has_sig": false,
"md5_digest": "7abc9a5d49cf8d7fc42229d38102d479",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 163215,
"upload_time": "2025-08-20T19:38:27",
"upload_time_iso_8601": "2025-08-20T19:38:27.414060Z",
"url": "https://files.pythonhosted.org/packages/86/ed/34fa3e32cf0f262b461d6a3030b42b8eff49fb42847311fadff15c31210f/tree_sitter_llvm-1.1.0-cp38-abi3-musllinux_1_2_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "b4c9084dbcab733bdf0c3d14688decd578a02420ab3edab19c92419173ee5b57",
"md5": "34a691a3195bc34e47447e62dbb21875",
"sha256": "cf8b35a7e7025b2cb8902d9ad8ac6cf1b5043648dd33409ad1937ea42f6b8b28"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-win_amd64.whl",
"has_sig": false,
"md5_digest": "34a691a3195bc34e47447e62dbb21875",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 153552,
"upload_time": "2025-08-20T19:38:28",
"upload_time_iso_8601": "2025-08-20T19:38:28.314754Z",
"url": "https://files.pythonhosted.org/packages/b4/c9/084dbcab733bdf0c3d14688decd578a02420ab3edab19c92419173ee5b57/tree_sitter_llvm-1.1.0-cp38-abi3-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "1485377f3a9255e05a248b3806628285e440e5d20e854f51f427d621b0b4ad6a",
"md5": "c50f3659c20a20cccaa4b529a5c31f0d",
"sha256": "dcbaee9705715fd18f10612c6564e0acf8ab32c51828730b5d6161ab2f3725e3"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0-cp38-abi3-win_arm64.whl",
"has_sig": false,
"md5_digest": "c50f3659c20a20cccaa4b529a5c31f0d",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.10",
"size": 145935,
"upload_time": "2025-08-20T19:38:29",
"upload_time_iso_8601": "2025-08-20T19:38:29.521757Z",
"url": "https://files.pythonhosted.org/packages/14/85/377f3a9255e05a248b3806628285e440e5d20e854f51f427d621b0b4ad6a/tree_sitter_llvm-1.1.0-cp38-abi3-win_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "d1502e43a514dbaa5c525d419b22cadaa89b1665590d6bcf7fbb512472aa4002",
"md5": "10cbee3fa8fc71f67e8f84ffddcaab09",
"sha256": "0b51d82413afd1738e75e2d766abc78ecf63ed77696c4dbd6d3d954881a9b1b1"
},
"downloads": -1,
"filename": "tree_sitter_llvm-1.1.0.tar.gz",
"has_sig": false,
"md5_digest": "10cbee3fa8fc71f67e8f84ffddcaab09",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.10",
"size": 404657,
"upload_time": "2025-08-20T19:38:30",
"upload_time_iso_8601": "2025-08-20T19:38:30.771412Z",
"url": "https://files.pythonhosted.org/packages/d1/50/2e43a514dbaa5c525d419b22cadaa89b1665590d6bcf7fbb512472aa4002/tree_sitter_llvm-1.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-08-20 19:38:30",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "tree-sitter",
"github_project": "tree-sitter-llvm",
"github_not_found": true,
"lcname": "tree-sitter-llvm"
}