我试图写一个看似如此的Flow:
def perform(id) do
id
|> Flow.from_stage(max_demand: 10)
|> Flow.map(&download(&1))
|> Flow.map(&process(&1))
|> Flow.each(&cleanup(&1, &2))
|> Flow.each(&respond(&1, &2))
|> Flow.run
end
模块中的其他功能如下所示:
def download(id) do
Service.get_images(id)
id
end
def process(id) do
%Result{out: sys_out, status: _} = Porcelain.exec("osascript",
["#{File.cwd!}/lib/script/test", "#{id}", "#{Application.get_env(:app, :server_env)}"]
)
{id, sys_out}
end
def cleanup(id, files) do
for file <- String.split(files, " ") do
System.cmd("exiftool", ["#{File.cwd!}/#{file}"])
end
{id, files}
end
def respond(id, files) do
files = String.split(files, " ")
System.cmd("curl", [" -d 'dowhatever=#{files[0]}&else=#{files[1]}' -k #{Application.get_env(:app, :api)}what/#{id}/notify"])
:ok
end
但我一直收到这个错误:
** (FunctionClauseError) no function clause matching in Flow.each/2
...
(app) lib/app/processor.ex:18: App.Processor.perform/1
第18行是&cleanup/2
行。我在这做错了什么?感觉就像我没有以某种方式返回正确的价值......
答案 0 :(得分:2)
process/1
会返回元组{id, sys_out}
,而cleanup/2
则会声明 2 。
迭代元组列表意味着迭代器必须是arity 1.你应该在 cleanup/1
内分解你的元组:
- def cleanup(id, files) do
+ def cleanup({id, files}) do
并称之为:
Flow.each(&cleanup/1)
这同样适用于后续respond
。