Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/swiftlang/indexstore-db
Index database library for use with sourcekit-lsp
https://github.com/swiftlang/indexstore-db
Last synced: about 21 hours ago
JSON representation
Index database library for use with sourcekit-lsp
- Host: GitHub
- URL: https://github.com/swiftlang/indexstore-db
- Owner: swiftlang
- License: apache-2.0
- Created: 2018-10-26T03:42:22.000Z (about 6 years ago)
- Default Branch: main
- Last Pushed: 2024-11-11T21:37:09.000Z (2 days ago)
- Last Synced: 2024-11-11T22:29:42.159Z (2 days ago)
- Language: C++
- Size: 1.62 MB
- Stars: 331
- Watchers: 129
- Forks: 71
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
# IndexStoreDB
IndexStoreDB is a source code indexing library. It provides a composable and efficient query API for looking up source code symbols, symbol occurrences, and relations. IndexStoreDB uses the libIndexStore library, which lives in [swiftlang/llvm-project](https://github.com/swiftlang/llvm-project/tree/apple/main/clang/tools/IndexStore), for reading raw index data. Raw index data can be produced by compilers such as Apple Clang and Swift using the `-index-store-path` option. IndexStoreDB enables efficiently querying this data by maintaining acceleration tables in a key-value database built with [LMDB](http://www.lmdb.tech/).
IndexStoreDB's data model is derived from libIndexStore. For more information about libIndexStore, and producing raw indexing data, see the [Indexing While Building](https://docs.google.com/document/d/1cH2sTpgSnJZCkZtJl1aY-rzy4uGPcrI-6RrUpdATO2Q/) whitepaper.
## Building IndexStoreDB
IndexStoreDB is built using the [Swift Package Manager](https://github.com/swiftlang/swift-package-manager).
For a standard debug build and test:
```sh
$ swift build
$ swift test
```### Building on Linux
The C++ code in the index requires `libdispatch`, but unlike Swift code, it cannot find it automatically on Linux. You can work around this by adding a search path manually.
```sh
$ swift build -Xcxx -I/usr/lib/swift -Xcxx -I/usr/lib/swift/Block
```## Some Example Users
[**Pecker**](https://github.com/woshiccm/Pecker): a tool to detect unused code based on [SwiftSyntax](https://github.com/swiftlang/swift-syntax.git) and [IndexStoreDB](https://github.com/swiftlang/indexstore-db.git).
## Contributing to Swift
Contributions to indexstore-db are welcomed and encouraged! Please see the
[Contributing to Swift guide](https://swift.org/contributing/).Before submitting the pull request, please make sure you have [tested your
changes](https://github.com/apple/swift/blob/main/docs/ContinuousIntegration.md)
and that they follow the Swift project [guidelines for contributing
code](https://swift.org/contributing/#contributing-code).To be a truly great community, [Swift.org](https://swift.org/) needs to welcome
developers from all walks of life, with different backgrounds, and with a wide
range of experience. A diverse and friendly community will have more great
ideas, more unique perspectives, and produce more great code. We will work
diligently to make the Swift community welcoming to everyone.To give clarity of what is expected of our members, Swift has adopted the
code of conduct defined by the Contributor Covenant. This document is used
across many open source communities, and we think it articulates our values
well. For more, see the [Code of Conduct](https://swift.org/code-of-conduct/).## Development
For more information about developing IndexStoreDB, see [Development](Documentation/Development.md).