Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/katyo/kquery
Deep diving tool for Linux kernel sources.
https://github.com/katyo/kquery
Last synced: 16 days ago
JSON representation
Deep diving tool for Linux kernel sources.
- Host: GitHub
- URL: https://github.com/katyo/kquery
- Owner: katyo
- License: mit
- Created: 2022-06-21T04:26:38.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-03-16T06:11:37.000Z (almost 2 years ago)
- Last Synced: 2024-10-30T16:12:09.298Z (2 months ago)
- Language: Rust
- Size: 64.5 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Linux source querying tool
[![github](https://img.shields.io/badge/github-katyo/kquery-8da0cb.svg?style=for-the-badge&logo=github)](https://github.com/katyo/kquery)
[![crates](https://img.shields.io/crates/v/kquery.svg?style=for-the-badge&color=fc8d62&logo=rust)](https://crates.io/crates/kquery)
[![docs](https://img.shields.io/badge/docs.rs-kquery-66c2a5?style=for-the-badge&logo=)](https://docs.rs/kquery)
[![status](https://img.shields.io/github/workflow/status/katyo/kquery/Rust?style=for-the-badge&logo=github-actions&logoColor=white)](https://github.com/katyo/kquery/actions?query=workflow%3ARust)This is blazing fast querying tool for deep dive into Linux source code.
Development in early stage so things may work wrong or does not work at all.Currently it consists of querying library and simple command-line tool.
## Command-line usage
Create or update index first:
```sh
$ cd path/to/linux/sources
$ kquery index
Found 21964 sources, 10521 compatible strings, 12519 configuration options
```List all found sources:
```sh
$ kquery sources
```List sources which match some pattern:
```sh
$ kquery sources drivers/**/arm/**
```List all found compatible strings:
```sh
$ kquery compats
```List compatible strings which match some pattern:
```sh
$ kquery compats arm,*
```List all found configuration options:
```sh
$ kquery configs
```List configuration options which match some pattern:
```sh
$ kquery compats ARM_*
```Query source info which has compatible string:
```sh
$ kquery compat arm,smmu-v2
```Query sources info related to configuration option:
```sh
$ kquery config ARM_SMMU
```Query source info by path:
```sh
$ kquery source drivers/iommu/arm/arm-smmu/arm-smmu.c
```## Library usage
```no_run
use kquery::{FileMgr, MetaData, Result};#[tokio::main]
async fn main() -> Result<()> {
// Create file manager instance using path to sources
let filemgr = FileMgr::new("path/to/sources").await?;// Create index from Linux source tree
let metadata = MetaData::from_kbuild(&filemgr).await?;// Store metadata into file in source tree
metadata.to_file("path/to/metadata.json", None).await?;// Load metadata from cache file in source tree
let metadata = MetaData::from_file("path/to/metadata.json", None).await?;Ok(())
}
```