Elixir流程:管道多个参数

时间:2017-10-17 00:46:19

标签: elixir genstage

我试图写一个看似如此的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行。我在这做错了什么?感觉就像我没有以某种方式返回正确的价值......

1 个答案:

答案 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