- 支持亿行代码、多仓库、复杂表达式高速检索和实时查询
- 超快的建索引速度:基于 Unicode 三元组(trigram)的内存索引,每分钟可索引超过 1000 万行代码
- 超快的搜索速度:多数 query 百毫秒内返回,优化了正则表达式查询,和竞品相比有 10 倍速度提升
- 支持丰富的搜索语言,可以基于正则表达式、与或非逻辑运算、文件名、仓库名等搜索
- 支持上百种编程语言的检测和查询
- 支持丰富的索引文件过滤选项
- 支持基于 ctags 的符号(变量、函数、类名等)查询
- 支持可扩展的访问权限控制
- 提供了 KWS 基于网页的搜索服务
- 提供了 KLS 命令行下的代码搜索瑞士军刀程序
- 采用对商业应用友好的 Apache License v2 发布
go get -u -v github.com/huichen/kunlun
先看一个例子(来自cmd/examples/simplest_example.go)
package main
import (
"flag"
"github.com/huichen/kunlun/pkg/engine"
"github.com/huichen/kunlun/pkg/types"
)
var (
dir = flag.String("d", "/usr/local/include", "索引这个文件夹下的所有文件")
query = flag.String("q", "gcc", "搜索表达式")
)
func main() {
flag.Parse()
// 创建引擎
kgn, _ := engine.NewKunlunEngine(nil) // 使用默认选项
// 构建索引
kgn.IndexDir(*dir)
kgn.Finish() // 开始搜索前必须先调用该函数
// 检索
request := types.SearchRequest{
Query: *query,
ReturnLineContent: true,
NumContextLines: 2}
resp, _ := kgn.Search(request)
// 打印输出
kgn.PrettyPrintSearchResponse(resp, true, true)
}
引擎提供了一系列文件遍历选项、索引选项和搜索选项,可以在引擎启动时通过参数传入。
如果你想阅读昆仑的代码,可以先看看这篇文档。