我正在使用Sinatra来监控服务器。我需要读取主文件夹中的文件夹列表,以及每个文件夹中meta.xml的内容。这是所需的输出:
<folders>
<folder 1>
<meta.xml content>
<folder 2>
<meta.xml content>
<\folders>
这是我目前的代码:
require 'sinatra'
require 'json'
require 'haml'
get '/processed' do
status 200
meeting_dir="/home/default"
Dir.entries(meeting_dir)
end
我对Sinatra打印get块中所有变量的值感到困惑。如果我想编写一个子函数getxml来生成xml,我应该把它放在哪里?
答案 0 :(得分:2)
require 'sinatra'
require 'json'
require 'haml'
helpers do
def get_xml( *args )
# your code here…
end
end
get '/processed' do
# getxml is available here
status 200
meeting_dir="/home/default"
Dir.entries(meeting_dir)
end
现在,我假设您希望输出为XML,因此该路由不起作用,您将获得最后一个表达式的评估,该表达式当前为Dir.entries(meeting_dir)
。
设置view,然后使用Haml's list_of
helper我们就可以输出值列表了:
#views/contents.haml
<folders>
= list_of(@metas) do |meta|
= "<#{meta.name}>"
= meta.content
= "</#{meta.name}>"
<\folders>
现在你需要一个@metas
对象:
helpers do
def get_xml( meeting_dir )
dirs = Dir.entries(meeting_dir).reject{|e| e.start_with? "." }
meta = Struct.new(:name, :content)
dirs.each_with_object([]) do |d,metas|
meta.name = d # it's up to you whether you
# want the absolute or relative path here
meta.content = File.read File.expand_path(File.join d, "meta.xml")
metas << meta
end
# the return value of each_with_object
# is the object, so no need for a return expression
end
end
get '/processed', :provides => :xml do
# status 200 <- this is not needed
meeting_dir="/home/default"
@metas = get_xml(meeting_dir)
haml :contents, :layout => false
end
另请查看http://www.sinatrarb.com/intro.html#Conditions和http://www.sinatrarb.com/intro.html#Named%20Templates。这应该会给你一些事情。