使用nodegit列出两个分支之间的不同提交

时间:2019-02-11 10:44:37

标签: javascript git github nodegit node-github

在我的程序中,我使用的是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获取所有提交和存储的信息。 谢谢大家的帮助。

0 个答案:

没有答案