这应该很简单,但我不知道它.我在
Linux下拥有超过4GB的大型
代码库.在构建期间
生成一些头
文件和xml
文件(使用gnu make).如果重要,则头
文件是基于xml
文件生成的.
我想在头文件中搜索一个关键字,该关键字是在时间实例(它是我的开始编译时间)之后的最后修改,以及类似的xml文件,但是单独的grep查询.
如果我在所有可能的头文件或xml文件上运行它,则需要花费很多时间.只有那些自动生成的.此外,搜索必须是递归的,因为有许多目录和子目录.
要在当前目录及其子目录中比some_file更新的所有
文件中以递归方式查找“模式”:
find -newer some_file -type f -exec grep 'pattern' {} +
您可以直接以date -d格式指定时间戳,并使用其他查找测试,例如-name,-mmin.
如果find太慢,您的构建系统也可能生成文件列表.
可以使用更具体的工具,例如ack
,etags,GCCSense
而不是grep.