首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >是否有基于inotify类机制的构建工具

是否有基于inotify类机制的构建工具
EN

Stack Overflow用户
提问于 2011-02-25 04:35:32
回答 5查看 2.6K关注 0票数 14

在使用普通老式make的相对较大的项目中,即使在没有任何变化的情况下构建项目也只需要几十秒。特别是在许多make -C执行的情况下,这会产生新的进程开销。

这个问题的明显解决方案是基于操作系统的inotify-like功能的构建工具。它将在某个文件发生更改时进行查找,并根据该列表单独编译该文件。

外面有这样的机器吗?开源项目的加分。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2011-03-02 19:26:10

你是说像Tup那样

在主页上:

Tup是基于文件的构建系统-它输入文件更改列表和有向无环图( DAG ),然后处理DAG以执行更新从属文件所需的相应命令。DAG存储在SQLite数据库中。默认情况下,文件更改列表是通过扫描文件系统生成的。或者,也可以通过运行包含的文件监视守护程序预先提供该列表。

票数 14
EN

Stack Overflow用户

发布于 2011-03-02 20:05:04

我想知道是不是stat()文件花了这么长时间。为了检查这一点,我编写了一个小systemtap脚本来测量访问stat()文件所需的时间:

代码语言:javascript
复制
# call-counts.stp

global calls, times

probe kernel.function(@1) {
    times[probefunc()] = gettimeofday_ns()
}

probe kernel.function(@1).return {
    now = gettimeofday_ns()
    delta = now - times[probefunc()]
    calls[probefunc()] <<< delta
}

然后像这样使用它:

代码语言:javascript
复制
$ stap -c "make -rC ~/src/prj -j8 -k" ~/tmp/count-calls.stp sys_newstat
make: Entering directory `/home/user/src/prj'
make: Nothing to be done for `all'.
make: Leaving directory `/home/user/src/prj'
calls["sys_newstat"] @count=8318 @min=684 @max=910667 @sum=26952500 @avg=3240

我运行它的项目有4593个源文件,make需要大约27毫秒(上面是26952500nsec)来统计所有文件以及相应的.d文件。不过,我使用的是非递归make。

票数 4
EN

Stack Overflow用户

发布于 2014-06-24 07:44:38

如果你使用的是OSX,你可以使用fswatch

https://github.com/alandipert/fswatch

下面介绍如何使用fswatch查看文件的更改,如果检测到任何更改,则运行make

代码语言:javascript
复制
fswatch -o anyFile | xargs -n1 -I{} make

您可以从makefile内部运行fswatch,如下所示:

代码语言:javascript
复制
watch: $(FILE)
  fswatch -o $^ | xargs -n1 -I{} make

(当然,$(FILE)是在makefile中定义的。)make现在可以监视文件中的更改,如下所示:

代码语言:javascript
复制
> make watch

你可以看另一个这样的文件:

代码语言:javascript
复制
> make watch anotherFile
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5110114

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档