【OpenGrok代码搜索引擎】四、OpenGrok使用指南

【OpenGrok代码搜索引擎】四、OpenGrok使用指南三、智能窗口四、差异跳转

大家好,又见面了,我是你们的朋友全栈君。

一、使用案例

1.1 查询函数”start_kernel”的定义

def:start_kernel

案例如下:

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

1.2 查询路径”sound/core”路径下使用函数”sprintf”

refs:sprintf  path:sound\/core\/

案例如下:

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

1.3 查询变量”cmdline”赋值

“command_line =”

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

1.4 查询Makefiles,二进制文件“init-mm.o”构建信息 

“init-mm.o” path:Makefile

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

1.5 查询字符“command line” 

“command line” 

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

1.6 使用通配符查询字符串”strart_*”

start_*

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

 1.7 条件查询文件

如从路径/usr/perl查询perl文件,但不查询路径为”/usr/bin/perl”下的perl文件。

-“arm/lib/Makefile” +“lib/Makefile”

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

 【OpenGrok代码搜索引擎】四、OpenGrok使用指南

 1.8 查找所有包含”. c”的文件

“. c”

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

 1.9 查找以“ma”开头的文件

path:/ma[a-zA-Z]*/

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

 1.10 查找所有c文件中的main函数 

main type:c

【OpenGrok代码搜索引擎】四、OpenGrok使用指南

二、使用技巧

一次查询就是一系列的子句组合,一个子句的前缀可能包括如下:

  • “+”表示查询子句内容是必须的;形如+“clause”
  • “-”表示查询子句内容是忽略的;形如-“clause”
  • “:”表示查询子句针对一个域的搜索;形如文件类型type:c

一个子句也有可能是下面这些形式:

  • 一个词语,表示查询所有包含该词语的文档;形如“term”
  • 一个词组;表示查询所有包含该词组的文档,形如“hello term”
  • 嵌套或组合查询;如通过“+”“-”的组合或者形如”term1″”term2″…
  • 逻辑运算查询;opengrok支持AND(&&),”+”,OR(||),NOT(!),”-“.注意,这些运算符必须要大写。

一个字句也支持诸如正则表达式,通配符,模糊查询,近似查询,范围搜索等。

  • 正则表达式;形如/[mb]an/,将会查询形如man或ban的字符等。
  • 通配符;形如”te?t”,将会擦汗寻到text,test等。
  • 模糊查询;使用“~”进行模糊或近似查询,例如res~;
  • 范围查询;

2.1 特殊字符

opengrok在查询语法中支持转义字符;这些特殊字符如“+ – && || ! ( ) { } [ ] ^ ” ~ * ? : \ /”。转义这些字符需要使用反斜杠\。例如搜索(1+1):2,完整的搜索字符串如下:

\(1\+\)\:2

需要特别注意的是索引字符主要是数字,字母和下划线,一个字符是无法进行索引。

2.2 域

2.2.1 full

全量搜索,包括字符串,数字,标识符等。

2.2.2 defs

定义搜索,主要对变量,函数进行查询等。 

2.2.3 refs

引用搜索,主要指符号如函数,类,变量。

2.2.4 path

资源文件路径搜索,如”src/mypath”。

2.2.5 hist

历史记录,日志注释搜索

2.26 type

类型查搜索,指定查询的文件,其中ada=Ada, asm=Asm, bzip2=Bzip(2), c=C, clojure=Clojure, csharp=C#, cxx=C++, eiffel=Eiffel, elf=ELF, erlang=Erlang, file=Image file, fortran=Fortran, golang=Golang, gzip=GZIP, haskell=Haskell, hcl=HCL, jar=Jar, java=Java, javaclass=Java class, javascript=JavaScript, json=Json, kotlin=Kotlin, lisp=Lisp, lua=Lua, mandoc=Manual pages, pascal=Pascal, perl=Perl, php=PHP, plain=Plain Text, plsql=PL/SQL, powershell=PowerShell script, python=Python, r=R, ruby=Ruby, rust=Rust, scala=Scala, sh=Shell script, sql=SQL, swift=Swift, tar=Tar, tcl=Tcl, terraform=Terraform, troff=Troff, typescript=TypeScript, uuencode=UUEncoded, vb=Visual Basic, verilog=Verilog, xml=XML, zip=Zip。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/132543.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • GoogleGoogle搜索解析

    GoogleGoogle搜索解析GoogleGoogle搜索解析是一个类似Google趋势SEO在线keyword工具。它的正式口号提出“在搜索些什么”。利用Google搜索解析,能够比較特定区域、类别、时间范围以及搜索资源之间的搜索量模式,这点也是Google搜索解析相比仅仅能提供基本信息的Googlekeyword工具。Google趋势。Google站点管理员工具以及GoogleAnalytic…

  • HTML制作网页_手机制作html网页

    HTML制作网页_手机制作html网页一、步骤1、HTML1、新建文本文档2、改后缀名.html3、以记事本方式打开并编写代码4、保存,关闭后,直接双击打开网页

  • js获取当前日期时间「建议收藏」

    js获取当前日期时间「建议收藏」functionThistime(){//当前日期vardate=newDate();varyear=date.getFullYear();varmonth=date.getMonth()+1;varday=date.getDate();varmytime=date.toLocaleTimeString();//获取当前时间//myDate.toLocaleString()

    2022年10月27日
  • LM优化算法_lm算法内参计算

    LM优化算法_lm算法内参计算LM算法理论知识梯度下降高斯牛顿Levenberg–Marquardt算法框架算法的整体流程求解器update流程说明算法实现头文件cpp算法调用LM优化算法,是一种非线性优化算法,其可以看作是梯度下降和高斯牛顿法的结合。综合了梯度下降对初值不敏感和高斯牛顿在最优值附近收敛速度快的特点。本人非数学专业,且对算法理解可能不到位,详细的算法推导及各个优化算法之间的关系,非常推荐看**《METHODSFORNON-LINEARLEASTSQUARESPROBLEMS》**,其介绍更详细也更专业。

  • 多少行代码可以申请软件著作权_python申请软件著作权

    多少行代码可以申请软件著作权_python申请软件著作权在申请软件专利或著作权时,如何快速统计源码行数。其实我们可以利用vs2010的文件搜索功能结合正则表达式,来遍历所有文件得出总行数.

  • FCoin交易所API文档

    本文介绍FCoinAPI介绍通过了解以下信息,您可以方便的使用FCoin提供的API来接入FCoin交易平台。认证执行下面的代码进行用户验证:importfcoinapi=fcoin.authorize(‘key’,’secret’,timestamp)FCoin使用APIkey和APIsecret进行验证,请访问设置中心,并…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号