perl – 如何处理Template Toolkit中的模板依赖项?
发布时间:2020-12-15 21:44:53 所属栏目:大数据 来源:网络整理
导读:我的静态网页是由一大堆模板构建的,这些模板是使用Template Toolkit的“import”和“include”包含在内的,所以page.html看起来像这样: [% INCLUDE top %][% IMPORT middle %] 然后top可能包含更多文件. 我有很多这些文件,他们必须运行以创建各种语言的网页(
我的静态网页是由一大堆模板构建的,这些模板是使用Template Toolkit的“import”和“include”包含在内的,所以page.html看起来像这样:
[% INCLUDE top %] [% IMPORT middle %] 然后top可能包含更多文件. 我有很多这些文件,他们必须运行以创建各种语言的网页(英语,法语等,而不是计算机语言).这是一个非常复杂的过程,当一个文件被更新时,我希望能够使用makefile或类似的东西自动重新制作必要的文件. 有没有像 或者有更好的方法来自动化这个过程吗? 解决方法Template Toolkit 确实带有自己的命令行脚本,名为
ttree ,用于构建TT网站ala make.
这是我在Mac上的TT网站项目中经常使用的ttree.cfg文件: # directories src = ./src lib = ./lib lib = ./content dest = ./html # pre process these site file pre_process = site.tt # copy these files copy = .(png|gif|jpg)$ # ignore following ignore = b(CVS|RCS)b ignore = ^# ignore = ^.DS_Store$ ignore = ^._ # other options verbose recurse 只运行ttree -f ttree.cfg将在dest中重建站点,只更新在源(在src中)或在我的库(在lib中)中更改的内容. 对于更精细的依赖项,请查看 更新 – 这是我通过子类化 { package MyProvider; use base 'Template::Provider'; # see _dump_cache in Template::Provider sub _dump_deps { my $self = shift; if (my $node = $self->{ HEAD }) { while ($node) { my ($prev,$name,$data,$load,$next) = @$node; say {*STDERR} "$name called from " . $data->{caller} if exists $data->{caller}; $node = $node->[ 4 ]; } } } } use Template; my $provider = MyProvider->new; my $tt = Template->new({ LOAD_TEMPLATES => $provider,}); $tt->process( 'root.tt',{} ) or die $tt->error; $provider->_dump_deps; 上面的代码显示了所有被调用的依赖项(通过INCLUDE,INSERT,PROCESS和WRAPPER)以及从整个root.tt树中调用的位置.因此,您可以构建一个ttree依赖文件. / I3az / (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |