diff options
author | Daniel Silverstone <dsilvers@digital-scurf.org> | 2012-09-08 21:27:57 +0100 |
---|---|---|
committer | Daniel Silverstone <dsilvers@digital-scurf.org> | 2012-09-08 21:27:57 +0100 |
commit | 02c686dcc0b70ad66f55c2873f083e68eab0b089 (patch) | |
tree | a98e50d7de11d1cb4c53bcc4cd68380a153301b7 /lib | |
parent | f0613b4cc5763d3de7dd65b89e6b4f9d3c6e6190 (diff) | |
download | gall-02c686dcc0b70ad66f55c2873f083e68eab0b089.tar.gz |
GALL: Initial git2 support, saves a litle under 30% of git spawns in the test suite
Diffstat (limited to 'lib')
-rw-r--r-- | lib/gall/object.lua | 24 | ||||
-rw-r--r-- | lib/gall/repository.lua | 9 |
2 files changed, 30 insertions, 3 deletions
diff --git a/lib/gall/object.lua b/lib/gall/object.lua index 2772587..bedc6f1 100644 --- a/lib/gall/object.lua +++ b/lib/gall/object.lua @@ -12,6 +12,7 @@ local tree = require "gall.tree" local tag = require "gall.tag" local repos = setmetatable({}, {__mode="k"}) +local blobs = setmetatable({}, {__mode="k"}) local known_types = { blob = true, commit = true, tree = true, tag = true, @@ -19,12 +20,25 @@ local known_types = { local function _objectindex(obj, field) local ok, ret + local blob = blobs[obj] if field == "type" then - ok, ret = repos[obj]:gather("cat-file", "-t", obj.sha) + if blob then + ok, ret = 0, blob:type() + else + ok, ret = repos[obj]:gather("cat-file", "-t", obj.sha) + end elseif field == "size" then - ok, ret = repos[obj]:gather("cat-file", "-s", obj.sha) + if blob then + ok, ret = 0, blob:size() + else + ok, ret = repos[obj]:gather("cat-file", "-s", obj.sha) + end elseif field == "raw" then - ok, ret = repos[obj]:rawgather("cat-file", (obj.type == "tag" and "tag" or "-p"), obj.sha) + if blob and obj.type ~= "tree" then + ok, ret = 0, blob:data() + else + ok, ret = repos[obj]:rawgather("cat-file", (obj.type == "tag" and "tag" or "-p"), obj.sha) + end elseif field == "content" then assert(known_types[obj.type], "Unknown type: " .. obj.type) if obj.type == "blob" then @@ -61,6 +75,10 @@ local objectmeta = { local function _new(repo, sha) local ret = setmetatable({sha=sha}, objectmeta) repos[ret] = repo + if ll.git2 then + local oid = ll.git2.OID.hex(sha) + blobs[ret] = repo.git2.odb:read(oid) + end return ret end diff --git a/lib/gall/repository.lua b/lib/gall/repository.lua index 5c157d8..32be33c 100644 --- a/lib/gall/repository.lua +++ b/lib/gall/repository.lua @@ -263,6 +263,15 @@ local function _new(path) retrepo.work = workpath retrepo.HEAD = symref + if ll.git2 then + local git2, msg = ll.git2.Repository(retrepo.path) + if not git2 then + return nil, msg + end + local odb = git2:odb() + retrepo.git2 = { repo = git2, odb = odb } + end + return setmetatable(retrepo, repomt) end |