IPKG würgaround
authorSteven Barth <steven@midlink.org>
Sat, 29 Nov 2008 21:58:58 +0000 (21:58 +0000)
committerSteven Barth <steven@midlink.org>
Sat, 29 Nov 2008 21:58:58 +0000 (21:58 +0000)
libs/ipkg/luasrc/model/ipkg.lua

index b06834510abb4ffb317ad2591206b06592385aae..3df4bf9451b4a170154728e1e9ca906f4f327c2e 100644 (file)
@@ -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