在我的程序中,我使用的是nodegit。我可以使用nodegit列出提交:
var nodegit = require("nodegit");
var path = require("path");
var fs = require("fs");
var shas = [];
var names= [];
var mess= [];
var sums= [];
var time =[];
let promise = new Promise(function(resolve, reject) {
nodegit.Repository.open(path.resolve(__dirname, "repo_dir/.git"))
.then(function(repo) {
return repo.getMasterCommit();
})
.then(function(firstCommitOnMaster){
// History returns an event.
var history = firstCommitOnMaster.history(nodegit.Revwalk.SORT.TIME,nodegit.Revwalk.SORT.REVERSE);
var sh = [];
var t =[];
var m = [];
var names = [];
var s = [];
var nfiles = [];
var numfiles = [];
// History emits "commit" event for each commit in the branch's history
history.on("commit", function(commit) {
t.push([commit.date().getDate(),commit.date().getMonth()+1,commit.date().getFullYear()]);
m.push(commit.message());
sh.push(commit.sha());
names.push(commit.committer().name());
s.push(commit.summary());
if(commit.sha()==firstCommitOnMaster.sha()){
resolve([t,m,sh,names,s,numfiles]);
};
});
history.start();
})
.done();
}).catch(function(e){console.log(e)});
promise.then(result =>{
time=result[0];
mess=result[1];
shas = result[2];
names = result[3];
sums = result[4];
nf = result[5];
let student = {
t: time,
m: mess,
shsh: shas,
n: names,
sum: sums,
numf: nf,
};
let data = JSON.stringify(student, null, 2);
fs.writeFileSync('fileJ.json', data, (err) => {
if (err) throw err;
console.log('Data written to file');
});
}).catch(function(e){console.log(e)});
但是我的问题是做同样的事情,但是在提交中,使用nodegit在两个分支之间列出了不同的提交。
我所发现的主要是在GitBash中,推荐:
$ git log --left-right --graph --cherry-pick --oneline feature...branch
我的代码应将master与早午餐进行比较,例如网站上的此工具: Compare tool on a site
然后像使用母版代码一样,以JSON获取所有提交和存储的信息。 谢谢大家的帮助。