From: Steven Barth Date: Sat, 29 Nov 2008 21:58:58 +0000 (+0000) Subject: IPKG würgaround X-Git-Tag: 0.8.2~15 X-Git-Url: http://207.154.207.93/?a=commitdiff_plain;h=285b78a4b47766143f2cc6bf47a46af53c4b05b3;p=project%2Fluci.git IPKG würgaround --- diff --git a/libs/ipkg/luasrc/model/ipkg.lua b/libs/ipkg/luasrc/model/ipkg.lua index b06834510..3df4bf945 100644 --- a/libs/ipkg/luasrc/model/ipkg.lua +++ b/libs/ipkg/luasrc/model/ipkg.lua @@ -14,6 +14,7 @@ $Id$ ]]-- local os = require "os" +local io = require "io" local util = require "luci.util" local type = type @@ -83,7 +84,15 @@ local function _lookup(act, pkg) cmd = cmd .. " '" .. pkg:gsub("'", "") .. "'" end - return _parselist(util.execi(cmd .. " 2>/dev/null")) + -- IPKG sometimes kills the whole machine because it sucks + -- Therefore we have to use a sucky approach too and use + -- tmpfiles instead of directly reading the output + local tmpfile = os.tmpname() + os.execute(cmd .. (" >%s 2>/dev/null" % tmpfile)) + + local data = _parselist(io.lines(tmpfile)) + os.remove(tmpfile) + return data end